wiki:GmlDefinitions

Version 1 (modified by Piero Campalani, 12 years ago) ( diff )

CRS GML definition candidates for SECORE

Preface

The opportunity to create arbitrary n-dimensional collections with rasdaman raises the need to properly address the referencing of, say, unconventional situations which can easily go beyond the simple pure spatial 1D to 3D coverages.

Whereas the latter ones can still be correctly referenced with existing Coordinate Reference Systems (CRSs) — usually by means of EPSG registered definitions (if we remain on Earth) — there are some other cases which call for definitions to be designed: it is for example the case of pure pixel-space indexing of images of whatever the dimensionality (what is usually known as CRS:1 space by the rasdaman community), or else the case of CRS composition (or compounding) which can take place e.g. when a pressure vertical axis gives volume to a 2D image, or when time shapes a group of spatial datasets into a series.

In line with the URL-oriented concept of CRS handling, where all the referencing metadata of a collection is moved to a separate web resolver in the form of a GML definition, this page proposes GML definitions and associated URI labeling needed to address this gap.


Image1D

<resolver>/def/crs/OGC/0.1/Image1D
E.g. for time dimension until GML issues are solved.

NOTE: showing optional components as <--comments—>.

<gml:ImageCRS gml:id="img1D">
   <!-- gml:description>string</gml:description -->
   <!-- gml:descriptionReference/ -->
   <gml:identifier codeSpace="OGP">urn:ogc:def:crs:OGC:0.1:Image1D</gml:identifier>
   <!-- gml:name>string</gml:name -->
   <gml:remarks>CRS for 1D pixel-domain referenced axes.</gml:remarks>
   <!-- gml:domainOfValidity>
      <gmd:EX_Extent>
         <gmd:description>...
         </gmd:description>
         <gmd:geographicElement>...
         </gmd:geographicElement>
         <gmd:temporalElement>...
         </gmd:temporalElement>
         <gmd:verticalElement>...
         </gmd:verticalElement>
      </gmd:EX_Extent>
   </gml:domainOfValidity -->
   <gml:scope>Default CRS for 1D axis that are referenced in the pixel domain.</gml:scope>
   <gml:cartesianCS>
      <gml:CartesianCS gml:id="cartesian1D">
         <!-- gml:description>string</gml:description -->
         <!-- gml:descriptionReference/ -->
         <gml:identifier codeSpace="OGP">urn:ogc:def:cs:OGC:0.1:Cartesian1D</gml:identifier>
         <!-- gml:name>string</gml:name -->
         <!-- gml:remarks>string</gml:remarks -->
         <gml:axis>
            <gml:CoordinateSystemAxis gml:id="i" uom="urn:ogc:def:uom:OGC:1.0:GridSpacing">
               <!-- gml:description>string</gml:description -->
               <!-- gml:descriptionReference/ -->
               <gml:identifier codeSpace="OGP">urn:ogc:def:axis:OGC:0.1:i</gml:identifier>
               <gml:name>i</gml:name>
               <!-- gml:remarks>string</gml:remarks -->
               <gml:axisAbbrev>i</gml:axisAbbrev>
               <gml:axisDirection codeSpace="EPSG">positive</gml:axisDirection>
               <!-- gml:minimumValue>1.0</gml:minimumValue -->
               <!-- gml:maximumValue>1.0</gml:maximumValue -->
               <!-- gml:rangeMeaning codeSpace="http://www.example.com/">string</gml:rangeMeaning -->
            </gml:CoordinateSystemAxis>
         </gml:axis>
      </gml:CartesianCS>
   </gml:cartesianCS>
   <gml:imageDatum>
      <gml:ImageDatum gml:id="imageDatum">
         <!-- gml:description>string</gml:description -->
         <!-- gml:descriptionReference/ -->
         <gml:identifier codeSpace="OGP">urn:ogc:def:datum:OGC:0.1:ImageDatumCellLowerBound</gml:identifier>
         <!-- gml:name>string</gml:name -->
         <!-- gml:remarks>string</gml:remarks -->
         <!-- gml:domainOfValidity>...</gml:domainOfValidity -->
         <gml:scope>A 1D image datum with the origin at the lower bound of the first cell in the axis.</gml:scope>
         <!-- gml:anchorDefinition>string</gml:anchorDefinition -->
         <!-- gml:realizationEpoch>2000-01-01</gml:realizationEpoch -->
         <gml:pixelInCell codeSpace="OGP">urn:ogc:def:pixelInCell:OGC:0.1:cellLowerBound</gml:pixelInCell>
      </gml:ImageDatum>
   </gml:imageDatum>
</gml:ImageCRS>

Image2D

<resolver>/def/crs/OGC/0.1/Image2D
E.g. for 2D rasters with no geo-reference.

<gml:ImageCRS gml:id="img2D">
   <!-- gml:identifier is optional but we *must* put it for SECORE to assign the URL -->
   <gml:identifier codeSpace="OGP">urn:ogc:def:crs:OGC:0.1:Image2D</gml:identifier>
   <gml:remarks>CRS for 2D pixel-domain referenced images.</gml:remarks>
   <!-- gml:scope is mandatory:                                                              -->
   <!-- The gml:scope property provides a description of the usage, or limitations of usage, -->
   <!-- for which this CRS-related object is valid. If unknown, enter "not known".           -->
   <gml:scope>Default CRS for 2D images that are referenced in the pixel domain.</gml:scope>
   <!-- Not deprecated choices: gml:cartesianCS and gml:affineCS -->
   <gml:cartesianCS>
      <!-- gml:cartesianCS just contains one element: gml:CartesianCS (is it a joke?) -->
      <gml:CartesianCS gml:id="cartesian2D">
         <gml:identifier codeSpace="OGP">urn:ogc:def:cs:OGC:0.1:Cartesian2D</gml:identifier>
         <!-- Here we can put from 1 to 3 axes: just one in this case. -->
         <gml:axis>
            <!-- Another so-called "association-role": contains just one element, a gml:CoordinateSystemAxis. -->
            <!-- I found this OGG:GridSpacing UoM (see [5] and [6]): we should upload it to SECORE as well    -->
            <gml:CoordinateSystemAxis gml:id="i" uom="urn:ogc:def:uom:OGC:1.0:GridSpacing">
               <gml:identifier codeSpace="OGP">urn:ogc:def:axis:OGC:0.1:i</gml:identifier>
               <gml:name>i</gml:name>
               <gml:axisAbbrev>i</gml:axisAbbrev>
               <gml:axisDirection codeSpace="EPSG">horizontal</gml:axisDirection>
            </gml:CoordinateSystemAxis>
         </gml:axis>
         <gml:axis>
            <gml:CoordinateSystemAxis gml:id="j" uom="urn:ogc:def:uom:OGC:1.0:GridSpacing">
               <gml:identifier codeSpace="OGP">urn:ogc:def:axis:OGC:0.1:j</gml:identifier>
               <gml:name>j</gml:name>
               <gml:axisAbbrev>j</gml:axisAbbrev>
               <gml:axisDirection codeSpace="EPSG">vertical</gml:axisDirection>
            </gml:CoordinateSystemAxis>
         </gml:axis>
      </gml:CartesianCS>
   </gml:cartesianCS>
   <gml:imageDatum>
      <!-- Another "association-role" -->
      <gml:ImageDatum gml:id="imageDatum">
         <gml:identifier codeSpace="OGP">urn:ogc:def:datum:OGC:0.1:ImageDatumGridUpperLeft</gml:identifier>
         <!-- Origin in the pixel domain is the upper-left pixel -->
         <gml:scope>A 2D image datum with the origin in the upper-left corner pixel of the grid.</gml:scope>
         <!-- gml:pixelInCell is a specification of the way an image grid is associated with the image data attributes. -->
         <!-- The required codeSpace attribute shall reference a source of information specifying the values and        -->
         <!-- meanings of all the allowed string values for this property (see [8]).                                    -->
         <gml:pixelInCell codeSpace="OGP">urn:ogc:def:pixelInCell:OGC:0.1:cellLowerBound</gml:pixelInCell>
      </gml:ImageDatum>
   </gml:imageDatum>
</gml:ImageCRS>

Image3D

<resolver>/def/crs/OGC/0.1/Image3D
E.g. for 3D rasters with no geo-reference (CTs?).

<gml:ImageCRS gml:id="img3D">
   <!-- gml:identifier is optional but we *must* put it for SECORE to assign the URL -->
   <gml:identifier codeSpace="OGP">urn:ogc:def:crs:OGC:0.1:Image3D</gml:identifier>
   <gml:remarks>CRS for 3D pixel-domain referenced images.</gml:remarks>
   <!-- gml:scope is mandatory:                                                              -->
   <!-- The gml:scope property provides a description of the usage, or limitations of usage, -->
   <!-- for which this CRS-related object is valid. If unknown, enter "not known".           -->
   <gml:scope>Default CRS for 3D images that are referenced in the pixel domain.</gml:scope>
   <!-- Not deprecated choices: gml:cartesianCS and gml:affineCS -->
   <gml:cartesianCS>
      <!-- gml:cartesianCS just contains one element: gml:CartesianCS (is it a joke?) -->
      <gml:CartesianCS gml:id="cartesian3D">
         <gml:identifier codeSpace="OGP">urn:ogc:def:cs:OGC:0.1:Cartesian3D</gml:identifier>
         <!-- Here we can put from 1 to 3 axes: just one in this case. -->
         <gml:axis>
            <!-- Another so-called "association-role": contains just one element, a gml:CoordinateSystemAxis. -->
            <!-- I found this OGG:GridSpacing UoM (see [5] and [6]): we should upload it to SECORE as well    -->
            <gml:CoordinateSystemAxis gml:id="i" uom="urn:ogc:def:uom:OGC:1.0:GridSpacing">
               <gml:identifier codeSpace="OGP">urn:ogc:def:axis:OGC:0.1:i</gml:identifier>
               <gml:name>i</gml:name>
               <gml:axisAbbrev>i</gml:axisAbbrev>
               <gml:axisDirection codeSpace="EPSG">base-horizontal</gml:axisDirection>
            </gml:CoordinateSystemAxis>
         </gml:axis>
         <gml:axis>
            <gml:CoordinateSystemAxis gml:id="j" uom="urn:ogc:def:uom:OGC:1.0:GridSpacing">
               <gml:identifier codeSpace="OGP">urn:ogc:def:axis:OGC:0.1:j</gml:identifier>
               <gml:name>j</gml:name>
               <gml:axisAbbrev>j</gml:axisAbbrev>
               <gml:axisDirection codeSpace="EPSG">base-vertical</gml:axisDirection>
            </gml:CoordinateSystemAxis>
         </gml:axis>
         <gml:axis>
            <gml:CoordinateSystemAxis gml:id="h" uom="urn:ogc:def:uom:OGC:1.0:GridSpacing">
               <gml:identifier codeSpace="OGP">urn:ogc:def:axis:OGC:0.1:k</gml:identifier>
               <gml:name>h</gml:name>
               <gml:axisAbbrev>h</gml:axisAbbrev>
               <gml:axisDirection codeSpace="EPSG">vertical</gml:axisDirection>
            </gml:CoordinateSystemAxis>
         </gml:axis>
      </gml:CartesianCS>
   </gml:cartesianCS>
   <gml:imageDatum>
      <!-- Another "association-role" -->
      <gml:ImageDatum gml:id="imageDatum">
         <gml:identifier codeSpace="OGP">urn:ogc:def:datum:OGC:0.1:ImageDatumCubeUpperLeft</gml:identifier>
         <!-- Origin in the pixel domain is the upper-left pixel of the cube base -->
         <gml:scope>A 3D image datum with the origin in the upper-left corner pixel of the gridded cube base.</gml:scope>
         <!-- gml:pixelInCell is a specification of the way an image grid is associated with the image data attributes. -->
         <!-- The required codeSpace attribute shall reference a source of information specifying the values and        -->
         <!-- meanings of all the allowed string values for this property (see [8]).                                    -->
         <gml:pixelInCell codeSpace="OGP">urn:ogc:def:pixelInCell:OGC:0.1:cellLowerBound</gml:pixelInCell>
      </gml:ImageDatum>
   </gml:imageDatum>
</gml:ImageCRS>

Cartesian?D

<resolver>/def/crs/OGC/0.1/Cartesian1D
<resolver>/def/crs/OGC/0.1/Cartesian2D

E.g. when elevation on a 3D dataset is based upon pressure: CCRS = (CRS2D + Cartesian1D). Otherwise when an arbitrary custom reference is needed.

Ideas:

  • For single axis CRS: EngineeringCRS with linearCS, which is defined as "a one-dimensional coordinate system that consists of the points that lie on the single axis described; the associated coordinate is the distance – with or without offset – from the specified datum to the point along the axis".
  • For 2 or 3 axes CRS: EngineeringCRS with CartesianCS, which is a 1-, 2-, or 3-dimensional coordinate system (in the 1-dimensional case, it contains a single straight coordinate axis; in the 2- and 3-dimensional cases gives the position of points relative to orthogonal straight axes; in the multi-dimensional case, all axes shall have the same length unit of measure) or UserDefinedCS, which is "a two- or three-dimensional coordinate system that consists of any combination of coordinate axes not covered by any other coordinate system type."

The datum used must be an EngineeringDatum, which simply defines the origin (namely the gml:anchorDefinition) of the coordinate reference system. the anchorDefinition is defined as a description, possibly including coordinates, of the definition used to anchor the datum to the Earth. Also known as the "origin", especially for engineering and image datums. The codeSpace attribute may be used to reference a source of more detailed on this point or surface, or on a set of such descriptions.

  1. For a geodetic datum, this point is also known as the fundamental point, which is traditionally the point where the relationship between geoid and ellipsoid is defined. In some cases, the "fundamental point" may consist of a number of points. In those cases, the parameters defining the geoid/ellipsoid relationship have been averaged for these points, and the averages adopted as the datum definition.
  2. For an engineering datum, the anchor definition may be a physical point, or it may be a point with defined coordinates in another CRS.may
  3. For an image datum, the anchor definition is usually either the centre of the image or the corner of the image.
  4. For a temporal datum, this attribute is not defined. Instead of the anchor definition, a temporal datum carries a separate time origin of type DateTime.

Example of EngineeringCRS : http://www.epsg-registry.org/export.htm?gml=urn:ogc:def:crs:EPSG::5801 which uses the engineeringDatum: http://www.epsg-registry.org/export.htm?gml=urn:ogc:def:datum:EPSG::9301

The preferred approach might be to define personal GML definitions with defined custom codes (e.g. MyCartesian1D or PressureWGS84), instead of defining a single template to be customised via key/value pairs. It is straightforward and less prone to problems and errors.


Referenced definitions:

  • http://kahlua.eecs.jacobs-university.de:8080/def/pixelInCell/OGC/1.0/cellLowerBound would resolve to:
    <gml:Definition gml:id="ogc-def-cellLowerBound">
       <gml:description>The origin of the image coordinate system is at the lower bound of a grid cell.</gml:description>
       <!--gml:descriptionReference/-->
       <gml:identifier codeSpace="OGP">urn:ogc:def:pixelInCell:OGC:0.1:cellLowerBound</gml:identifier>
       <!--gml:name>string</gml:name-->
       <!--gml:remarks>string</gml:remarks-->
    </gml:Definition>
    
  • http://kahlua.eecs.jacobs-university.de:8080/def/uom/OGC/1.0/GridSpacing would resolve to:
    <BaseUnit xmlns="http://www.opengis.net/gml" 
         xmlns:gml="http://www.opengis.net/gml" 
         xmlns:xlink="http://www.w3.org/1999/xlink" 
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
         xsi:schemaLocation="http://www.opengis.net/gml http://schemas.opengis.net/gml/3.1.1/base/units.xsd" 
         gml:id="GridSpacing">
       <gml:name>pixels</gml:name>   
       <gml:description>Spacing between adjacent pixels points, or between centers of adjacent pixels</gml:description>   
       <gml:identifier codeSpace="OGP">urn:ogc:def:uom:OGC:1.0:GridSpacing</gml:identifier>
       <gml:quantityType>Pixels</gml:quantityType>
       <gml:unitsSystem xlink:href="urn:ogc:def:nil:OGC:0:inapplicable"/>
    </BaseUnit>
    

Issues

  • does each datum (1D, 2D, 3D) require its own pixelInCell definition, or can the cellLowerBound be adopted for grids of any dimension?
  • are the so-called association roles necessary? For instance cartesianCS to include CartesianCS: SECORE output directly puts a CartesianCS, but is this valid GML?

External links:

  1. gml:ImageCRS
  2. gml:CartesianCS
  3. gml:CoordinateSystemAxis
  4. gml:ImageCRS alt
  5. ImageCRS example
  6. GridSpacing UoM example
  7. gml:ImageDatum
  8. gml:pixelInCell example
  9. userDefinedCS
  10. EngineeringCRS
  11. linearCS
  12. engineeringDatum

Note: See TracWiki for help on using the wiki.