Regina 7.3 Calculation Engine
|
Specifies a single normal disc in a normal surface. More...
#include <surface/disc.h>
Public Member Functions | |
DiscSpec ()=default | |
Creates a new uninitialised disc specifier. More... | |
DiscSpec (size_t newTetIndex, int newType, unsigned long newNumber) | |
Creates a new disc specifier containing the given values. More... | |
DiscSpec (const DiscSpec &cloneMe)=default | |
Creates a new disc specifier that is a clone of the given specifier. More... | |
DiscSpec & | operator= (const DiscSpec &cloneMe)=default |
Copies the values from the given disc specifier into this specifier. More... | |
bool | operator== (const DiscSpec &other) const |
Determines if this and the given disc specifier contain identical information. More... | |
bool | operator!= (const DiscSpec &other) const |
Determines if this and the given disc specifier contain different information. More... | |
Public Attributes | |
size_t | tetIndex |
The index in the triangulation of the tetrahedron containing the disc. More... | |
int | type |
The disc type; this is between 0 and 9 inclusive, as described in the DiscSpec class notes. More... | |
unsigned long | number |
Specifies which disc of the particular type in the particular tetrahedron is being referred to; discs are numbered as described in the DiscSpec class notes. More... | |
Friends | |
std::ostream & | operator<< (std::ostream &out, const DiscSpec &spec) |
Writes the given disc specifier to the given output stream. More... | |
Specifies a single normal disc in a normal surface.
There are 10 disc types. Types 0-3 represent triangles 0-3, types 4-6 represent quads 0-2 and types 7-9 represent octagons 0-2.
Discs of a specific type are assigned numbers from 0 upwards. Triangular discs are numbered outwards from the vertex they surround. Quad discs and octagonal discs are numbered outwards away from vertex 0 of the tetrahedron.
Note that, unlike DiscType in which the meaning of DiscType::type is flexible, the meaning of DiscSpec::type is fixed as described above.
These objects are small enough to pass by value and swap with std::swap(), with no need for any specialised move operations or swap functions.
unsigned long
. See the precondition below.
|
default |
Creates a new uninitialised disc specifier.
|
inline |
Creates a new disc specifier containing the given values.
newTetIndex | the index in the triangulation of the tetrahedron containing the disc. |
newType | the disc type; this is between 0 and 9 inclusive, as described in the DiscSpec class notes. |
newNumber | specifies which disc of the particular type in the particular tetrahedron is being referred to; discs are numbered as described in the DiscSpec class notes. |
|
default |
Creates a new disc specifier that is a clone of the given specifier.
cloneMe | the disc specifier to clone. |
|
inline |
Determines if this and the given disc specifier contain different information.
other | the disc specifier to compare with this. |
true
if and only if this and the given disc specifier contain different information. Copies the values from the given disc specifier into this specifier.
cloneMe | the disc specifier whose values should be copied. |
|
inline |
Determines if this and the given disc specifier contain identical information.
other | the disc specifier to compare with this. |
true
if and only if this and the given disc specifier contain identical information.
|
friend |
Writes the given disc specifier to the given output stream.
The disc specifier will be written as a triple (tetIndex, type, number)
.
out | the output stream to which to write. |
spec | the disc specifier to write. |
unsigned long regina::DiscSpec::number |
Specifies which disc of the particular type in the particular tetrahedron is being referred to; discs are numbered as described in the DiscSpec class notes.
size_t regina::DiscSpec::tetIndex |
The index in the triangulation of the tetrahedron containing the disc.
int regina::DiscSpec::type |
The disc type; this is between 0 and 9 inclusive, as described in the DiscSpec class notes.