Domains
Overview
A geospatial domain is a (discretized) region in physical space. For example, a collection of rain gauge stations can be represented as a PointSet
in the map. Similarly, a collection of states in a given country can be represented as a GeometrySet
of polygons.
We provide flexible domain types for advanced geospatial workflows via the Meshes.jl submodule. The domains can consist of sets (or "soups") of geometries as it is most common in GIS or be actual meshes with topological information.
Meshes.Domain
— TypeDomain{M,CRS}
A domain is an indexable collection of geometries (e.g. mesh) in a given manifold M
with point coordinates specified in a coordinate reference system CRS
.
Meshes.Mesh
— TypeMesh{M,CRS,TP}
A mesh of geometries in a given manifold M
with point coordinates specified in a coordinate reference system CRS
. Unlike a general domain, a mesh has a well-defined topology TP
.
The list of supported domains is continuously growing. The following code can be used to print an updated list in any project environment:
# packages to print type tree
using InteractiveUtils
using AbstractTrees
# load framework's domains
using GeoStats
# define the tree of types
AbstractTrees.children(T::Type) = subtypes(T)
# print all currently available transforms
AbstractTrees.print_tree(Domain)
Domain
├─ CylindricalTrajectory
├─ GeometrySet
├─ Mesh
│ ├─ RectilinearGrid
│ ├─ RegularGrid
│ ├─ SimpleMesh
│ ├─ StructuredGrid
│ └─ TransformedMesh
├─ SubDomain
└─ TransformedDomain
Examples
PointSet
Meshes.PointSet
— TypePointSet(points)
A set of points
(a.k.a. point cloud) representing a Domain
.
Examples
All point sets below are the same and contain two points in R³:
julia> PointSet([Point(1,2,3), Point(4,5,6)])
julia> PointSet(Point(1,2,3), Point(4,5,6))
julia> PointSet([(1,2,3), (4,5,6)])
julia> PointSet((1,2,3), (4,5,6))
pset = PointSet(rand(Point, 100))
viz(pset)
data:image/s3,"s3://crabby-images/1709a/1709ac0bb1298200ac410e5016e3a650d44881f8" alt="Example block output"
GeometrySet
Meshes.GeometrySet
— TypeGeometrySet(geometries)
A set of geometries
representing a Domain
.
Examples
Set containing two balls centered at (0.0, 0.0)
and (1.0, 1.0)
:
julia> GeometrySet([Ball((0.0, 0.0)), Ball((1.0, 1.0))])
Notes
- Geometries with different CRS will be projected to the CRS of the first geometry.
tria = Triangle((0.0, 0.0), (1.0, 1.0), (0.0, 1.0))
quad = Quadrangle((1.0, 1.0), (2.0, 1.0), (2.0, 2.0), (1.0, 2.0))
gset = GeometrySet([tria, quad])
viz(gset, showsegments = true)
data:image/s3,"s3://crabby-images/2d1c2/2d1c2a24248eed001b44397fdc965388e369838d" alt="Example block output"
RegularGrid
Meshes.RegularGrid
— TypeRegularGrid(dims, origin, spacing)
A regular grid with dimensions dims
, lower left corner at origin
and cell spacing spacing
. The three arguments must have the same length.
RegularGrid(dims, origin, spacing, offset)
A regular grid with dimensions dims
, with lower left corner of element offset
at origin
and cell spacing spacing
.
RegularGrid(start, finish, dims=dims)
Alternatively, construct a regular grid from a start
point to a finish
with dimensions dims
.
RegularGrid(start, finish, spacing)
Alternatively, construct a regular grid from a start
point to a finish
point using a given spacing
.
RegularGrid(dims)
RegularGrid(dim1, dim2, ...)
Finally, a regular grid can be constructed by only passing the dimensions dims
as a tuple, or by passing each dimension dim1
, dim2
, ... separately. In this case, the origin and spacing default to (0,0,...) and (1,1,...).
Examples
Create a 3D grid with 100x100x50 hexahedrons:
julia> RegularGrid(100, 100, 50)
Create a 2D grid with 100 x 100 quadrangles and origin at (10.0, 20.0):
julia> RegularGrid((100, 100), (10.0, 20.0), (1.0, 1.0))
Create a 1D grid from -1 to 1 with 100 segments:
julia> RegularGrid((-1.0,), (1.0,), dims=(100,))
See also CartesianGrid
.
Meshes.CartesianGrid
— TypeCartesianGrid(args...; kwargs...)
A Cartesian grid is a RegularGrid
where all arguments are forced to have Cartesian
coordinates. Please check the docstring of RegularGrid
for more information on possible args
and kwargs
.
See also RegularGrid
.
grid = CartesianGrid(10, 10, 10)
viz(grid, showsegments = true)
data:image/s3,"s3://crabby-images/ca326/ca3260ae860c1492e1f38485ddf6c1f8cab954c1" alt="Example block output"