pygplates.resolve_topologies
- pygplates.resolve_topologies(topological_features, rotation_model, resolved_topologies, reconstruction_time[, resolved_topological_sections][, anchor_plate_id][, default_resolve_topology_parameters][, **output_parameters])
Resolve topological features (lines, boundaries and networks) to a specific geological time.
- Parameters:
topological_features (
FeatureCollection
, or string/os.PathLike
, orFeature
, or sequence ofFeature
, or sequence of any combination of those four types) – The topological boundary and network features and the topological section features they reference (regular and topological lines) as a feature collection, or filename, or feature, or sequence of features, or a sequence (eg,list
ortuple
) of any combination of those four types. Note: Each entry can optionally be a 2-tuple (entry,ResolveTopologyParameters
) to override default_resolve_topology_parameters for that entry.rotation_model (
RotationModel
. OrFeatureCollection
, or string/os.PathLike
, orFeature
, or sequence ofFeature
, or sequence of any combination of those four types) – A rotation model. Or a rotation feature collection, or a rotation filename, or a rotation feature, or a sequence of rotation features, or a sequence of any combination of those four types.resolved_topologies (string/
os.PathLike
orlist
) – theresolved topological lines
,resolved topological boundaries
andresolved topological networks
(depending on the optional keyword argument resolve_topology_types - see output_parameters table) are either exported to a file (with specified filename) or appended to a pythonlist
(note that the list is not cleared first)reconstruction_time (float or
GeoTimeInstant
) – the specific geological time to resolve toresolved_topological_sections (string/
os.PathLike
orlist
) – Theresolved topological sections
are either exported to a file (with specified filename) or appended to a pythonlist
(note that the list is not cleared first). Default is to do neither.anchor_plate_id (int) – The anchored plate id used during reconstruction. Defaults to the default anchor plate of rotation_model.
default_resolve_topology_parameters (
ResolveTopologyParameters
) – Default parameters used to resolve topologies. Note that these can optionally be overridden in topological_features. Defaults todefault-constructed ResolveTopologyParameters
).output_parameters – Variable number of keyword arguments specifying output parameters (see table below). Default is no keyword arguments.
- Raises:
OpenFileForReadingError if any input file is not readable (when filenames specified)
- Raises:
OpenFileForWritingError if resolved_topologies is a filename and it is not writeable
- Raises:
FileFormatNotSupportedError if any input file format (identified by any topological and rotation filename extensions) does not support reading (when filenames specified), or if resolved_topologies or resolved_topological_sections is a filename and it is not supported for writing
- Raises:
ValueError if reconstruction_time is
distant past
ordistant future
- Raises:
ValueError if resolve_topology_types (if specified) contains a flag that is not one of
pygplates.ResolveTopologyType.line
,pygplates.ResolveTopologyType.boundary
orpygplates.ResolveTopologyType.network
- Raises:
ValueError if resolve_topological_section_types (if specified) contains a flag that is not one of
pygplates.ResolveTopologyType.boundary
orpygplates.ResolveTopologyType.network
The following optional keyword arguments are supported by output_parameters:
Name
Type
Default
Description
resolve_topology_types
int
ResolveTopologyType.boundary | ResolveTopologyType.network
A bitwise combination of any of the following:
ResolveTopologyType.line
:ResolveTopologyType.boundary
:ResolveTopologyType.network
:
Determines whether to output
ResolvedTopologicalLine
,ResolvedTopologicalBoundary
andResolvedTopologicalNetwork
.resolve_topological_section_types
int
Same value as resolve_topology_types (if specified), otherwise its default value
ResolveTopologyType.boundary | ResolveTopologyType.network
A bitwise combination of any of the following:
ResolveTopologyType.boundary
:ResolveTopologyType.network
:
Note
ResolveTopologyType.line
is excluded since only topologies with boundaries are considered.Determines whether
ResolvedTopologicalBoundary
orResolvedTopologicalNetwork
(or both types) are referenced in theresolved topological sections
of resolved_topological_sections.export_topological_line_sub_segments
bool
True
Export the individual sub-segments of each boundary segment that came from a resolved topological line (instead of exporting a single geometry per boundary segment).Note
Only applies when exporting to a file specified with resolved_topological_sections.
export_wrap_to_dateline
bool
True
Wrap/clip resolved topologies to the dateline (currently ignored unless exporting to an ESRI Shapefile format file).Note
Only applies when exporting to a file (ESRI Shapefile).
export_force_boundary_orientation
int
None
(don’t force)Optionally force boundary orientation (clockwise or counter-clockwise):
PolygonOnSphere.Orientation.clockwise
PolygonOnSphere.Orientation.counter_clockwise
Note
Only applies to resolved topological boundaries and networks.
Note
ESRI Shapefiles always use clockwise orientation.
Warning
Only applies when exporting to a file (except ESRI Shapefile).
The argument topological_features consists of the topologicalfeatures
as well as the topological sections (alsofeatures
) that are referenced by the topological features.They can all be mixed in a singlefeature collection
or file, or they can be distributed across multiplefeature collections
or files.For example the dynamic polygons in the GPlates geodata have everything in a single file.Note
Topological sections can be regular features or topological line features. The latter are typically used for sections of a plate polygon (or network) boundary that are deforming.
The argument resolved_topologies can be either an export filename or a pythonlist
.In the latter case the resolved topologies generated by the reconstruction are appended to the pythonlist
(instead of exported to a file).A similar argument resolved_topological_sections can also be either an export filename or a pythonlist
.In the latter case theresolved topological sections
generated by the reconstruction are appended to the pythonlist
(instead of exported to a file).Both resolved_topologies and resolved_topological_sections are output in the same order as that of their respective features in topological_features (the order across feature collections is also retained). This happens regardless of whether topological_features, and resolved_topologies and resolved_topological_sections, include files or not.Note
Resolved topological sections
can be used to find the unique (non-overlapping) set of boundary sub-segments that are shared by the resolved topologies.Each resolved topology also has a list of its boundary sub-segments but they overlap with the boundary sub-segments of neighbouring topologies.The optional keyword argument resolve_topology_types (see output_parameters table) determines the type of resolved topologies output to resolved_topologies.This can consist ofresolved topological lines
,resolved topological boundaries
andresolved topological networks
(and any combination of them).By default onlyresolved topological boundaries
andresolved topological networks
are output sinceresolved topological lines
are typically only used as topological sections for resolved topological boundaries and networks.A similar optional keyword argument is resolve_topological_section_types (see output_parameters table).This determines which resolved topology types are referenced in theshared sub-segments
of the resolved_topological_sections.The following export file formats are currently supported:
Export File Format
Filename Extension
ESRI Shapefile
‘.shp’
GeoJSON
‘.geojson’ or ‘.json’
OGR GMT
‘.gmt’
GMT xy
‘.xy’
Warning
Currently, resolved topological networks exported to OGR GMT or ESRI Shapefile will not be loaded if the exported file is subsequently loaded into GPlates.The resolved topological networks will still be in the exported file though.Note
When exporting to a file, the filename extension of resolved_topologies determines the export file format.
Note
topological_features can be a
FeatureCollection
or a filename or aFeature
or a sequence offeatures
, or a sequence (eg,list
ortuple
) of any combination of those four types.Note
rotation_model can be either a
RotationModel
or a rotationFeatureCollection
or a rotation filename or a sequence (eg,list
ortuple
) containing rotationFeatureCollection
instances or filenames (or a mixture of both). When aRotationModel
is not specified then a temporary one is created internally (and hence is less efficient if this function is called multiple times with the same rotation data).If any filenames are specified then
FeatureCollection
is used internally to read feature collections from those files.Resolving a file containing dynamic plate polygons to a shapefile at 10Ma:
pygplates.resolve_topologies( 'dynamic_plate_polygons.gpml', 'rotations.rot', 'resolved_plate_polygons_10Ma.shp', 10)
Resolving the same file but also exporting resolved topological sections.These are the unique (non-duplicated) segments (shared by neighbouring topology boundaries).pygplates.resolve_topologies( 'dynamic_plate_polygons.gpml', 'rotations.rot', 'resolved_plate_polygons_10Ma.shp', 10, 'resolved_plate_segments_10Ma.shp')
Resolving only topological networks in a file containing both dynamic plate polygons and deforming networks:
pygplates.resolve_topologies( 'plate_polygons_and_networks.gpml', 'rotations.rot', 'resolved_networks_10Ma.shp', 10, resolve_topology_types=pygplates.ResolveTopologyType.network)
Writing only resolved networks to
resolved_networks_10Ma.shp
but writing shared boundary segments between resolved plate polygons and networks toresolved_boundary_segments_10Ma.shp
:pygplates.resolve_topologies( 'plate_polygons_and_networks.gpml', 'rotations.rot', 'resolved_networks_10Ma.shp', 10, 'resolved_boundary_segments_10Ma.shp', resolve_topology_types=pygplates.ResolveTopologyType.network, resolve_topological_section_types=pygplates.ResolveTopologyType.boundary | pygplates.ResolveTopologyType.network)
Resolving to a list of topologies and a list of topological sections:
resolved_topologies = [] resolved_topological_sections = [] pygplates.resolve_topologies( 'plate_polygons_and_networks.gpml', 'rotations.rot', resolved_topologies, 10, resolved_topological_sections)
See also
Changed in version 0.29: The output order of resolved_topological_sections is now same as that of their respective features in topological_features (the order across feature collections is also retained). Previously the order was only retained for resolved_topologies.
Changed in version 0.31: Added default_resolve_topology_parameters argument.
Changed in version 0.33: Added export_topological_line_sub_segments argument.
Changed in version 0.44: Filenames can be os.PathLike (such as pathlib.Path) in addition to strings.