pygplates.GpmlTopologicalSection

class pygplates.GpmlTopologicalSection

Bases: PropertyValue

The base class inherited by all derived topological section property value classes.

The list of derived topological section property value classes includes:

__init__()

Raises an exception This class cannot be instantiated from Python

Methods

__init__

Raises an exception This class cannot be instantiated from Python

accept_visitor(visitor)

Accept a property value visitor so that it can visit this property value.

clone()

Create a duplicate of this property value (derived) instance, including a recursive copy of any nested property values that this instance might contain.

create(feature, [geometry_property_name], ...)

[staticmethod] Create a topological section referencing a feature geometry.

create_network_interior(feature, ...)

[staticmethod] Create a topological network interior referencing a feature geometry.

get_geometry()

Extracts the geometry if this property value contains a geometry.

get_property_delegate()

Returns the property value that references/delegates the source geometry.

get_reverse_orientation()

Returns True if this topological section is a line and it was reversed when contributing to the parent topology.

get_value([time=0])

Extracts the value, of this possibly time-dependent property value, at the reconstruction time.

static create(feature[, geometry_property_name][, reverse_order][, topological_geometry_type])

[staticmethod] Create a topological section referencing a feature geometry.

Parameters:
  • feature (Feature) – the feature referenced by the returned topological section

  • geometry_property_name (PropertyName, or None) – the optional geometry property name used to find the geometry (topological or non-topological), if not specified then the default geometry property name associated with the feature’s type is used instead

  • reverse_order (bool) – whether to reverse the topological section when it’s used to resolve a topological geometry, this is ignored for point sections and only applies to a line section when it does not intersect both its neighbours (when resolving the parent topology) - defaults to False

  • topological_geometry_type (GpmlTopologicalLine or GpmlTopologicalPolygon or GpmlTopologicalNetwork, or None) – optional type of topological geometry that the returned section will be used for (if specified, then used to determine what type of feature geometry can be used as a section)

Return type:

GpmlTopologicalSection (GpmlTopologicalLineSection or GpmlTopologicalPoint), or None

Raises:

ValueError if topological_geometry_type is specified but is not one of the accepted types (GpmlTopologicalLine or GpmlTopologicalPolygon or GpmlTopologicalNetwork)

If geometry_property_name is not specified then the default geometry property name is determined from the feature’s type - see Feature.get_geometry() for more details.

A regular polyline or point can be referenced by any topological geometry (topological line, polygon or network). However a topological line can only be referenced by a topological polygon or network.

Note

It’s fine to ignore reverse_order (leave it as the default) since it is not used when resolving the topological geometry provided it intersects both its neighbouring topological sections (in the topological geometry) - which applies only to line sections (not points). When a line section does not intersect both neighbouring sections then its reverse flag determines its orientation when rubber-banding the topology geometry.

Returns None if:

  • there is not exactly one geometry (topological or non-topological) property named geometry_property_name (or default) in feature, or

  • it’s a regular geometry but it’s not a point or polyline, or

  • it’s a regular point/polyline and topological_geometry_type is a topological network but feature is not reconstructable by plate ID or half-stage rotation (the only supported reconstructable types inside the deforming network Delaunay triangulation), or

  • it’s a topological polygon or network, or

  • it’s a topological line but topological_geometry_type is also a topological line (or not specified)

Create a topological section to be used in a GpmlTopologicalPolygon:

boundary_sections = []

boundary_section = pygplates.GpmlTopologicalSection.create(referenced_feature, topological_geometry_type=pygplates.GpmlTopologicalPolygon)
if boundary_section:
    boundary_sections.append(boundary_section)

...

topological_boundary = pygplates.GpmlTopologicalPolygon(boundary_sections)

topological_boundary_feature = pygplates.Feature(pygplates.FeatureType.gpml_topological_closed_plate_boundary)
topological_boundary_feature.set_topological_geometry(topological_boundary)

Added in version 0.24.

static create_network_interior(feature[, geometry_property_name])

[staticmethod] Create a topological network interior referencing a feature geometry.

Parameters:
  • feature (Feature) – the feature referenced by the returned network interior

  • geometry_property_name (PropertyName, or None) – the optional geometry property name used to find the geometry (topological or non-topological), if not specified then the default geometry property name associated with the feature’s type is used instead

Return type:

GpmlPropertyDelegate, or None

If geometry_property_name is not specified then the default geometry property name is determined from the feature’s type - see Feature.get_geometry() for more details.

Any regular geometry (point, multipoint, polyline, polygon) or topological line can be referenced by a topological network interior.

Note

If a regular polygon geometry is referenced then it will be treated as a rigid interior block in the topological network and will not be part of the deforming region. Anything inside this interior polygon geometry will move rigidly using the plate ID of the referenced feature.

Returns None if:

  • there is not exactly one geometry (topological or non-topological) property named geometry_property_name (or default) in feature, or

  • it’s a regular geometry but feature is not reconstructable by plate ID or half-stage rotation (the only supported reconstructable types inside the deforming network Delaunay triangulation), or

  • it’s a topological polygon or network

Create a topological network interior:

network_interiors = []

network_interior = pygplates.GpmlTopologicalSection.create_network_interior(referenced_interior_feature)
if network_interior:
    network_interiors.append(network_interior)

...
network_boundaries = []

network_boundary = pygplates.GpmlTopologicalSection.create(referenced_boundary_feature)
if network_boundary:
    network_boundaries.append(network_boundary)

...

topological_network = pygplates.GpmlTopologicalNetwork(network_boundaries, network_interiors)

topological_network_feature = pygplates.Feature(pygplates.FeatureType.gpml_topological_network)
topological_network_feature.set_topological_geometry(topological_network)

Added in version 0.24.

get_property_delegate()

Returns the property value that references/delegates the source geometry.

Return type:

GpmlPropertyDelegate

get_reverse_orientation()

Returns True if this topological section is a line and it was reversed when contributing to the parent topology.

Return type:

bool

Note

If this topological section is a point then False will always be returned.