GRASS GIS 3D raster maps use the same coordinate system as 2D raster maps (row count from north to south) with an additional z dimension (depth) counting from bottom to top. The upper left corner (NW) is the origin. 3D rasters are stored using a tile cache based approach. This allows arbitrary read and write operations in the created 3D raster. The size of the tiles can be specified at import time with a given import module such as r3.in.ascii or the data can be retiled using r3.retile after import or creation.
Note that GRASS GIS uses the term 3D raster map or just 3D raster for short, rather than 3D raster layer because term map emphasizes the mapping of positions to values which is the purpose of 3D raster map (in mathematics, map or mapping is close to a term function) On the other hand, the term layer emphasizes overlaying or stacking up. The former is not the only operation done with data and the latter could be confusing in case of 3D raster data.
3D raster map is divided into cells in the same way as the (2D) raster map. A cell is a cube or a (rectangular) cuboid depending on the resolution. The resolution influences volume of one cell. Some literature or other software may use terms such as volume, volume unit, volumetric pixel, volume pixel, or voxel. Note that voxel can be sometimes used to refer to a whole 3D raster and that for example in 3D computer graphics, voxel can denote object with some complicated shape.
Type of map and element name in GRASS GIS is called raster_3d
.
The module family prefix is r3
.
Occasionally, 3D raster related things can be
referred differently, for example according to a programming language standards.
This might be the case of some functions or classes in Python.
In GRASS GIS 3D rasters as stored in tiles which are hidden from user most of the time. When analyzing or visualizing 3D rasters user can create slices or cross sections. Slices can be horizontal, vertical, or general plains going through a 3D raster. Slices, especially the horizontal ones, may be called layers in some literature or some other software. Cross sections are general functions, e.g. defined by 2D raster, going through a 3D raster. Another often used term is an isosuface which has the same relation to 3D raster as contour (isoline) to a 2D raster. An isosurface is a surface that represent places with a constant value.
When 3D raster is used in the way that vertical dimension represents time 3D raster can be referred to as space time cubes (STC) or space time cube 3D raster. Some literature may also use space time voxel cube, space time voxel model or some other combination.
In case of CSV tables, the modules v.in.ascii (using the -z flag) may be a choice to first import the 3D points as vector points and the convert them to 3D raster (see below).
Import of 3D (LiDAR) points and their statistics can be done using r3.in.lidar for LiDAR data and r3.in.xyz for CSV and other ASCII text formats.
NetCDF export of 3D raster maps can be performed using the module r3.out.netcdf. It supports 3D raster maps with spatial dimensions and temporal (vertical) dimension.
GRASS GIS 3D raster maps can be exported to VTK using r3.out.vtk. VTK files can be visualized with the VTK Toolkit, Paraview and MayaVi. Moreover, GRASS GIS 2D raster maps can be exported to VTK with r.out.vtk and GRASS GIS vector maps can be exported to VTK with v.out.vtk.
Alternatively, GRASS 3D raster maps can be imported and exported from/to Vis5D (r3.in.v5d, r3.out.v5d).