Reference

This document lists the Python functions and classes that make up the GPlates Python Application Programming Interface (API) known as pyGPlates.

Note

Please see the installation section for information on how to install pyGPlates.

Note

Please see the tutorial section to help get you started using pyGPlates.

Reconstruction

Classes to query the history of reconstructions:

pygplates.ReconstructModel

A history of reconstructed geometries over geological time.

pygplates.ReconstructSnapshot

A snapshot of reconstructed regular features (including motion paths and flowlines) at a specific geological time.

Function to reconstruct backward and forward in time:

pygplates.reconstruct(...)

Reconstruct regular geological features (including motion paths and flowlines) to a specific geological time.

pygplates.reverse_reconstruct(...)

Reverse reconstruct geological features from a specific geological time.

Classes resulting from reconstructing regular features at a particular reconstruction time.

pygplates.ReconstructedFeatureGeometry

The geometry of a feature reconstructed to a geological time.

pygplates.ReconstructedFlowline

The reconstructed history of plate motion away from a spreading ridge in the form of a path of points over geological time.

pygplates.ReconstructedMotionPath

The reconstructed history of a plate's motion in the form of a path of points over geological time.

All three above reconstructed feature types inherit from:

pygplates.ReconstructionGeometry

The base class inherited by all derived reconstruction geometry classes.

Topology

Classes to query the history of a topological model, and reconstruct regular features using it:

pygplates.TopologicalModel

A history of topologies over geological time.

pygplates.TopologicalSnapshot

A snapshot of resolved topological features (lines, boundaries and networks) at a specific geological time.

pygplates.ReconstructedGeometryTimeSpan

A history of geometries reconstructed using topologies over geological time.

pygplates.TopologyPointLocation

Locates a point in a specific resolved topological boundary or network (deforming region or interior rigid block).

Parameters to control how topologies are resolved:

pygplates.ResolveTopologyParameters

Parameters used to resolve topologies.

Function to resolve topologies:

pygplates.resolve_topologies(...)

Resolve topological features (lines, boundaries and networks) to a specific geological time.

Classes resulting from resolving topological features at a particular reconstruction time.

pygplates.ResolvedTopologicalLine

The geometry of a topological line feature resolved to a geological time.

pygplates.ResolvedTopologicalBoundary

The geometry of a topological boundary feature resolved to a geological time.

pygplates.ResolvedTopologicalNetwork

The geometry of a topological network feature resolved to a geological time.

All three above resolved topology types inherit from:

pygplates.ReconstructionGeometry

The base class inherited by all derived reconstruction geometry classes.

The following class represents a sub-segment of a single resolved topological line, boundary or network.

pygplates.ResolvedTopologicalSubSegment

The subset of vertices of a reconstructed topological section that contribute to the geometry of a resolved topology.

The following classes represent sub-segments shared by one or more resolved topological boundaries and/or networks.

pygplates.ResolvedTopologicalSection

The sequence of shared sub-segments of a reconstructed topological section that uniquely contribute to the boundaries of one or more resolved topologies.

pygplates.ResolvedTopologicalSharedSubSegment

The shared subset of vertices of a reconstructed topological section that uniquely contribute to the boundaries of one or more resolved topologies.

The following class contains the triangulation of the deforming region of a resolved topological network.

pygplates.NetworkTriangulation

The Delaunay triangulation of a resolved topological network.

Velocity and strain

Functions to calculate velocities:

pygplates.calculate_velocities(...)

Calculate velocities at a sequence of points assuming movement due to a finite rotation over a time interval.

The following classes represent strain rate and strain (at a particular surface location).

pygplates.Strain

The strain at a particular location (parcel of crust) is tracked over time and represents the accumulated deformation undergone by that parcel of crust.

pygplates.StrainRate

The strain rate at a particular location (parcel of crust) represents the rate at which deformation occurs at that parcel of crust.

The following class contains statistics (like convergence velocity) at a point on a plate boundary.

pygplates.PlateBoundaryStatistic

Statistics at a point on a plate boundary.

Rotation

RotationModel is the main class for getting finite and stage rotations from rotation models/files.
FiniteRotation is a useful maths class for rotating geometries (and vectors).
NetRotationModel is for calculating net rotation of topological plates and deforming networks.

pygplates.RotationModel

Query a finite rotation of a moving plate relative to any other plate, optionally between two instants in geological time.

pygplates.FiniteRotation

Represents the motion of plates on the surface of the globe.

pygplates.NetRotationModel

Net rotation of topological plates and deforming networks.

pygplates.NetRotationSnapshot

Net rotation snapshot of topological plates and deforming networks at a particular reconstruction time.

pygplates.NetRotation

Net rotation of regional or global crust.

Note

ReconstructionTreeEdge is only needed for very advanced scenarios.

pygplates.ReconstructionTree

Represents the plate-reconstruction hierarchy of total reconstruction poles at an instant in geological time.

pygplates.ReconstructionTreeEdge

A reconstruction tree edge represents a moving/fixed plate pair in the graph of the plate-reconstruction hierarchy.

Functions to find and fix finite rotation crossovers (transitions of fixed plate):

pygplates.find_crossovers(rotation_features, ...)

Find crossovers in rotation features.

pygplates.synchronise_crossovers(...)

Synchronise crossovers in rotation features.

Plate Partitioning

Functions to partition into plates:

pygplates.partition_into_plates(...)

Partition features into plates.

Classes to partition into plates:

pygplates.PlatePartitioner

Partition features or geometries into plates.

File I/O

Classes that read/write data from/to files:

pygplates.FeatureCollection

A feature collection aggregates a set of features into a collection.

Feature

Feature is the main class to go to for querying/setting geological feature properties.

pygplates.Feature

The feature is an abstract model of some geological or plate-tectonic object or concept of interest defined by the GPlates Geological Information Model (GPGIM).

pygplates.FeatureCollection

A feature collection aggregates a set of features into a collection.

Feature property

A feature is essentially a list of properties where each property has a name and a value.

Note

PropertyValueVisitor is only needed for very advanced scenarios.

pygplates.Property

Associates a property name with a property value.

pygplates.PropertyName

The namespace-qualified name of a property.

pygplates.PropertyValue

The base class inherited by all derived property value classes.

pygplates.PropertyValueVisitor

The base class inherited by all derived property value visitor classes.

Feature property value

These classes represent the various types of property values that a feature can contain.
Property values contain things such as plate IDs, geometries, finite rotations, strings, numbers, etc. All these property values inherit from PropertyValue.

Note

Some of these property values can be obtained more easily using Feature directly.

pygplates.Enumeration

A property value that represents a finite set of accepted (string) values per enumeration type.

pygplates.GmlDataBlock

A data block that associates each scalar type with a sequence of floating-point scalar values.

pygplates.GmlLineString

A property value representing a polyline geometry.

pygplates.GmlMultiPoint

A property value representing a multi-point geometry.

pygplates.GmlOrientableCurve

A property value representing a polyline geometry with a positive or negative orientation.

pygplates.GmlPoint

A property value representing a point geometry.

pygplates.GmlPolygon

A property value representing a polygon geometry.

pygplates.GmlTimeInstant

A property value representing an instant in geological time.

pygplates.GmlTimePeriod

A property value representing a period in geological time (time of appearance to time of disappearance).

pygplates.GpmlArray

A sequence of property value elements.

pygplates.GpmlFiniteRotation

A property value that represents a finite rotation.

pygplates.GpmlKeyValueDictionary

A dictionary of key/value pairs that associates string keys with integer, float or string values.

pygplates.GpmlOldPlatesHeader

A property value containing metadata inherited from imported PLATES data files.

pygplates.GpmlPlateId

A property value that represents a plate id.

pygplates.GpmlPolarityChronId

A property value that identifies an Isochron or MagneticAnomalyIdentification.

pygplates.XsBoolean

A property value that represents a boolean value.

pygplates.XsDouble

A property value that represents a double-precision floating-point number.

pygplates.XsInteger

A property value that represents an integer number.

pygplates.XsString

A property value that represents a string.

The following subset of property value classes represent topological lines, polygons and networks.

pygplates.GpmlTopologicalLine

A topological line geometry that is resolved from topological sections.

pygplates.GpmlTopologicalPolygon

A topological polygon geometry that is resolved from topological sections.

pygplates.GpmlTopologicalNetwork

A topological deforming network that is resolved from boundary topological sections and interior geometries.

The following subset of property value classes represent the topological sections that topologies are created from.

pygplates.GpmlTopologicalSection

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

pygplates.GpmlTopologicalSectionList

A list of GpmlTopologicalSection instances.

pygplates.GpmlTopologicalPoint

A topological section referencing a point geometry.

pygplates.GpmlTopologicalLineSection

A topological section referencing a line geometry.

pygplates.GpmlPropertyDelegate

A property value that represents a reference, or delegation, to a property in another feature.

pygplates.GpmlPropertyDelegateList

A list of GpmlPropertyDelegate instances.

The following subset of property value classes are time-dependent wrappers. These are what enable the above property values to vary over geological time.

Note

There is currently limited support for time-dependent properties.

pygplates.GpmlConstantValue

The most basic case of a time-dependent property value is one that is constant for all time. The other two types are GpmlIrregularSampling and GpmlPiecewiseAggregation. The GPlates Geological Information Model (GPGIM) defines those properties that are time-dependent (see http://www.gplates.org/gpml.html) and those that are not. For example, a GpmlPlateId property value is used in gpml:reconstructionPlateId properties, of general feature types, and also in gpml:relativePlate properties of motion path features. In the former case it is expected to be wrapped in a GpmlConstantValue while in the latter case it is not.

pygplates.GpmlIrregularSampling

A time-dependent property consisting of a sequence of time samples irregularly spaced in time.

pygplates.GpmlPiecewiseAggregation

A time-dependent property consisting of a sequence of time windows each with a constant property value.

The following time sample and time window classes are used by the above time-dependent wrappers to contain property values.

pygplates.GpmlTimeSample

A time sample associates an arbitrary property value with a specific time instant.

pygplates.GpmlTimeSampleList

A list of GpmlTimeSample instances.

pygplates.GpmlTimeWindow

A time window associates an arbitrary property value with a specific time period.

pygplates.GpmlTimeWindowList

A list of GpmlTimeWindow instances.

Geometry

There are four types of geometry:

pygplates.PointOnSphere

Represents a point on the surface of the unit length sphere in 3D cartesian coordinates.

pygplates.MultiPointOnSphere

Represents a multi-point (collection of points) on the surface of the unit length sphere.

pygplates.PolylineOnSphere

Represents a polyline on the surface of the unit length sphere.

pygplates.PolygonOnSphere

Represents a polygon on the surface of the unit length sphere.

All four above geometry types inherit from:

pygplates.GeometryOnSphere

The base class inherited by all derived classes representing geometries on the sphere.

A polyline or a polygon is both a sequence of points and a sequence of segments (between adjacent points). Each segment is a great circle arc:

pygplates.GreatCircleArc

A great-circle arc on the surface of the unit globe.

There is also a latitude/longitude version of a point:

pygplates.LatLonPoint

Represents a point in 2D geographic coordinates (latitude and longitude).

Vector

A vector class, and conversions between global cartesian and local magnitude/azimuth/inclination:

pygplates.LocalCartesian

A local cartesian coordinate system located at a point on the sphere.

pygplates.Vector3D

Represents a vector in 3D cartesian coordinates.

String

String-type classes used in various areas of pyGPlates:

pygplates.EnumerationType

The namespace-qualified type of an enumeration.

pygplates.FeatureId

A feature ID acts as a persistent unique identifier for a feature.

pygplates.FeatureType

The namespace-qualified type of a feature.

pygplates.PropertyName

The namespace-qualified name of a property.

pygplates.ScalarType

The namespace-qualified type of scalar values.

Utility

General utility classes:

pygplates.DateLineWrapper

Wraps geometries to the dateline.

pygplates.Earth

Various Earth-related parameters (such as radius).

pygplates.FeaturesFunctionArgument

A utility class for extracting features from collections and files.

pygplates.GeoTimeInstant

Represents an instant in geological time.

pygplates.Version

A version of pyGPlates (GPlates Python API).