Enumerations | |
enum | regina::SurfaceExportFields { regina::surfaceExportName = 0x0001, regina::surfaceExportEuler = 0x0002, regina::surfaceExportOrient = 0x0004, regina::surfaceExportSides = 0x0008, regina::surfaceExportBdry = 0x0010, regina::surfaceExportLink = 0x0020, regina::surfaceExportType = 0x0040, regina::surfaceExportNone = 0, regina::surfaceExportAllButName = 0x007e, regina::surfaceExportAll = 0x007f } |
Indicates a set of additional fields that can be exported as part of a normal surface list. More... | |
Functions | |
bool | regina::writeCSVStandard (const char *filename, NNormalSurfaceList &surfaces, int additionalFields=surfaceExportAll) |
Exports the given list of normal surfaces as a plain text CSV (comma-separated value) file. | |
bool | regina::writeCSVEdgeWeight (const char *filename, NNormalSurfaceList &surfaces, int additionalFields=surfaceExportAll) |
Exports the given list of normal surfaces as a plain text CSV (comma-separated value) file. | |
NContainer * | regina::readDehydrationList (const char *filename, unsigned colDehydrations=0, int colLabels=-1, unsigned long ignoreLines=0) |
Reads a list of dehydrated triangulations from the given text file. | |
NTriangulation * | regina::readOrb (const char *filename) |
Reads a triangulation from the given Orb / Casson file. | |
NTriangulation * | regina::readSnapPea (const char *filename) |
Reads a triangulation from the given SnapPea file. | |
bool | regina::writeSnapPea (const char *filename, NTriangulation &tri) |
Writes the given triangulation to the given file in SnapPea format. | |
std::string | regina::stringToToken (const char *str) |
Returns a token derived from the given string. | |
std::string | regina::stringToToken (const std::string &str) |
Returns a token derived from the given string. |
Indicates a set of additional fields that can be exported as part of a normal surface list.
This type can be used as a bitmask: to describe a set of fields, simply combine several individual fields using bitwise or.
The list of available fields may grow with future releases of Regina.
surfaceExportName |
Represents the user-assigned surface name.
|
surfaceExportEuler |
Represents the calculated Euler characteristic of a surface.
This will be an integer, and will be left empty if the Euler characteristic cannot be computed. |
surfaceExportOrient |
Represents the calculated property of whether a surface is orientable.
This will be |
surfaceExportSides |
Represents the calculated property of whether a surface is one-sided or two-sided.
This will be the integer 1 or 2, or will be left empty if the "sidedness" cannot be computed. |
surfaceExportBdry |
Represents the calculated property of whether a surface is bounded.
This will be one of the strings "closed", "real bdry" or "infinite" (where "infinite" indicates a surface with infinitely many discs). |
surfaceExportLink |
Represents whether a surface is a single vertex link or a thin edge link.
See NNormalSurface::isVertexLink() and NNormalSurface::isThinEdgeLink() for details. This will be written as a human-readable string. |
surfaceExportType |
Represents any additional high-level properties of a surface, such as whether it is a splitting surface or a central surface.
This will be written as a human-readable string. This field is somewhat arbitrary, and the precise properties it describes are subject to change in future releases of Regina. |
surfaceExportNone |
Indicates that no additional fields should be exported.
|
surfaceExportAllButName |
Indicates that all available fields should be exported, except for the user-assigned surface name.
Since the list of available fields may grow with future releases, the numerical value of this constant may change as a result. |
surfaceExportAll |
Indicates that all available fields should be exported, including the user-assigned surface name.
Since the list of available fields may grow with future releases, the numerical value of this constant may change as a result. |
NContainer* regina::readDehydrationList | ( | const char * | filename, | |
unsigned | colDehydrations = 0 , |
|||
int | colLabels = -1 , |
|||
unsigned long | ignoreLines = 0 | |||
) |
Reads a list of dehydrated triangulations from the given text file.
The file should contain one dehydration string per line. These strings will be rehydrated as described in NTriangulation::insertRehydration().
A newly allocated container will be returned; the imported triangulations will be inserted as children of this container. The container will not be assigned a label. The individual triangulations will be assigned labels according to the parameter colLabels.
If any dehydrations strings are invalid, these will be recorded in an additional text packet that will be the last child of the returned container.
If an I/O error occurred while trying to read the given file, 0 will be returned.
In its simplest form, the text file can simply contain one dehydration string per line and nothing else. However, more complex formats are allowed. In particular, by passing appropriate values for the arguments colDehydrations and colLabels, the dehydration strings and triangulation packet labels can be taken from arbitrary columns of the text file. Columns are considered to be separated by whitespace and are numbered beginning at 0.
filename | the name of the text file from which to read. | |
colDehydrations | the column of the text file containing the dehydration strings. | |
colLabels | the column of the text file containing the triangulation packet labels. If this is negative then the dehydration strings themselves will be used as packet labels. | |
ignoreLines | the number of lines at the beginning of the text file that should be ignored completely. |
NTriangulation* regina::readOrb | ( | const char * | filename | ) |
Reads a triangulation from the given Orb / Casson file.
A newly allocated triangulation will be returned; it is the user's responsibility to deallocate this when it is finished with.
The packet label of the new triangulation will be the manifold name read from the second line of the Orb / Casson file. The first line of the Orb / Casson file must simply be ``% orb
''.
If the file could not be read or if the data was not in the correct format, 0 will be returned.
filename | the name of the Orb / Casson file from which to read. |
NTriangulation* regina::readSnapPea | ( | const char * | filename | ) |
Reads a triangulation from the given SnapPea file.
A newly allocated triangulation will be returned; it is the user's responsibility to deallocate this when it is finished with.
The packet label of the new triangulation will be the manifold name read from the second line of the SnapPea file. The first line of the SnapPea file must simply be ``% Triangulation
.
If the file could not be read or if the data was not in the correct format, 0 will be returned.
filename | the name of the SnapPea file from which to read. |
std::string regina::stringToToken | ( | const std::string & | str | ) |
Returns a token derived from the given string.
All whitespace characters in the given string will be replaced with an underscore.
str | the string on which to base the token. |
std::string regina::stringToToken | ( | const char * | str | ) |
Returns a token derived from the given string.
All whitespace characters in the given string will be replaced with an underscore.
str | the string on which to base the token. |
bool regina::writeCSVEdgeWeight | ( | const char * | filename, | |
NNormalSurfaceList & | surfaces, | |||
int | additionalFields = surfaceExportAll | |||
) |
Exports the given list of normal surfaces as a plain text CSV (comma-separated value) file.
CSV files are human-readable and human-editable, and are suitable for importing into spreadsheets and databases.
The surfaces will be exported in edge weight coordinates. Thus there will be one coordinate for each edge of the underlying triangulation; each such coordinate will become a separate field in the CSV file.
As well as the normal surface coordinates, additional properties of the normal surfaces (such as Euler characteristic, orientability, and so on) can be included as extra fields in the export. Users can select precisely which properties to include by passing a bitmask formed from regina::SurfaceExportFields constants.
The CSV format used here begins with a header row, and uses commas as field separators. Text fields with arbitrary contents are placed inside double quotes, and the double quote character itself is represented by a pair of double quotes. Thus the string my "normal" surface's name
would be stored as "my ""normal"" surface's name"
.
filename | the name of the CSV file to export to. | |
surfaces | the list of normal surfaces to export. | |
additionalFields | a bitwise combination of regina::SurfaceExportFields constants indicating which additional properties of surfaces should be included in the export. |
true
if the export was successful, or false
otherwise. bool regina::writeCSVStandard | ( | const char * | filename, | |
NNormalSurfaceList & | surfaces, | |||
int | additionalFields = surfaceExportAll | |||
) |
Exports the given list of normal surfaces as a plain text CSV (comma-separated value) file.
CSV files are human-readable and human-editable, and are suitable for importing into spreadsheets and databases.
The surfaces will be exported in standard coordinates (tri-quad coordinates for normal surfaces, or tri-quad-oct coordinates for almost normal surfaces). Each coordinate will become a separate field in the CSV file.
As well as the normal surface coordinates, additional properties of the normal surfaces (such as Euler characteristic, orientability, and so on) can be included as extra fields in the export. Users can select precisely which properties to include by passing a bitmask formed from regina::SurfaceExportFields constants.
The CSV format used here begins with a header row, and uses commas as field separators. Text fields with arbitrary contents are placed inside double quotes, and the double quote character itself is represented by a pair of double quotes. Thus the string my "normal" surface's name
would be stored as "my ""normal"" surface's name"
.
filename | the name of the CSV file to export to. | |
surfaces | the list of normal surfaces to export. | |
additionalFields | a bitwise combination of regina::SurfaceExportFields constants indicating which additional properties of surfaces should be included in the export. |
true
if the export was successful, or false
otherwise. bool regina::writeSnapPea | ( | const char * | filename, | |
NTriangulation & | tri | |||
) |
Writes the given triangulation to the given file in SnapPea format.
All information aside from tetrahedron gluings will be flagged as unknown for SnapPea to recalculate. The manifold name written in the file will be derived from the packet label.
filename | the name of the SnapPea file to which to write. | |
tri | the triangulation to write to the SnapPea file. |
true
if the export was successful, or false
otherwise.