![]() |
An instance of data type Ray_d is a ray in d-dimensional Euclidean space. It starts in a point called the source of r and it goes to infinity.
| |
the representation type.
| |
| |
the ring type.
| |
| |
the field type.
| |
| |
the linear algebra layer.
|
| |
introduces some ray in
d-dimensional space.
| |
| |
introduces a ray
through p and q and starting at p. Precondition: p and q are distinct and have the same dimension. Precondition: p.dimension()==q.dimension().
| |
| |
introduces
a ray starting in p with direction dir. Precondition: p and dir have the same dimension and dir is not degenerate. Precondition: p.dimension()==dir.dimension().
| |
| |
introduces a ray through
s.source() and s.target() and starting at
s.source(). Precondition: s is not degenerate.
|
|
| returns the dimension of the ambient space. |
|
| returns the source point of r. |
|
|
returns a point on
r. point(0) is the source. point(i), with i>0, is
different from the source. Precondition: i ![]() |
| ||
| returns the direction of r. | |
|
| |
returns the supporting line of r. | ||
|
| returns the ray with direction opposite to r and starting in source. |
|
| |
returns t(r). Precondition: r.dimension()==t.dimension(). | ||
|
| |
returns
r+v, i.e., r translated by vector v. Precondition: r.dimension()==v.dimension(). | ||
|
| |
A point is on r,
iff it is equal to the source of r, or if it is in the interior
of r. Precondition: r.dimension()==p.dimension(). |
|
| |
returns true if the unoriented supporting lines of r1 and
r2 are parallel and false otherwise. Precondition: r1.dimension()==r2.dimension(). |
Rays are implemented by a pair of points as an item type. All operations like creation, initialization, tests, direction calculation, input and output on a ray r take time O(r.dimension()). dimension(), coordinate and point access, and identity test take constant time. The space requirement is O(r.dimension()).