From a8dee6a5b2565bf8c7bf145bbcba07fe2b8cfb80 Mon Sep 17 00:00:00 2001 From: Alex Robin Date: Wed, 4 Sep 2024 11:35:12 +0200 Subject: [PATCH] [SWECommon] Remove some temp files from VC --- swecommon/standard/.gitignore | 14 +- swecommon/standard/24-014.err.html | 984 -- swecommon/standard/24-014.html | 4676 -------- swecommon/standard/24-014.presentation.xml | 10984 ------------------- 4 files changed, 7 insertions(+), 16651 deletions(-) delete mode 100644 swecommon/standard/24-014.err.html delete mode 100644 swecommon/standard/24-014.html delete mode 100644 swecommon/standard/24-014.presentation.xml diff --git a/swecommon/standard/.gitignore b/swecommon/standard/.gitignore index 6a424158..0d71c402 100644 --- a/swecommon/standard/.gitignore +++ b/swecommon/standard/.gitignore @@ -1,11 +1,11 @@ .DS_Store/ -08-094r2.err -08-094r2.err.html -08-094r2.xml -08-094r2.presentation.xml -08-094r2.html -08-094r2.pdf -08-094r2.pdf.err +24-014.err +24-014.err.html +24-014.xml +24-014.presentation.xml +24-014.html +24-014.pdf +24-014.pdf.err *.abort relaton/ iev/ diff --git a/swecommon/standard/24-014.err.html b/swecommon/standard/24-014.err.html deleted file mode 100644 index 7955235c..00000000 --- a/swecommon/standard/24-014.err.html +++ /dev/null @@ -1,984 +0,0 @@ -./24-014.err.html errors - -

./24-014.err.html errors

-

AsciiDoc Input

- - - - -
LineIDMessageContext
Bibliographyno anchor on reference, markup may be malformed: seehttps://​www.​metanorma.com/​author/topics/​document-f­ormat/​bibliography/ ,https://​www.​metanorma.com/​author/iso/​topics/​markup/​#bibliographies -: For citations in the text please use square brackets and consecutive numbers: [1], [2], [3]
#<Asciidoctor::List@1790200 {context: :ulist, style: nil, items: 1}>
-

Crossreferences

- - - - - - -
LineIDMessageContext
000384_​observationISO19156 does not have a corresponding anchor ID in the bibliography!
<origin bibitemid="ISO19156" type="inline" citeas="">ISO-19156, definition 4.10</origin>
000394_​observation_​procedureISO19156 does not have a corresponding anchor ID in the bibliography!
<origin bibitemid="ISO19156" type="inline" citeas="">ISO-19156, definition 4.11</origin>
000407_propertyISO19143 does not have a corresponding anchor ID in the bibliography!
<origin bibitemid="ISO19143" type="inline" citeas="">ISO-19143</origin>
-

Anchors

- - - - - - - -
LineIDMessageContext
000362_​a5c2011b-080b-de57-­753c-94b804e5f324Crossreference target OGC06-121r9 is undefined
<xref target="OGC06-121r9"/>
002135_​9acae3e4-938d-7eef-­1adb-63a260409236Crossreference target encoding_​rules_xml is undefined
<xref target="encoding_rules_xml">XML encoding rules</xref>
002135_​9acae3e4-938d-7eef-­1adb-63a260409236Crossreference target xsd_geom_​components­ is undefined
<xref target="xsd_geom_components">XML implementation</xref>
004407_​8c9dfe2a-e60c-3085-­f85a-fcebbe53472cCrossreference target xsd_​binarycomponent­_elt is undefined
<xref target="xsd_binarycomponent_elt"/>
-

Syntax

- - - - - - - -
LineIDMessageContext
001762_​b4a6b80f-3977-dcd6-­a436-d1f2aca96fb7There is an instance of figure nested within example
<figure id="_b4a6b80f-3977-dcd6-a436-d1f2aca96fb7" unnumbered="true">
-  <image src="" mimetype="image/png" id="_5861038d-f364-64d3-0405-486a36242574" height="auto" width="auto"/>
-</figure>
001930_​b2f495ef-8c17-9909-­e33d-ddee2783541eThere is an instance of figure nested within example
<figure id="_b2f495ef-8c17-9909-e33d-ddee2783541e" unnumbered="true">
-  <image src="" mimetype="image/png" id="_1da2fea1-0737-3553-4b08-52b9a92a8495" height="auto" width="auto"/>
-</figure>
001936_​1b554c03-ae41-e820-­e28d-36905fb837f6There is an instance of figure nested within example
<figure id="_1b554c03-ae41-e820-e28d-36905fb837f6" unnumbered="true">
-  <image src="" mimetype="image/png" id="_559ff1e0-b75b-2d91-fa0a-b3e01187b979" height="auto" width="auto"/>
-</figure>
001947_​3e583759-fd51-f80a-­fe7a-942d5ce7e3e8There is an instance of figure nested within example
<figure id="_3e583759-fd51-f80a-fe7a-942d5ce7e3e8" unnumbered="true">
-  <image src="" mimetype="image/png" id="_6b616cf0-3d22-fa6b-623f-381b6c0a9390" height="auto" width="auto"/>
-</figure>
-

Metanorma XML Style Warning

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
LineIDMessageContext
000001_​misccontainer_​anchor_aliasesTable should have title
<table id="_misccontainer_anchor_aliases">
-  <tbody>
-    <tr>
-      <th>_c783dac9-3b6e-4a0f-8f06-94547924f0fe</th>
-      <td>/req/core</td>
000046_​230088cf-7ecd-fbbd-­c257-c8f721bd0035Table should have title
<table id="_230088cf-7ecd-fbbd-c257-c8f721bd0035" unnumbered="true" width="100%"> <colgroup> <col width="23.0769%"/> <col width="76.9231%"/> </colgroup> <thead> <tr> <th valign="middle" align="left"> <strong>Name</strong> </th>
-<th valign="middle" align="left"> <strong>Affiliation</strong> </th>
-</tr> </thead>
-<tbody> <tr> <td valign="middle" align="left">Alex Robin (Editor)</td>
-<td valign="middle" align="left">GeoRobotix, Inc.</td>
000062_​4fed7ea0-b3d1-355f-­8e92-4bd736f3a87fTable should have title
<table id="_4fed7ea0-b3d1-355f-8e92-4bd736f3a87f" unnumbered="true"> <tbody> <tr> <td valign="middle" align="left"> <strong>Name</strong> </td>
-<td valign="middle" align="left"> <strong>Affiliation</strong> </td>
-</tr> <tr> <td valign="middle" align="left">Arne Broering</td>
-<td valign="middle" align="left">52° North Initiative</td>
-</tr> <tr> <td valign="middle" align="left">Barry Reff</td>
000452_​conventionsHanging paragraph in clause
<clause id="_conventions" obligation="normative">
-<title>Conventions</title>
-<clause id="_identifiers" obligation="normative">
-<title>Identifiers</title>
-<p id="_695d051b-6fef-c0b6-5aa8-0fe8fff41091">The normative provisions in this standard are denoted by the URI</p>
000511_​e16c7c75-f340-0144-­dc6e-81b9f59397f8Figure should have title
<figure id="_e16c7c75-f340-0144-dc6e-81b9f59397f8">
-  <image src="" mimetype="image/png" id="_bc68bc3c-5867-fbb7-efd5-b2d3e98fe5d3" height="auto" width="auto"/>
-</figure>
000515core_​conceptsHanging paragraph in clause
<clause id="core_concepts" obligation="normative">
-<title>Requirements Class: Core Concepts (normative core)</title>
-<requirement id="_056c9de6-79cc-7051-3593-6b5c5d9c615f" model="ogc" type="class">
-<title>Core Concepts</title> <identifier>/req/core</identifier> <subject>Derived Models and Software Implementations</subject>
-
000562core_data_​repHanging paragraph in clause
<clause id="core_data_rep" obligation="normative">
-<title>Data Representation</title>
-<p id="_337dfc15-b3a1-b1c9-9c95-a41032d10358">Data representation deals with how property values are represented and stored digitally. Each component (or field) in a dataset carries a value that represents the state of a property. This representation will vary depending on the nature of the method used to capture the data and/or the target usage. For instance, a fluid temperature can be represented as a decimal number expressed in degrees Celsius (i.e. 25.4 °C), or as a categorical value taken from a list of possible choices (such as “freezing, cold, normal, warm, hot”).</p>
-
-<p id="_abe01dd2-6def-9a0e-85a0-299bb7cdf48e">The following types of representations have been identified: Boolean, Categorical, Continuous Numerical, Discrete Countable and Textual. The paragraphs below explain basic features of each of these representation types.</p>
000713core_data_​natureHanging paragraph in clause
<clause id="core_data_nature" obligation="normative">
-<title>Nature of Data</title>
-<p id="_34725401-5c2d-3eb7-9b2a-0a14f33c391e">We define “Nature of data” as the information needed to understand what property the value represents. It is thus connected to semantics and the semantic details are often provided by external sources such as dictionaries, taxonomies or ontologies. Note that it is independent of the type of representation used and it does not include information about how the data was actually measured or acquired. This lineage information should be described by other means as explained in <xref target="core_full_lineage"/>.</p>
-
-<clause id="core_human_readable_info" obligation="normative">
000790core_data_​qualityHanging paragraph in clause
<clause id="core_data_quality" obligation="normative">
-<title>Data Quality</title>
-<p id="_e9c6a2ca-7b94-23f5-0a41-95066c2323de">Quality information can be essential to the data consumer and the SWE Common Data Model provides simple and flexible ways to associate qualitative information with each component of a dataset.</p>
-
-<clause id="core_quality_info" obligation="normative">
000901uml_​modelsHanging paragraph in clause
<clause id="uml_models" obligation="normative">
-<title>UML Conceptual Models (normative)</title>
-<p id="_a44c9d55-47d1-525c-1248-9a5161eaf441">This standard defines normative UML models with which derived encoding models as well as all future separate extensions should be compliant. The standardization target type for the UML requirements classes defined in this clause is thus a software implementation or an encoding model that directly implements the conceptual models defined in this standard.</p>
-
-<clause id="_package_dependencies" obligation="normative">
000920uml_​simple_​componentsHanging paragraph in clause
<clause id="uml_simple_components" obligation="normative">
-<title>Requirements Class: Basic Types and Simple Components Packages</title>
-<requirement id="_e2776023-f091-0c76-b3a5-f83f23903205" model="ogc" type="class">
-<title>Simple Components UML Package</title> <identifier>/req/uml-simple-components</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/core</inherit>
-
001619uml_​record_​componentsHanging paragraph in clause
<clause id="uml_record_components" obligation="normative">
-<title>Requirements Class: Record Components Package</title>
-<requirement id="_2482225b-0e65-b85f-57ac-c5ac6d068358" model="ogc" type="class">
-<title>Record Components UML Package</title> <identifier>/req/uml-record-components</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/uml-simple-components</inherit>
-
001762_​b4a6b80f-3977-dcd6-­a436-d1f2aca96fb7Figure should have title
<figure id="_b4a6b80f-3977-dcd6-a436-d1f2aca96fb7" unnumbered="true">
-  <image src="" mimetype="image/png" id="_5861038d-f364-64d3-0405-486a36242574" height="auto" width="auto"/>
-</figure>
001774uml_​choice_​componentsHanging paragraph in clause
<clause id="uml_choice_components" obligation="normative">
-<title>Requirements Class: Choice Components Package</title>
-<requirement id="_7a84a684-db61-305d-4e88-784d9ee73536" model="ogc" type="class">
-<title>Choice Components UML Package</title> <identifier>/req/uml-choice-components</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/uml-simple-components</inherit>
-
001838uml_block_​components­Hanging paragraph in clause
<clause id="uml_block_components" obligation="normative">
-<title>Requirements Class: Block Components Package</title>
-<requirement id="_230ddecb-09b0-6911-19eb-045b86aa6eba" model="ogc" type="class">
-<title>Block Components UML Package</title> <identifier>/req/uml-block-components</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/uml-simple-components</inherit> <inherit>/req/uml-simple-encodings</inherit>
-
001930_​b2f495ef-8c17-9909-­e33d-ddee2783541eFigure should have title
<figure id="_b2f495ef-8c17-9909-e33d-ddee2783541e" unnumbered="true">
-  <image src="" mimetype="image/png" id="_1da2fea1-0737-3553-4b08-52b9a92a8495" height="auto" width="auto"/>
-</figure>
001936_​1b554c03-ae41-e820-­e28d-36905fb837f6Figure should have title
<figure id="_1b554c03-ae41-e820-e28d-36905fb837f6" unnumbered="true">
-  <image src="" mimetype="image/png" id="_559ff1e0-b75b-2d91-fa0a-b3e01187b979" height="auto" width="auto"/>
-</figure>
001947_​3e583759-fd51-f80a-­fe7a-942d5ce7e3e8Figure should have title
<figure id="_3e583759-fd51-f80a-fe7a-942d5ce7e3e8" unnumbered="true">
-  <image src="" mimetype="image/png" id="_6b616cf0-3d22-fa6b-623f-381b6c0a9390" height="auto" width="auto"/>
-</figure>
002068uml_geom_​componentsHanging paragraph in clause
<clause id="uml_geom_components" obligation="normative">
-<title>Requirements Class: Geometry Components Package</title>
-<requirement id="_d2632134-1a89-18cf-a0b9-38b5be589d64" model="ogc" type="class">
-<title>Geometry Components UML Package</title> <identifier>/req/uml-geom-components</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/uml-simple-components</inherit>
-
002148uml_​simple_​encodingsHanging paragraph in clause
<clause id="uml_simple_encodings" obligation="normative">
-<title>Requirements Class: Simple Encodings Package</title>
-<requirement id="_08c4500b-e118-1ba3-953b-be4890058f15" model="ogc" type="class">
-<title>Simple Encodings UML Package</title> <identifier>/req/uml-simple-encodings</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/core</inherit>
-
002223uml_​advanced_​encodingsHanging paragraph in clause
<clause id="uml_advanced_encodings" obligation="normative">
-<title>Requirements Class: Advanced Encodings Package</title>
-<requirement id="_ebcb3bde-1307-6818-4c8a-89d69894fa05" model="ogc" type="class">
-<title>Advanced Encodings UML Package</title> <identifier>/req/uml-advanced-encodings</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/uml-simple-encodings</inherit>
-
002303json_implHanging paragraph in clause
<clause id="json_impl" obligation="normative">
-<title>JSON Implementation (normative)</title>
-<p id="_31b60645-09e6-ce8f-1a77-5a3520eca393">This standard defines a normative JSON implementation of the conceptual models presented in <xref target="uml_models"/>. The standardization target type for all requirements classes in this clause is a JSON instance document that seeks compliance with this JSON encoding model.</p>
-
-<p id="_1cf4a114-de99-8706-0754-a23233d31e0a">JSON schemas defined in this section are a direct implementation of the UML conceptual models described in <xref target="uml_models"/>. They have been generated from these models by strictly following well-defined encoding rules. All attributes and composition/aggregation associations contained in the UML models are encoded as JSON object members.</p>
002323json_​simple_​componentsHanging paragraph in clause
<clause id="json_simple_components" obligation="normative">
-<title>Requirements Class: Basic Types and Simple Components JSON Schemas</title>
-<requirement id="_99b7f7b8-1019-5b0d-e920-eadec3efc268" model="ogc" type="class">
-<title>Basic Types and Simple Components JSON Schemas</title> <identifier>/req/json-simple-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-simple-components</inherit>
-
002883json_​record_​componentsHanging paragraph in clause
<clause id="json_record_components" obligation="normative">
-<title>Requirements Class: Record Components JSON Schema</title>
-<requirement id="_6c309e4e-6f02-20bb-fba5-7e91ad207e11" model="ogc" type="class">
-<title>Record Components JSON Schema</title> <identifier>/req/json-record-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-record-components</inherit> <inherit>/req/json-simple-components</inherit>
-
003095json_​choice_​componentsHanging paragraph in clause
<clause id="json_choice_components" obligation="normative">
-<title>Requirements Class: Choice Components JSON Schema</title>
-<requirement id="_bb59272d-3510-7da9-3247-df501dd3e841" model="ogc" type="class">
-<title>Choice Components JSON Schema</title> <identifier>/req/json-choice-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-choice-components</inherit> <inherit>/req/json-simple-components</inherit>
-
003179json_​block_​componentsHanging paragraph in clause
<clause id="json_block_components" obligation="normative">
-<title>Requirements Class: Block Components JSON Schema</title>
-<requirement id="_fa1e418c-cb12-4d18-981c-abd027ffe14f" model="ogc" type="class">
-<title>Block Components JSON Schema</title> <identifier>/req/json-block-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-block-components</inherit> <inherit>/req/json-simple-components</inherit>
-
003473json_geom_​components­Hanging paragraph in clause
<clause id="json_geom_components" obligation="normative">
-<title>Requirements Class: Geometry Components JSON Schema</title>
-<requirement id="_592e474e-c0ae-be08-40f0-e1037d58dd01" model="ogc" type="class">
-<title>Geometry Components JSON Schema</title> <identifier>/req/json-geom-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-geom-components</inherit> <inherit>/req/json-simple-components</inherit>
-
003540json_​simple_​encodingsHanging paragraph in clause
<clause id="json_simple_encodings" obligation="normative">
-<title>Requirements Class: Simple Encodings JSON Schema</title>
-<requirement id="_5941b0e3-b8ac-02c6-96a5-f8da75d20226" model="ogc" type="class">
-<title>Simple Encodings JSON Schema</title> <identifier>/req/json-simple-encodings</identifier> <subject>JSON Document</subject> <inherit>/req/json-simple-encodings</inherit> <inherit>/req/text-encoding-rules</inherit> <inherit>/req/json-encoding-rules</inherit>
-
003583json_​advanced_​encodingsHanging paragraph in clause
<clause id="json_advanced_encodings" obligation="normative">
-<title>Requirements Class: Advanced Encodings JSON Schema</title>
-<requirement id="_9acc1a88-e86e-a618-4410-7b27b372e782" model="ogc" type="class">
-<title>Advanced Encodings JSON Schema</title> <identifier>/req/json-advanced-encodings</identifier> <subject>JSON Document</subject> <inherit>/req/uml-advanced-encodings</inherit> <inherit>/req/json-simple-encodings</inherit> <inherit>/req/binary-encoding-rules</inherit>
-
003741_​requirements_class_​general_​encoding_​rulesHanging paragraph in clause
<clause id="_requirements_class_general_encoding_rules" obligation="normative">
-<title>Requirements Class: General Encoding Rules</title>
-<requirement id="_1907413d-16cf-2fff-31d1-00a12dbcc8c0" model="ogc" type="class">
-<title>General Encoding Rules</title> <identifier>/req/general-encoding-rules</identifier> <subject>Encoded Values Instance</subject> <classification> <tag>indirect-dependency</tag> <value>/req/uml-simple-encodings</value> </classification>
-
003784_​de9e5250-8795-38e5-­e509-4c8f2c816527Figure should have title
<figure id="_de9e5250-8795-38e5-e509-4c8f2c816527" unnumbered="true">
-  <image src="" mimetype="image/png" id="_85be1447-0888-37a1-d668-95e1b3230e09" height="auto" width="auto"/>
-</figure>
003801_​025f87f8-636c-0faa-­2e44-c7aa8fc127b5Figure should have title
<figure id="_025f87f8-636c-0faa-2e44-c7aa8fc127b5" unnumbered="true">
-  <image src="" mimetype="image/png" id="_046b115e-72a5-52de-9b15-aabd287b2031" height="auto" width="auto"/>
-</figure>
003820_​1c68e07d-7cd6-46ff-­7812-72b541333428Figure should have title
<figure id="_1c68e07d-7cd6-46ff-7812-72b541333428" unnumbered="true">
-  <image src="" mimetype="image/png" id="_b5cba205-cf8d-a952-f399-f9ac6d4cfae6" height="auto" width="auto"/>
-</figure>
003842encoding_​rules_jsonHanging paragraph in clause
<clause id="encoding_rules_json" obligation="normative">
-<title>Requirements Class: JSON Encoding Rules</title>
-<requirement id="_c2015f20-f489-6745-fd69-b92ab9886815" model="ogc" type="class">
-<title>JSON Encoding Rules</title> <identifier>/req/json-encoding-rules</identifier> <subject>Encoded Values Instance</subject> <inherit>/req/general-encoding-rules</inherit> <classification> <tag>indirect-dependency</tag> <value>/req/uml-simple-encodings</value> </classification>
-
004121encoding_​rules_textHanging paragraph in clause
<clause id="encoding_rules_text" obligation="normative">
-<title>Requirements Class: Text Encoding Rules</title>
-<requirement id="_cc4eb8a1-db2e-a8e9-78a6-1e923ad92b51" model="ogc" type="class">
-<title>Text Encoding Rules</title> <identifier>/req/text-encoding-rules</identifier> <subject>Encoded Values Instance</subject> <inherit>/req/general-encoding-rules</inherit> <classification> <tag>indirect-dependency</tag> <value>/req/uml-simple-encodings</value> </classification>
-
004366encoding_​rules_​binaryHanging paragraph in clause
<clause id="encoding_rules_binary" obligation="normative">
-<title>Requirements Class: Binary Encoding Rules</title>
-<requirement id="_b1ce9c3b-8a15-9fd0-be63-ac80b4fe0b44" model="ogc" type="class">
-<title>Binary Encoding Rules</title> <identifier>/req/binary-encoding-rules</identifier> <subject>Encoded Values Instance</subject> <inherit>/req/general-encoding-rules</inherit> <classification> <tag>indirect-dependency</tag> <value>/req/uml-advanced-encodings</value> </classification>
-
006199_xml_​encoding_rules_​examplesHanging paragraph in clause
<clause id="_xml_encoding_rules_examples" obligation="informative">
-<title>XML Encoding Rules Examples</title>
-<p id="_822a7111-bf90-a3eb-e553-28a3d8a3acec">The following examples build on the ones provided in the <xref target="enc_text_examples" style="basic"/> section. The datastream descriptions are kept the same, except that the encoding method would have to be changed to:</p>
-
-<sourcecode id="_8dc83268-df1a-1b27-df27-853b3c9f172a" lang="xml" unnumbered="true">&lt;swe:encoding&gt;
006428_json_​encoding_​rules_examplesHanging paragraph in clause
<clause id="_json_encoding_rules_examples" obligation="informative">
-<title>JSON Encoding Rules Examples</title>
-<p id="_f2759f82-3110-b6dc-9e02-69fc13362ef9">The following examples build on the ones provided in the <xref target="enc_text_examples" style="basic"/> section. The datastream descriptions are kept the same, except that the encoding method would have to be changed to:</p>
-
-<sourcecode id="_1fce0c5c-f767-b713-4925-8bea40e85823" lang="xml" unnumbered="true">&lt;swe:encoding&gt;
006720_​f9a0580f-73b5-c0aa-­10f1-badec38ae640Table should have title
<table id="_f9a0580f-73b5-c0aa-10f1-badec38ae640" unnumbered="true" width="90%"> <thead> <tr> <th valign="middle" align="left">Date</th>
-<th valign="middle" align="left">Release</th>
-<th valign="middle" align="left">Editor</th>
-<th valign="middle" align="left">Primary clauses modified</th>
-<th valign="middle" align="left">Description</th>
-

Requirements

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
LineIDMessageContext
000517_​056c9de6-79cc-7051-­3593-6b5c5d9c615fRequirement class /req/​core has no corresponding Requirement -
<requirement id="_056c9de6-79cc-7051-3593-6b5c5d9c615f" model="ogc" type="class">
-<title>Core Concepts</title> <identifier>/req/core</identifier> <subject>Derived Models and Software Implementations</subject>
-
-</requirement>
000922_​e2776023-f091-0c76-­b3a5-f83f23903205Requirement class /req/​uml-simple-com­ponents has no corresponding Requirement -
<requirement id="_e2776023-f091-0c76-b3a5-f83f23903205" model="ogc" type="class">
-<title>Simple Components UML Package</title> <identifier>/req/uml-simple-components</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/core</inherit>
-
-</requirement>
001621_​2482225b-0e65-b85f-­57ac-c5ac6d068358Requirement class /req/​uml-record-com­ponents has no corresponding Requirement -
<requirement id="_2482225b-0e65-b85f-57ac-c5ac6d068358" model="ogc" type="class">
-<title>Record Components UML Package</title> <identifier>/req/uml-record-components</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/uml-simple-components</inherit>
-
-</requirement>
001776_​7a84a684-db61-305d-­4e88-784d9ee73536Requirement class /req/​uml-choice-com­ponents has no corresponding Requirement -
<requirement id="_7a84a684-db61-305d-4e88-784d9ee73536" model="ogc" type="class">
-<title>Choice Components UML Package</title> <identifier>/req/uml-choice-components</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/uml-simple-components</inherit>
-
-</requirement>
001840_​230ddecb-09b0-6911-­19eb-045b86aa6ebaRequirement class /req/​uml-block-comp­onents has no corresponding Requirement -
<requirement id="_230ddecb-09b0-6911-19eb-045b86aa6eba" model="ogc" type="class">
-<title>Block Components UML Package</title> <identifier>/req/uml-block-components</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/uml-simple-components</inherit> <inherit>/req/uml-simple-encodings</inherit>
-
-</requirement>
002070_​d2632134-1a89-18cf-­a0b9-38b5be589d64Requirement class /req/​uml-geom-compo­nents has no corresponding Conformance class -
<requirement id="_d2632134-1a89-18cf-a0b9-38b5be589d64" model="ogc" type="class">
-<title>Geometry Components UML Package</title> <identifier>/req/uml-geom-components</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/uml-simple-components</inherit>
-
-</requirement>
002070_​d2632134-1a89-18cf-­a0b9-38b5be589d64Requirement class /req/​uml-geom-compo­nents has no corresponding Requirement -
<requirement id="_d2632134-1a89-18cf-a0b9-38b5be589d64" model="ogc" type="class">
-<title>Geometry Components UML Package</title> <identifier>/req/uml-geom-components</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/uml-simple-components</inherit>
-
-</requirement>
002089_​a909ecd4-6e57-4ca8-­331d-4d9b9767bdffRequirement /req/​uml-geom-compo­nents/​package-fully-­implemented has no corresponding Conformance test -
<requirement id="_a909ecd4-6e57-4ca8-331d-4d9b9767bdff" model="ogc">  <identifier>/req/uml-geom-components/package-fully-implemented</identifier>
-
-<description> <p id="_6dd4df75-174a-a4c2-c4b7-fec48e2bbb1f">The encoding or software shall correctly implement all classes defined in the “Geometry Components” UML package.</p> </description>
-</requirement>
002109_​9f47db81-b9da-c6e0-­fd10-8132673072fdRequirement /req/​uml-geom-compo­nents/​srs-valid has no corresponding Conformance test -
<requirement id="_9f47db81-b9da-c6e0-fd10-8132673072fd" model="ogc">  <identifier>/req/uml-geom-components/srs-valid</identifier>
-
-<description> <p id="_7cf76592-c182-2a96-178a-052570516ccf">The “srs” attribute shall reference the definition of a valid 2D or 3D spatial reference system.</p> </description>
-</requirement>
002125_​fb77236b-42c6-c559-­9ee2-1d27fde83d3aRequirement /req/​uml-geom-compo­nents/​geom-value-val­id has no corresponding Conformance test -
<requirement id="_fb77236b-42c6-c559-9ee2-1d27fde83d3a" model="ogc">  <identifier>/req/uml-geom-components/geom-value-valid</identifier>
-
-<description> <p id="_b7bb9a4c-bfa7-c330-dc03-8651ee95081f">The “value” attribute shall be one of the concrete geometry value classes defined in <eref type="inline" bibitemid="OGC_SFA" citeas="OGC 06-103r4"/>: “Point”, “MultiPoint”, “LineString”, “MultiLineString”, “Polygon”, or “MultiPolygon”.</p> </description>
-</requirement>
002150_​08c4500b-e118-1ba3-­953b-be4890058f15Requirement class /req/​uml-simple-enc­odings has no corresponding Requirement -
<requirement id="_08c4500b-e118-1ba3-953b-be4890058f15" model="ogc" type="class">
-<title>Simple Encodings UML Package</title> <identifier>/req/uml-simple-encodings</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/core</inherit>
-
-</requirement>
002225_​ebcb3bde-1307-6818-­4c8a-89d69894fa05Requirement class /req/​uml-advanced-e­ncodings has no corresponding Requirement -
<requirement id="_ebcb3bde-1307-6818-4c8a-89d69894fa05" model="ogc" type="class">
-<title>Advanced Encodings UML Package</title> <identifier>/req/uml-advanced-encodings</identifier> <subject>Software Implementation or Encoding of the Conceptual Models</subject> <inherit>/req/uml-simple-encodings</inherit>
-
-</requirement>
002325_​99b7f7b8-1019-5b0d-­e920-eadec3efc268Requirement class /req/​json-simple-co­mponents has no corresponding Conformance class -
<requirement id="_99b7f7b8-1019-5b0d-e920-eadec3efc268" model="ogc" type="class">
-<title>Basic Types and Simple Components JSON Schemas</title> <identifier>/req/json-simple-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-simple-components</inherit>
-
-</requirement>
002325_​99b7f7b8-1019-5b0d-­e920-eadec3efc268Requirement class /req/​json-simple-co­mponents has no corresponding Requirement -
<requirement id="_99b7f7b8-1019-5b0d-e920-eadec3efc268" model="ogc" type="class">
-<title>Basic Types and Simple Components JSON Schemas</title> <identifier>/req/json-simple-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-simple-components</inherit>
-
-</requirement>
002346_​232d0ef5-7bb4-7fa7-­efd9-26c925f18379Requirement /req/​json-simple-co­mponents/​schema-vali­d has no corresponding Conformance test -
<requirement id="_232d0ef5-7bb4-7fa7-efd9-26c925f18379" model="ogc">  <identifier>/req/json-simple-components/schema-valid</identifier>
-
-<description> <p id="_4a640195-32a4-a8a7-90f8-8e5669dbac1e">The JSON document instance shall be valid with respect to the JSON schema <link target="https://raw.githubusercontent.com/opengeospatial/connected-systems/master/swecommon/schemas/json/sweCommon.json">“sweCommon.json”</link>.</p> </description>
-</requirement>
002375_​72202d05-04cb-6b8d-­c945-88b72a913ce0Requirement /req/​json-simple-co­mponents/​special-num­erical-values has no corresponding Conformance test -
<requirement id="_72202d05-04cb-6b8d-c945-88b72a913ce0" model="ogc">  <identifier>/req/json-simple-components/special-numerical-values</identifier>
-
-<description> <p id="_e28a619e-76dd-9c5f-5d3d-6f0af644313d">The special JSON Strings <tt>NaN</tt>, <tt>-Infinity</tt> and <tt>+Infinity</tt> shall be allowed as the inline or out-of-band value for Quantity and Time <hi>(and Count?)</hi> components (except when the Time component uses the ISO 8601 format).</p> </description>
-</requirement>
002401_​54da0a70-966f-3b79-­a16c-32ac10ec7e01Requirement /req/​json-simple-co­mponents/​definition-­resolvable has no corresponding Conformance test -
<requirement id="_54da0a70-966f-3b79-a16c-32ac10ec7e01" model="ogc">  <identifier>/req/json-simple-components/definition-resolvable</identifier>
-
-<description> <p id="_9d3eac58-c5b2-b625-168a-d5627aa17ed9">The “definition” object member defined in the “AbstractDataComponent.json” schema shall contain a URI that can be resolved to the complete human readable definition of the property that is represented by the data component.</p> </description>
-</requirement>
002409_​e6f29c20-c75e-756b-­7c78-cd45a402a8ceRequirement /req/​json-simple-co­mponents/​inline-valu­e-constraint-valid has no corresponding Conformance test -
<requirement id="_e6f29c20-c75e-756b-7c78-cd45a402a8ce" model="ogc">  <identifier>/req/json-simple-components/inline-value-constraint-valid</identifier>
-
-<description> <p id="_1f16d48e-99a3-fdbd-7aa4-d9f2c4cb8a5a">The inline value included in a JSON instance validating against the “AbstractSimpleComponent.json” schema shall satisfy the constraints specified by this instance.</p> </description>
-</requirement>
002538_​9bb6b30c-4d7c-0486-­ec5c-5935d2cb9453Requirement /req/​json-simple-co­mponents/​ucum-code-u­sed has no corresponding Conformance test -
<requirement id="_9bb6b30c-4d7c-0486-ec5c-5935d2cb9453" model="ogc">  <identifier>/req/json-simple-components/ucum-code-used</identifier>
-
-<description> <p id="_0dde8e93-c881-192b-0e45-5b81b287fa80">Whenever it can be constructed using the <eref type="inline" bibitemid="UCUM" citeas="UCUM"/> specification, the unit of measure shall be specified using a UCUM code as the value of the “uom/code” property. Otherwise the “uom/href” property shall be used to reference an external unit definition.</p> </description>
-</requirement>
002588_​517c5d35-6327-fe06-­ceed-e91b31e00e1eRequirement /req/​json-simple-co­mponents/​iso8601-uom­-used has no corresponding Conformance test -
<requirement id="_517c5d35-6327-fe06-ceed-e91b31e00e1e" model="ogc">  <identifier>/req/json-simple-components/iso8601-uom-used</identifier>
-
-<description> <p id="_b9ed4610-2400-a1c3-e0e8-c3676dbb0783">When ISO 8601 notation is used to express the value associated to a “Time” element, the URI “http://www.opengis.net/def/uom/ISO-8601/0/Gregorian” shall be used as the value of the “uom/href” property.</p> </description>
-</requirement>
002885_​6c309e4e-6f02-20bb-­fba5-7e91ad207e11Requirement class /req/​json-record-co­mponents has no corresponding Conformance class -
<requirement id="_6c309e4e-6f02-20bb-fba5-7e91ad207e11" model="ogc" type="class">
-<title>Record Components JSON Schema</title> <identifier>/req/json-record-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-record-components</inherit> <inherit>/req/json-simple-components</inherit>
-
-</requirement>
002885_​6c309e4e-6f02-20bb-­fba5-7e91ad207e11Requirement class /req/​json-record-co­mponents has no corresponding Requirement -
<requirement id="_6c309e4e-6f02-20bb-fba5-7e91ad207e11" model="ogc" type="class">
-<title>Record Components JSON Schema</title> <identifier>/req/json-record-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-record-components</inherit> <inherit>/req/json-simple-components</inherit>
-
-</requirement>
003097_​bb59272d-3510-7da9-­3247-df501dd3e841Requirement class /req/​json-choice-co­mponents has no corresponding Conformance class -
<requirement id="_bb59272d-3510-7da9-3247-df501dd3e841" model="ogc" type="class">
-<title>Choice Components JSON Schema</title> <identifier>/req/json-choice-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-choice-components</inherit> <inherit>/req/json-simple-components</inherit>
-
-</requirement>
003097_​bb59272d-3510-7da9-­3247-df501dd3e841Requirement class /req/​json-choice-co­mponents has no corresponding Requirement -
<requirement id="_bb59272d-3510-7da9-3247-df501dd3e841" model="ogc" type="class">
-<title>Choice Components JSON Schema</title> <identifier>/req/json-choice-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-choice-components</inherit> <inherit>/req/json-simple-components</inherit>
-
-</requirement>
003181_​fa1e418c-cb12-4d18-­981c-abd027ffe14fRequirement class /req/​json-block-com­ponents has no corresponding Conformance class -
<requirement id="_fa1e418c-cb12-4d18-981c-abd027ffe14f" model="ogc" type="class">
-<title>Block Components JSON Schema</title> <identifier>/req/json-block-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-block-components</inherit> <inherit>/req/json-simple-components</inherit>
-
-</requirement>
003181_​fa1e418c-cb12-4d18-­981c-abd027ffe14fRequirement class /req/​json-block-com­ponents has no corresponding Requirement -
<requirement id="_fa1e418c-cb12-4d18-981c-abd027ffe14f" model="ogc" type="class">
-<title>Block Components JSON Schema</title> <identifier>/req/json-block-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-block-components</inherit> <inherit>/req/json-simple-components</inherit>
-
-</requirement>
003475_​592e474e-c0ae-be08-­40f0-e1037d58dd01Requirement class /req/​json-geom-comp­onents has no corresponding Conformance class -
<requirement id="_592e474e-c0ae-be08-40f0-e1037d58dd01" model="ogc" type="class">
-<title>Geometry Components JSON Schema</title> <identifier>/req/json-geom-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-geom-components</inherit> <inherit>/req/json-simple-components</inherit>
-
-</requirement>
003475_​592e474e-c0ae-be08-­40f0-e1037d58dd01Requirement class /req/​json-geom-comp­onents has no corresponding Requirement -
<requirement id="_592e474e-c0ae-be08-40f0-e1037d58dd01" model="ogc" type="class">
-<title>Geometry Components JSON Schema</title> <identifier>/req/json-geom-components</identifier> <subject>JSON Document</subject> <inherit>/req/uml-geom-components</inherit> <inherit>/req/json-simple-components</inherit>
-
-</requirement>
003542_​5941b0e3-b8ac-02c6-­96a5-f8da75d20226Requirement class /req/​json-simple-en­codings has no corresponding Conformance class -
<requirement id="_5941b0e3-b8ac-02c6-96a5-f8da75d20226" model="ogc" type="class">
-<title>Simple Encodings JSON Schema</title> <identifier>/req/json-simple-encodings</identifier> <subject>JSON Document</subject> <inherit>/req/json-simple-encodings</inherit> <inherit>/req/text-encoding-rules</inherit> <inherit>/req/json-encoding-rules</inherit>
-
-</requirement>
003542_​5941b0e3-b8ac-02c6-­96a5-f8da75d20226Requirement class /req/​json-simple-en­codings has no corresponding Requirement -
<requirement id="_5941b0e3-b8ac-02c6-96a5-f8da75d20226" model="ogc" type="class">
-<title>Simple Encodings JSON Schema</title> <identifier>/req/json-simple-encodings</identifier> <subject>JSON Document</subject> <inherit>/req/json-simple-encodings</inherit> <inherit>/req/text-encoding-rules</inherit> <inherit>/req/json-encoding-rules</inherit>
-
-</requirement>
003585_​9acc1a88-e86e-a618-­4410-7b27b372e782Requirement class /req/​json-advanced-­encodings has no corresponding Conformance class -
<requirement id="_9acc1a88-e86e-a618-4410-7b27b372e782" model="ogc" type="class">
-<title>Advanced Encodings JSON Schema</title> <identifier>/req/json-advanced-encodings</identifier> <subject>JSON Document</subject> <inherit>/req/uml-advanced-encodings</inherit> <inherit>/req/json-simple-encodings</inherit> <inherit>/req/binary-encoding-rules</inherit>
-
-</requirement>
003585_​9acc1a88-e86e-a618-­4410-7b27b372e782Requirement class /req/​json-advanced-­encodings has no corresponding Requirement -
<requirement id="_9acc1a88-e86e-a618-4410-7b27b372e782" model="ogc" type="class">
-<title>Advanced Encodings JSON Schema</title> <identifier>/req/json-advanced-encodings</identifier> <subject>JSON Document</subject> <inherit>/req/uml-advanced-encodings</inherit> <inherit>/req/json-simple-encodings</inherit> <inherit>/req/binary-encoding-rules</inherit>
-
-</requirement>
003618_​15046b98-8fe1-d39d-­671e-f764994f701cRequirement /req/​xsd-advanced-e­ncodings/​ref-syntax-­valid has no corresponding Conformance test -
<requirement id="_15046b98-8fe1-d39d-671e-f764994f701c" model="ogc">  <identifier>/req/xsd-advanced-encodings/ref-syntax-valid</identifier>
-
-<description> <p id="_04fc4bec-2c64-15ae-fee9-bc2614429b01">The “ref” attribute of the “Component” and “Block” elements shall contain a hierarchical ‘/’ separated list of data component names.</p> </description>
-</requirement>
003628_​84816db2-598f-b3fa-­10e5-3d188d5d011dRequirement /req/​xsd-advanced-e­ncodings/​scalar-ref-­component-valid has no corresponding Conformance test -
<requirement id="_84816db2-598f-b3fa-10e5-3d188d5d011d" model="ogc">  <identifier>/req/xsd-advanced-encodings/scalar-ref-component-valid</identifier>
-
-<description> <p id="_9c1216fb-06a2-1331-f16c-962d248f2674">The “ref” attribute of a “Component” element shall reference a scalar or range component.</p> </description>
-</requirement>
003638_​3665aee1-2ec8-849b-­5d5e-0a4f0e656202Requirement /req/​xsd-advanced-e­ncodings/​datatype-va­lid has no corresponding Conformance test -
<requirement id="_3665aee1-2ec8-849b-5d5e-0a4f0e656202" model="ogc">  <identifier>/req/xsd-advanced-encodings/datatype-valid</identifier>
-
-<description> <p id="_5f5149ae-99f9-b6b7-3c36-bf4588c5b855">The value of the “dataType” XML attribute of the “Component” element shall be one of the URIs listed in <xref target="binary-datatypes-table"/>.</p> </description>
-</requirement>
003714_​029e4bde-d12d-4add-­0e9d-35671234858aRequirement /req/​xsd-advanced-e­ncodings/​datatype-co­mpatible has no corresponding Conformance test -
<requirement id="_029e4bde-d12d-4add-0e9d-35671234858a" model="ogc">  <identifier>/req/xsd-advanced-encodings/datatype-compatible</identifier>
-
-<description> <p id="_ec1fc219-c4c4-a671-57c2-0332086d7114">The chosen data type shall be compatible with the scalar component representation, constraints and NIL values.</p> </description>
-</requirement>
003724_​4d5ffe24-8c67-fc21-­ef8a-a4ade56dc3c6Requirement /req/​xsd-advanced-e­ncodings/​no-datatype­-length has no corresponding Conformance test -
<requirement id="_4d5ffe24-8c67-fc21-ef8a-a4ade56dc3c6" model="ogc">  <identifier>/req/xsd-advanced-encodings/no-datatype-length</identifier>
-
-<description> <p id="_730ceb10-4f01-fa2e-0b5e-8108ff9929af">The “bitLength” and “byteLength” XML attributes shall not be set when a fixed size data type is used.</p> </description>
-</requirement>
003743_​1907413d-16cf-2fff-­31d1-00a12dbcc8c0Requirement class /req/​general-encodi­ng-rules has no corresponding Requirement -
<requirement id="_1907413d-16cf-2fff-31d1-00a12dbcc8c0" model="ogc" type="class">
-<title>General Encoding Rules</title> <identifier>/req/general-encoding-rules</identifier> <subject>Encoded Values Instance</subject> <classification> <tag>indirect-dependency</tag> <value>/req/uml-simple-encodings</value> </classification>
-
-</requirement>
003844_​c2015f20-f489-6745-­fd69-b92ab9886815Requirement class /req/​json-encoding-­rules has no corresponding Conformance class -
<requirement id="_c2015f20-f489-6745-fd69-b92ab9886815" model="ogc" type="class">
-<title>JSON Encoding Rules</title> <identifier>/req/json-encoding-rules</identifier> <subject>Encoded Values Instance</subject> <inherit>/req/general-encoding-rules</inherit> <classification> <tag>indirect-dependency</tag> <value>/req/uml-simple-encodings</value> </classification>
-
-</requirement>
003844_​c2015f20-f489-6745-­fd69-b92ab9886815Requirement class /req/​json-encoding-­rules has no corresponding Requirement -
<requirement id="_c2015f20-f489-6745-fd69-b92ab9886815" model="ogc" type="class">
-<title>JSON Encoding Rules</title> <identifier>/req/json-encoding-rules</identifier> <subject>Encoded Values Instance</subject> <inherit>/req/general-encoding-rules</inherit> <classification> <tag>indirect-dependency</tag> <value>/req/uml-simple-encodings</value> </classification>
-
-</requirement>
003866_​3b8c2409-b7a4-feb3-­ca1a-71604e23b107Requirement /req/​json-encodings­-rules/​json-valid has no corresponding Conformance test -
<requirement id="_3b8c2409-b7a4-feb3-ca1a-71604e23b107" model="ogc">  <identifier>/req/json-encodings-rules/json-valid</identifier>
-
-<description> <p id="_30f04319-33b6-1245-7d25-f0fa5c5d99ab">Data blocks and datastreams encoded using the JSON Encoding rules shall be valid JSON documents as defined by <eref type="inline" bibitemid="JSON" citeas="IETF RFC 8259"/>.</p> </description>
-</requirement>
003888_​46bffada-b372-7dd9-­8207-499d97fa4889Requirement /req/​json-encoding-­rules/​scalar-value-v­alid has no corresponding Conformance test -
<requirement id="_46bffada-b372-7dd9-8207-499d97fa4889" model="ogc">  <identifier>/req/json-encoding-rules/scalar-value-valid</identifier>
-
-<description> <p id="_eff9618f-a095-4d2f-a82d-630796a248d6">The value of a scalar component shall be represented using a JSON Number, a JSON String, or a boolean literal value, as defined in <xref target="json_value_types_mappings"/>.</p> </description>
-</requirement>
003946_​489031e3-0f6f-aca0-­6709-04b408d805f8Requirement /req/​json-encoding-­rules/​range-value-va­lid has no corresponding Conformance test -
<requirement id="_489031e3-0f6f-aca0-6709-04b408d805f8" model="ogc"> <identifier>/req/json-encoding-rules/range-value-valid</identifier> <component class="part"> <p id="_6490401e-7224-9245-f5a2-e327a2f7a66c">Values of range components shall be wrapped in a JSON Array with exactly 2 scalar values.</p>
-</component> <component class="part"> <p id="_a2028d3f-7bc4-b2d9-9d9f-7e50cd33f4f5">Each value is encoded in the same manner as the corresponding scalar component as defined in <xref target="json_value_types_mappings"/>.</p>
-</component>
-</requirement>
003987_​953406a4-525e-80cd-­0524-b9704a7dfde2Requirement /req/​json-encoding-­rules/​record-object-­valid has no corresponding Conformance test -
<requirement id="_953406a4-525e-80cd-0524-b9704a7dfde2" model="ogc"> <identifier>/req/json-encoding-rules/record-object-valid</identifier> <component class="part"> <p id="_016d3745-396f-71d9-6fa1-b61c1d7a3ca3">“DataRecord” values shall be wrapped in a JSON Object.</p>
-</component> <component class="part"> <p id="_beb46f4e-0820-ea0d-5311-f053a5ea6db2">The name of the JSON object members shall be the same as the “DataRecord” field names.</p>
-</component> <component class="part"> <p id="_3e5e5677-9e42-cf79-0ae5-37f974244410">The value of each JSON Object member shall be chosen by following the encoding rules of the data component used as the record field with the same name.</p>
-</component> <component class="part"> <p id="_2f119b7e-0c0b-8d41-44c9-cc0bb81c2ca8">If a record field is marked as ‘optional’, the corresponding JSON object member can be omitted or its JSON value can be set to <tt>null</tt>.</p>
-</component>
004005_​a1338f02-ad0f-421f-­9920-3f8cac2c246aRequirement /req/​json-encoding-­rules/​vector-object-­valid has no corresponding Conformance test -
<requirement id="_a1338f02-ad0f-421f-9920-3f8cac2c246a" model="ogc"> <identifier>/req/json-encoding-rules/vector-object-valid</identifier> <component class="part"> <p id="_e77ba825-07a2-8378-2f5c-443af93aef38">“Vector” values shall be wrapped in a JSON Object.</p>
-</component> <component class="part"> <p id="_1cfa451d-2873-16a7-75b8-d9bf7048b577">The name of the JSON object members shall be the same as the “Vector” coordinate names.</p>
-</component> <component class="part"> <p id="_50d7ad5a-6709-c5a9-bf08-88c5ca238445">The value of each JSON Object member shall be chosen by following the encoding rules of the data component used as the vector coordinate field with the same name.</p>
-</component>
-</requirement>
004037_​12c87431-1947-c69f-­15c5-0c43e75e6b74Requirement /req/​json-encoding-­rules/​choice-object-­valid has no corresponding Conformance test -
<requirement id="_12c87431-1947-c69f-15c5-0c43e75e6b74" model="ogc"> <identifier>/req/json-encoding-rules/choice-object-valid</identifier> <component class="part"> <p id="_d2a3e69f-6536-bc3a-5967-62879e1be820">“DataChoice” values shall be encapsulated in a JSON Object.</p>
-</component> <component class="part"> <p id="_84c88ab6-cc49-9594-99d6-4b9e32bd53f8">The JSON object shall contain a single member whose name is the same as the selected choice item.</p>
-</component> <component class="part"> <p id="_e2851041-0698-3652-7c6b-a68dd5fbf984">The JSON value of this unique member shall be chosen according to the encoding rules of the data component corresponding to the selected item.</p>
-</component>
-</requirement>
004059_​09dddaa8-1dd2-18dc-­190b-a09aebdd30ecRequirement /req/​json-encoding-­rules/​array-values-v­alid has no corresponding Conformance test -
<requirement id="_09dddaa8-1dd2-18dc-190b-a09aebdd30ec" model="ogc"> <identifier>/req/json-encoding-rules/array-values-valid</identifier> <component class="part"> <p id="_b7c62353-b69f-c82e-aa96-09bba20b29f4">“DataArray” and “Matrix” values shall be encapsulated in a JSON Array.</p>
-</component> <component class="part"> <p id="_cdce5754-a73d-9c3a-ceea-da90fbc49f3f">Each array element shall be encoded using the rules corresponding to the data component used as the array element type.</p>
-</component>
-</requirement>
004084_​80ea57d1-de9e-d411-­aa3a-ae26f74e3e6eRequirement /req/​json-encodings­-rules/​geometry-vali­d has no corresponding Conformance test -
<requirement id="_80ea57d1-de9e-d411-aa3a-ae26f74e3e6e" model="ogc"> <identifier>/req/json-encodings-rules/geometry-valid</identifier> <component class="part"> <p id="_6d429430-0736-1e67-8840-e81c6eb1bb94">The value of a “Geometry” component shall be encoded as a GeoJSON Geometry Object, following rules defined by <eref type="inline" bibitemid="GeoJSON" citeas="IETF RFC 7946"/>.</p>
-</component> <component class="part"> <p id="_6d878d22-dc4e-1a49-9ad5-83d329a2d3f0">The allowed GeoJSON geometry types shall be restricted to: <tt>Point</tt>, <tt>LineString</tt>, <tt>Polygon</tt>, <tt>MultiPoint</tt>, <tt>MultiLineString</tt>, and <tt>MultiPolygon</tt> </p>
-</component> <component class="part"> <p id="_c8c9b794-acd3-5126-ca39-857f7fa36301">The number of dimensions of the GeoJSON geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component.</p>
-</component>
-</requirement>
004123_​cc4eb8a1-db2e-a8e9-­78a6-1e923ad92b51Requirement class /req/​text-encoding-­rules has no corresponding Requirement -
<requirement id="_cc4eb8a1-db2e-a8e9-78a6-1e923ad92b51" model="ogc" type="class">
-<title>Text Encoding Rules</title> <identifier>/req/text-encoding-rules</identifier> <subject>Encoded Values Instance</subject> <inherit>/req/general-encoding-rules</inherit> <classification> <tag>indirect-dependency</tag> <value>/req/uml-simple-encodings</value> </classification>
-
-</requirement>
004145_​5a2935fe-255d-fb10-­0f4e-1957c185aa3fRequirement /req/​text-encodings­-rules/​abnf-syntax-v­alid has no corresponding Conformance test -
<requirement id="_5a2935fe-255d-fb10-0f4e-1957c185aa3f" model="ogc">  <identifier>/req/text-encodings-rules/abnf-syntax-valid</identifier>
-
-<description> <p id="_ec7d7999-d082-428e-97db-664995a0944b">The encoded values block shall be formatted as defined by the ABNF grammar defined in this clause.</p> </description>
-</requirement>
004159_​868cd68c-010f-f254-­2ed8-2fff5bdf8bc5Requirement /req/​text-encodings­-rules/​separators-va­lid has no corresponding Conformance test -
<requirement id="_868cd68c-010f-f254-2ed8-2fff5bdf8bc5" model="ogc">  <identifier>/req/text-encodings-rules/separators-valid</identifier>
-
-<description> <p id="_6aad5585-abb0-9fcb-fbb0-1432cf1a496d">Block and token separators used in the “TextEncoding” method shall be chosen as a sequence of characters that never occur in the data values themselves.</p> </description>
-</requirement>
004224_​6db1335b-3007-20b7-­9809-e49aca52bdebRequirement /req/​text-encodings­-rules/​optional-fiel­d-marker-present has no corresponding Conformance test -
<requirement id="_6db1335b-3007-20b7-9809-e49aca52bdeb" model="ogc">  <identifier>/req/text-encodings-rules/optional-field-marker-present</identifier>
-
-<description> <p id="_397248f2-0321-c29c-ad64-54385f304980">The ‘Y’ or ‘N’ token shall be inserted in a text encoded data block for all fields that have the “optional” attribute set to ‘true’.</p> </description>
-</requirement>
004259_​3c894731-50fe-75f7-­83d3-da90958c0f49Requirement /req/​text-encodings­-rules/​choice-select­ion-marker-valid has no corresponding Conformance test -
<requirement id="_3c894731-50fe-75f7-83d3-da90958c0f49" model="ogc">  <identifier>/req/text-encodings-rules/choice-selection-marker-valid</identifier>
-
-<description> <p id="_69177994-4ae9-b3f4-f6d6-2cd818171f3c">The selected-item-name token shall correspond to the value of the “name” attribute of the “item” property element that represents the selected item.</p> </description>
-</requirement>
004323_​dafd2c5a-fdf3-ae77-­d431-914df3143c22Requirement /req/​text-encodings­-rules/​geometry-vali­d has no corresponding Conformance test -
<requirement id="_dafd2c5a-fdf3-ae77-d431-914df3143c22" model="ogc"> <identifier>/req/text-encodings-rules/geometry-valid</identifier> <component class="part"> <p id="_5ce1a39a-c63a-574e-2369-6a6abde46240">The value of a “Geometry” component shall be encoded using the WKT format defined in <eref type="inline" bibitemid="OGC_SFA" citeas="OGC 06-103r4"/>, clause 7.</p>
-</component> <component class="part"> <p id="_6cb17868-8336-000b-2b13-fef82aeb4176">The WKT representation shall be either a “Two-Dimension Geometry WKT” (clause 7.2.2 of <eref type="inline" bibitemid="OGC_SFA" citeas="OGC 06-103r4"/>) or a “Three-Dimension Geometry WKT” (clause 7.2.3 of <eref type="inline" bibitemid="OGC_SFA" citeas="OGC 06-103r4"/>). The ‘M’ coordinate shall not be used.</p>
-</component> <component class="part"> <p id="_5047514d-e22c-343d-8aa4-c10a597b0c1e">The number of dimensions of the WKT geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component.</p>
-</component> <component class="part"> <p id="_23dd179f-70bc-3f5e-c27c-ab548034824d">When a geometry value is included in a text-encoded datastream, the token separator shall not be the comma character (ASCII code 44) to avoid conflicting with commas used inside the WKT representation.</p>
-</component>
004368_​b1ce9c3b-8a15-9fd0-­be63-ac80b4fe0b44Requirement class /req/​binary-encodin­g-rules has no corresponding Requirement -
<requirement id="_b1ce9c3b-8a15-9fd0-be63-ac80b4fe0b44" model="ogc" type="class">
-<title>Binary Encoding Rules</title> <identifier>/req/binary-encoding-rules</identifier> <subject>Encoded Values Instance</subject> <inherit>/req/general-encoding-rules</inherit> <classification> <tag>indirect-dependency</tag> <value>/req/uml-advanced-encodings</value> </classification>
-
-</requirement>
004543_​ca510e08-11ec-e6db-­02ab-eede857cfe5fRequirement /req/​binary-encodin­gs-rules/​geometry-va­lid has no corresponding Conformance test -
<requirement id="_ca510e08-11ec-e6db-02ab-eede857cfe5f" model="ogc"> <identifier>/req/binary-encodings-rules/geometry-valid</identifier> <component class="part"> <p id="_494f55d4-652b-27ea-3909-be55d54ea17e">The value of a “Geometry” component shall be encoded using the WKB format defined in <eref type="inline" bibitemid="OGC_SFA" citeas="OGC 06-103r4"/>, clause 8.</p>
-</component> <component class="part"> <p id="_1eac5982-66c9-dcda-be90-ab3f308cfabd">The WKB geometry type shall be one of the following types listed in <eref type="inline" bibitemid="OGC_SFA" citeas="OGC 06-103r4"/>, clause 8.2.3, table 7: <tt>Point</tt>, <tt>LineString</tt>, <tt>Polygon</tt>, <tt>MultiPoint</tt>, <tt>MultiLineString</tt>, <tt>MultiPolygon</tt>, <tt>Point Z</tt>, <tt>LineString Z</tt>, <tt>Polygon Z</tt>, <tt>MultiPoint Z</tt>, <tt>MultiLineString Z</tt>, <tt>MultiPolygon Z</tt>. Other geometry type codes shall not be used.</p>
-</component> <component class="part"> <p id="_d4169bac-78f6-f9b7-e6bc-a8046de39d34">The number of dimensions of the WKB geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component.</p>
-</component>
-</requirement>
004589_​2e94aa21-11f9-9580-­16b8-f4c966aa814bConformance class /conf/​core has no corresponding Conformance test -
<requirement id="_2e94aa21-11f9-9580-16b8-f4c966aa814b" model="ogc" type="conformanceclass"> <identifier>/conf/core</identifier> <classification> <tag>Target Type</tag> <value>Derived Models and Software Implementations</value> </classification> <classification> <tag>target</tag> <value>/req/core</value> </classification>
-</requirement>
004601_​1f55f341-eb03-7b04-­f1fe-1256a96a481eConformance test /conf/​core/​core-concepts-used has no corresponding Conformance class -
<requirement id="_1f55f341-eb03-7b04-f1fe-1256a96a481e" model="ogc" type="abstracttest">
-<title>Core concepts are the base of all derived models</title> <identifier>/conf/core/core-concepts-used</identifier> <classification> <tag>target</tag> <value>/req/core/core-concepts-used</value> </classification> <component class="test-purpose"> <p id="_2f02a668-5949-fb8a-f3c9-2d3bc3a590da">Verify that the target implementation correctly implements the core concepts.</p>
-</component>
-
-
004618_​b5365a63-e3ac-56b3-­b7e7-70afb3de616aConformance test /conf/​core/​boolean-rep-valid has no corresponding Conformance class -
<requirement id="_b5365a63-e3ac-56b3-b7e7-70afb3de616a" model="ogc" type="abstracttest">
-<title>A boolean representation consists of a boolean value</title> <identifier>/conf/core/boolean-rep-valid</identifier> <classification> <tag>target</tag> <value>/req/core/boolean-rep-valid</value> </classification> <component class="test-purpose"> <p id="_256cbb8e-ee15-e7d8-098e-05dc5208b009">Verify that the target implementation correctly implements the Boolean representation.</p>
-</component>
-
-
004635_​dd3d410f-0ced-ea27-­b3d7-0ab262f4d729Conformance test /conf/​core/​categorical-rep-valid has no corresponding Conformance class -
<requirement id="_dd3d410f-0ced-ea27-b3d7-0ab262f4d729" model="ogc" type="abstracttest">
-<title>A categorical representation consists of a token with a code space</title> <identifier>/conf/core/categorical-rep-valid</identifier> <classification> <tag>target</tag> <value>/req/core/categorical-rep-valid</value> </classification> <component class="test-purpose"> <p id="_086f347a-134e-ad51-f5fe-1529d7026bb3">Verify that the target implementation correctly implements the Categorical representation.</p>
-</component>
-
-
004652_​f42a5b56-be51-7cfa-­b705-c18183956649Conformance test /conf/​core/​numerical-rep-valid has no corresponding Conformance class -
<requirement id="_f42a5b56-be51-7cfa-b705-c18183956649" model="ogc" type="abstracttest">
-<title>A continuous numerical representation consists of a number with a scale</title> <identifier>/conf/core/numerical-rep-valid</identifier> <classification> <tag>target</tag> <value>/req/core/numerical-rep-valid</value> </classification> <component class="test-purpose"> <p id="_0c44d3cb-1337-24fa-3638-7988f2e0701f">Verify that the target implementation correctly implements the Numerical representation.</p>
-</component>
-
-
004669_​3d541508-03c4-983d-­3164-b82379f718dbConformance test /conf/​core/​countable-rep-valid has no corresponding Conformance class -
<requirement id="_3d541508-03c4-983d-3164-b82379f718db" model="ogc" type="abstracttest">
-<title>A countable representation consists of an integer number</title> <identifier>/conf/core/countable-rep-valid</identifier> <classification> <tag>target</tag> <value>/req/core/countable-rep-valid</value> </classification> <component class="test-purpose"> <p id="_2492a9bc-cf7d-4c0a-8f5e-a0871a18b132">Verify that the target implementation correctly implements the Countable representation.</p>
-</component>
-
-
004686_​0fcd9892-59a5-f7c6-­a371-9a12278fe563Conformance test /conf/​core/​textual-rep-valid has no corresponding Conformance class -
<requirement id="_0fcd9892-59a5-f7c6-a371-9a12278fe563" model="ogc" type="abstracttest">
-<title>A textual representation is implemented as a character string</title> <identifier>/conf/core/textual-rep-valid</identifier> <classification> <tag>target</tag> <value>/req/core/textual-rep-valid</value> </classification> <component class="test-purpose"> <p id="_5253fd0c-887a-0557-e248-af1881411898">Verify that the target implementation correctly implements the Textual representation.</p>
-</component>
-
-
004703_​62ae396f-d39a-3929-­4947-8cf2acea2049Conformance test /conf/​core/​semantics-defined has no corresponding Conformance class -
<requirement id="_62ae396f-d39a-3929-4947-8cf2acea2049" model="ogc" type="abstracttest">
-<title>A semantic definition of each property shall be provided</title> <identifier>/conf/core/semantics-defined</identifier> <classification> <tag>target</tag> <value>/req/core/semantics-defined</value> </classification> <component class="test-purpose"> <p id="_fb3b14fc-148a-8208-0d55-883033901091">Verify that the target implementation allows attaching a semantic definition to all property representations.</p>
-</component>
-
-
004720_​f6ca1eff-5254-37bb-­860a-72bf5e3373c7Conformance test /conf/​core/​semantics-resolvable has no corresponding Conformance class -
<requirement id="_f6ca1eff-5254-37bb-860a-72bf5e3373c7" model="ogc" type="abstracttest">
-<title>References to semantical information shall be resolvable</title> <identifier>/conf/core/semantics-resolvable</identifier> <classification> <tag>target</tag> <value>/req/core/semantics-resolvable</value> </classification> <component class="test-purpose"> <p id="_62ab3857-3c55-4966-cbaa-9741496f35e7">Verify that the target implementation encodes the semantic links in a way that they can be resolved to an actual concept definition.</p>
-</component>
-
-
004737_​9b17e49c-0a5e-ff47-­cd32-aa6532b308b0Conformance test /conf/​core/​temporal-frame-defined has no corresponding Conformance class -
<requirement id="_9b17e49c-0a5e-ff47-cd32-aa6532b308b0" model="ogc" type="abstracttest">
-<title>A temporal quantity is associated to a temporal reference frame</title> <identifier>/conf/core/temporal-frame-defined</identifier> <classification> <tag>target</tag> <value>/req/core/temporal-frame-defined</value> </classification> <component class="test-purpose"> <p id="_b79bfe4c-3d20-6477-b397-0215007f0859">Verify that the target implementation allows providing a temporal reference frame along with any date/time quantity.</p>
-</component>
-
-
004754_​d1e381f3-ef78-b336-­5679-f9f664cd2a44Conformance test /conf/​core/​spatial-frame-defined has no corresponding Conformance class -
<requirement id="_d1e381f3-ef78-b336-5679-f9f664cd2a44" model="ogc" type="abstracttest">
-<title>A spatial quantity is associated to an axis of a spatial reference frame</title> <identifier>/conf/core/spatial-frame-defined</identifier> <classification> <tag>target</tag> <value>/req/core/spatial-frame-defined</value> </classification> <component class="test-purpose"> <p id="_aa5c2d2a-3bb2-9a4c-3a16-d39aabcc2c9c">Verify that the target implementation allows providing a spatial reference frame and axis along with any quantity that is projected along a spatial dimension.</p>
-</component>
-
-
004771_​6d591855-e9df-7057-­3484-d1792560969bConformance test /conf/​core/​nil-reasons-defined has no corresponding Conformance class -
<requirement id="_6d591855-e9df-7057-3484-d1792560969b" model="ogc" type="abstracttest">
-<title>A NIL value maps a reserved value to a reason</title> <identifier>/conf/core/nil-reasons-defined</identifier> <classification> <tag>target</tag> <value>/req/core/nil-reasons-defined</value> </classification> <component class="test-purpose"> <p id="_42a01bb7-0eee-b4d4-fc08-0529973b9f27">Verify that the target implementation allows providing a reason along with each NIL (reserved) value.</p>
-</component>
-
-
004788_​f5349524-3e6e-097b-­b4bb-68e196ad1c50Conformance test /conf/​core/​aggregates-model-valid has no corresponding Conformance class -
<requirement id="_f5349524-3e6e-097b-b4bb-68e196ad1c50" model="ogc" type="abstracttest">
-<title>Aggregate data types are modeled according to ISO 11404</title> <identifier>/conf/core/aggregates-model-valid</identifier> <classification> <tag>target</tag> <value>/req/core/aggregates-model-valid</value> </classification> <component class="test-purpose"> <p id="_23a81749-cdfb-777a-8ef1-88e0215d6ec8">Verify that the target implementation models aggregate data types according to ISO 11404 definitions.</p>
-</component>
-
-
004805_​e7e68016-7366-6985-­4d98-1e070fdefaa3Conformance test /conf/​core/​encoding-method-valid has no corresponding Conformance class -
<requirement id="_e7e68016-7366-6985-4d98-1e070fdefaa3" model="ogc" type="abstracttest">
-<title>Encoding methods shall be defined for all possible data structures</title> <identifier>/conf/core/encoding-method-valid</identifier> <classification> <tag>target</tag> <value>/req/core/encoding-method-valid</value> </classification> <component class="test-purpose"> <p id="_5294388b-bacd-f967-5383-e644e1ae050d">Verify that the target implementation provides encoding methods for all representations and all implemented data structures.</p>
-</component>
-
-
004828_​8fd371be-e163-3e07-­276d-169b28da25a8Conformance class /conf/​uml-simple-co­mponents has no corresponding Conformance test -
<requirement id="_8fd371be-e163-3e07-276d-169b28da25a8" model="ogc" type="conformanceclass">
-<title>Basic Types and Simple Components UML Packages</title> <identifier>/conf/uml-simple-components</identifier> <inherit>/conf/core</inherit> <classification> <tag>Target Type</tag> <value>Derived Models and Software Implementations</value> </classification> <classification> <tag>target</tag> <value>/req/uml-simple-components</value> </classification>
-
-</requirement>
004845_​ec727618-01a0-8bb7-­1264-c3e3bbfdd161Conformance test /conf/​uml-simple-co­mponents/​package-ful­ly-implemented has no corresponding Conformance class -
<requirement id="_ec727618-01a0-8bb7-1264-c3e3bbfdd161" model="ogc" type="abstracttest">
-<title>Compliance with UML models defined in this package</title> <identifier>/conf/uml-simple-components/package-fully-implemented</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/package-fully-implemented</value> </classification> <component class="test-purpose"> <p id="_78469ee7-6c95-1179-6ed5-cc3f6f367b25">Verify that the target implements all classes in the UML package.</p>
-</component>
-
-
004862_​1d593a64-81e0-f014-­2bfb-a19bf4c56cc0Conformance test /conf/​uml-simple-co­mponents/​iso19103-im­plemented has no corresponding Conformance class -
<requirement id="_1d593a64-81e0-f014-2bfb-a19bf4c56cc0" model="ogc" type="abstracttest">
-<title>Compliance with UML models defined in ISO 19103</title> <identifier>/conf/uml-simple-components/iso19103-implemented</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/iso19103-implemented</value> </classification> <component class="test-purpose"> <p id="_bd6f96f1-b0f9-91a4-e761-f6af31d3cb2e">Verify that the target implements all classes imported from ISO 19103 UML packages.</p>
-</component>
-
-
004879_​7763f80b-6944-f333-­64d9-d3c4ca4eeccbConformance test /conf/​uml-simple-co­mponents/​iso19108-im­plemented has no corresponding Conformance class -
<requirement id="_7763f80b-6944-f333-64d9-d3c4ca4eeccb" model="ogc" type="abstracttest">
-<title>Compliance with UML models defined in ISO 19108</title> <identifier>/conf/uml-simple-components/iso19108-implemented</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/iso19108-implemented</value> </classification> <component class="test-purpose"> <p id="_038d6de7-e81c-b94a-f31e-8f1bd8fbf386">Verify that the target implements all classes imported from ISO 19108 UML packages.</p>
-</component>
-
-
004896_​7b84a17a-c4ea-7d68-­00af-f64e12752a61Conformance test /conf/​uml-simple-co­mponents/​definition-­present has no corresponding Conformance class -
<requirement id="_7b84a17a-c4ea-7d68-00af-f64e12752a61" model="ogc" type="abstracttest">
-<title>A definition URI is mandatory on all simple components</title> <identifier>/conf/uml-simple-components/definition-present</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/definition-present</value> </classification> <component class="test-purpose"> <p id="_61e29fa4-1e81-8e60-09ca-d8d0cf323257">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
004913_​2f72e808-9edb-3f01-­fa1c-c98ae66ef95cConformance test /conf/​uml-simple-co­mponents/​axis-valid has no corresponding Conformance class -
<requirement id="_2f72e808-9edb-3f01-fa1c-c98ae66ef95c" model="ogc" type="abstracttest">
-<title>The value of the axisID and axisAbbrev attributes match</title> <identifier>/conf/uml-simple-components/axis-valid</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/axis-valid</value> </classification> <component class="test-purpose"> <p id="_2486f6cd-b3d9-8827-fead-23b50aad67ae">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
004930_​38a63c29-32d4-39cf-­1288-280f6ed20fd6Conformance test /conf/​uml-simple-co­mponents/​axis-define­d has no corresponding Conformance class -
<requirement id="_38a63c29-32d4-39cf-1288-280f6ed20fd6" model="ogc" type="abstracttest">
-<title>The axis ID is always specified on scalar spatial properties</title> <identifier>/conf/uml-simple-components/axis-defined</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/axis-defined</value> </classification> <component class="test-purpose"> <p id="_f2e36aab-3076-fecf-4920-ddcb3e07f8b0">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
004947_​918c07b5-7c56-dfee-­4cc5-87a36991e593Conformance test /conf/​uml-simple-co­mponents/​ref-frame-d­efined has no corresponding Conformance class -
<requirement id="_918c07b5-7c56-dfee-4cc5-87a36991e593" model="ogc" type="abstracttest">
-<title>The reference frame is specified on scalar spatial properties not part of a vector</title> <identifier>/conf/uml-simple-components/ref-frame-defined</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/ref-frame-defined</value> </classification> <component class="test-purpose"> <p id="_ffa013bf-dac0-0fd9-b46a-7fd453538b43">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
004964_​9df5ed8c-0cc7-c93e-­962f-8827f8ccfa48Conformance test /conf/​uml-simple-co­mponents/​value-const­raint-valid has no corresponding Conformance class -
<requirement id="_9df5ed8c-0cc7-c93e-962f-8827f8ccfa48" model="ogc" type="abstracttest">
-<title>The value of a component satisfies the constraints</title> <identifier>/conf/uml-simple-components/value-constraint-valid</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/value-constraint-valid</value> </classification> <component class="test-purpose"> <p id="_2423401b-0e48-9093-ee9b-f00863fe70a7">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
004981_​7608113c-e18e-1477-­7a54-944cc143cc17Conformance test /conf/​uml-simple-co­mponents/​value-attri­bute-present has no corresponding Conformance class -
<requirement id="_7608113c-e18e-1477-7a54-944cc143cc17" model="ogc" type="abstracttest">
-<title>All derived simple components have an optional value attribute</title> <identifier>/conf/uml-simple-components/value-attribute-present</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/value-attribute-present</value> </classification> <component class="test-purpose"> <p id="_0a68cde6-05a3-62f3-ec9a-99b391bc6120">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
004998_​a3642a51-c9e0-329d-­84e2-412a89e90aadConformance test /conf/​uml-simple-co­mponents/​category-co­nstraint-valid has no corresponding Conformance class -
<requirement id="_a3642a51-c9e0-329d-84e2-412a89e90aad" model="ogc" type="abstracttest">
-<title>The list of values allowed in a Category component is a subset of the code space</title> <identifier>/conf/uml-simple-components/category-constraint-valid</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/category-constraint-valid</value> </classification> <component class="test-purpose"> <p id="_ad1652c1-d167-1c79-a6cf-7e34b339fddd">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
005015_​e593b018-a5d6-95aa-­e3c1-ba12b38bec01Conformance test /conf/​uml-simple-co­mponents/​category-en­um-defined has no corresponding Conformance class -
<requirement id="_e593b018-a5d6-95aa-e3c1-ba12b38bec01" model="ogc" type="abstracttest">
-<title>A Category component always specifies a list of possible values</title> <identifier>/conf/uml-simple-components/category-enum-defined</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/category-enum-defined</value> </classification> <component class="test-purpose"> <p id="_95200efc-bd62-29cd-e0d9-5c71f4a7ad2a">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
005032_​4551a35a-a720-e0b0-­2946-f3a671a26a23Conformance test /conf/​uml-simple-co­mponents/​category-va­lue-valid has no corresponding Conformance class -
<requirement id="_4551a35a-a720-e0b0-2946-f3a671a26a23" model="ogc" type="abstracttest">
-<title>The value of a Category component is one defined in the code space</title> <identifier>/conf/uml-simple-components/category-value-valid</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/category-value-valid</value> </classification> <component class="test-purpose"> <p id="_0b57b77e-33fa-df83-8337-0508afea6432">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
005049_​1a840f67-2ed8-3e75-­6c20-eb09d63ad675Conformance test /conf/​uml-simple-co­mponents/​time-ref-fr­ame-defined has no corresponding Conformance class -
<requirement id="_1a840f67-2ed8-3e75-6c20-eb09d63ad675" model="ogc" type="abstracttest">
-<title>The temporal reference frame is defined</title> <identifier>/conf/uml-simple-components/time-ref-frame-defined</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/time-ref-frame-defined</value> </classification> <component class="test-purpose"> <p id="_ad2547d9-09f0-81b5-203f-034546f275eb">Verify that the implementation correctly assumes the default value when the attribute is not set.</p>
-</component>
-
-
005066_​76c2de34-aa20-6e9d-­8877-d380a5559faaConformance test /conf/​uml-simple-co­mponents/​time-ref-ti­me-valid has no corresponding Conformance class -
<requirement id="_76c2de34-aa20-6e9d-8877-d380a5559faa" model="ogc" type="abstracttest">
-<title>The time of reference is expressed relative to the origin of the reference frame</title> <identifier>/conf/uml-simple-components/time-ref-time-valid</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/time-ref-time-valid</value> </classification> <component class="test-purpose"> <p id="_4c9f348a-8a51-bedd-c365-7a0d5eba32ee">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
005083_​f2ed762a-89f8-e545-­e171-5decf3d35e93Conformance test /conf/​uml-simple-co­mponents/​time-local-­frame-valid has no corresponding Conformance class -
<requirement id="_f2ed762a-89f8-e545-e171-5decf3d35e93" model="ogc" type="abstracttest">
-<title>The local and reference frames of a Time component are different</title> <identifier>/conf/uml-simple-components/time-local-frame-valid</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/time-local-frame-valid</value> </classification> <component class="test-purpose"> <p id="_5274fb50-5742-a627-f873-610bca243b9b">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
005100_​358d5b78-7db5-6804-­6ed1-8d00446d33cbConformance test /conf/​uml-simple-co­mponents/​range-value­-valid has no corresponding Conformance class -
<requirement id="_358d5b78-7db5-6804-6ed1-8d00446d33cb" model="ogc" type="abstracttest">
-<title>Values of range components satisfy the same requirements as scalar values</title> <identifier>/conf/uml-simple-components/range-value-valid</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/range-value-valid</value> </classification> <component class="test-purpose"> <p id="_fe752f10-e73e-413b-a3d4-77cc964ce930">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
005117_​a6405909-acf8-e472-­2eb2-777032902bdaConformance test /conf/​uml-simple-co­mponents/​category-ra­nge-valid has no corresponding Conformance class -
<requirement id="_a6405909-acf8-e472-2eb2-777032902bda" model="ogc" type="abstracttest">
-<title>CategoryRange components satisfy all requirements of a Category component</title> <identifier>/conf/uml-simple-components/category-range-valid</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/category-range-valid</value> </classification> <component class="test-purpose"> <p id="_d8064e91-f066-9562-4678-1bef1d8609a5">Verify that the target implementation has constraints that enforce the requirement.</p>
-</component>
-
-
005143_​b9358381-d3b4-8ad3-­925f-981da87ff61fConformance test /conf/​uml-simple-co­mponents/​category-ra­nge-codespace-order has no corresponding Conformance class -
<requirement id="_b9358381-d3b4-8ad3-925f-981da87ff61f" model="ogc" type="abstracttest">
-<title>The code space of a CategoryRange component is well-ordered</title> <identifier>/conf/uml-simple-components/category-range-codespace-order</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/category-range-codespace-order</value> </classification> <component class="test-purpose"> <p id="_f977898b-f9f7-ac2c-ff0a-32a4cbf7fb26">Verify that the code space contains elements that have a specific order (either implied or defined).</p>
-</component>
-
-
005160_​86eb7b36-a3e6-f16b-­7dcd-2cc5bc65c7daConformance test /conf/​uml-simple-co­mponents/​time-range-­valid has no corresponding Conformance class -
<requirement id="_86eb7b36-a3e6-f16b-7dcd-2cc5bc65c7da" model="ogc" type="abstracttest">
-<title>TimeRange components satisfy all requirements of the Time class</title> <identifier>/conf/uml-simple-components/time-range-valid</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/time-range-valid</value> </classification> <component class="test-purpose"> <p id="_579f376f-2337-605e-1637-e1680334271f">Verify that the target implementation has constraints that enforce the requirement.</p>
-</component>
-
-
005186_​0e46c606-0125-38a8-­1ffe-7e80633fa5a0Conformance test /conf/​uml-simple-co­mponents/​nil-reason-­resolvable has no corresponding Conformance class -
<requirement id="_0e46c606-0125-38a8-1ffe-7e80633fa5a0" model="ogc" type="abstracttest">
-<title>The reason attribute is a URI that is resolvable to a definition</title> <identifier>/conf/uml-simple-components/nil-reason-resolvable</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/nil-reason-resolvable</value> </classification> <component class="test-purpose"> <p id="_5a7c7878-bd9d-c551-2d4c-7e045038199a">Verify that the target implementation allows the value of a NIL reason identifier to be either:</p>
-<ul id="_47a17258-17c9-0c47-d53f-7cdbe01a1b69"> <li> <p id="_761eb6c6-739a-cdf3-bdc7-f4e05244fa91">a well known reason code defined by OGC</p>
-</li>
-<li> <p id="_4c921710-3d9b-7c1c-40d2-13a3ce58027e">a URI that can be resolved to the textual description of a custom reason.</p>
005208_​47a7ce47-e6c4-84b9-­1703-6fab0c9186e5Conformance test /conf/​uml-simple-co­mponents/​nil-value-t­ype-coherent has no corresponding Conformance class -
<requirement id="_47a7ce47-e6c4-84b9-1703-6fab0c9186e5" model="ogc" type="abstracttest">
-<title>Values reserved for NIL reasons are compatible with the component data type</title> <identifier>/conf/uml-simple-components/nil-value-type-coherent</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/nil-value-type-coherent</value> </classification> <component class="test-purpose"> <p id="_ac5a7d5b-83a0-177f-f3fc-6a299586e295">Verify that the target implementation has a constraint that enforces the requirement.</p>
-</component>
-
-
005225_​87f9c85a-c75d-4250-­e7bc-f767f62ebe1aConformance test /conf/​uml-simple-co­mponents/​allowed-val­ues-unit-coherent has no corresponding Conformance class -
<requirement id="_87f9c85a-c75d-4250-e7bc-f767f62ebe1a" model="ogc" type="abstracttest">
-<title>The scale of constraints is the same as the scale of the component value</title> <identifier>/conf/uml-simple-components/allowed-values-unit-coherent</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-components/allowed-values-unit-coherent</value> </classification> <component class="test-purpose"> <p id="_00331a01-f980-a49a-2a8e-4ffe5f924cee">Verify that numerical constraints are expressed with the correct scale.</p>
-</component>
-
-
005245_​2a52852a-766d-5abd-­96f6-906c472153c5Conformance class /conf/​uml-record-co­mponents has no corresponding Conformance test -
<requirement id="_2a52852a-766d-5abd-96f6-906c472153c5" model="ogc" type="conformanceclass">
-<title>Record Components UML Package</title> <identifier>/conf/uml-record-components</identifier> <inherit>/conf/uml-simple-components</inherit> <classification> <tag>Target Type</tag> <value>Derived Models and Software Implementations</value> </classification> <classification> <tag>target</tag> <value>/req/uml-record-components</value> </classification>
-
-</requirement>
005262_​edd69f9a-ff81-a141-­baae-cd2e10f96446Conformance test /conf/​uml-record-co­mponents/​package-ful­ly-implemented has no corresponding Conformance class -
<requirement id="_edd69f9a-ff81-a141-baae-cd2e10f96446" model="ogc" type="abstracttest">
-<title>Compliance with UML models defined in this package</title> <identifier>/conf/uml-record-components/package-fully-implemented</identifier> <classification> <tag>target</tag> <value>/req/uml-record-components/package-fully-implemented</value> </classification> <component class="test-purpose"> <p id="_3dcb7362-d240-d94c-0949-80fec6eac33c">Verify that the target implements all classes in the UML package.</p>
-</component>
-
-
005279_​25a6b420-ac60-03d4-­a909-441eaa7c9399Conformance test /conf/​uml-record-co­mponents/​record-fiel­d-name-unique has no corresponding Conformance class -
<requirement id="_25a6b420-ac60-03d4-a909-441eaa7c9399" model="ogc" type="abstracttest">
-<title>Each DataRecord field has a unique name</title> <identifier>/conf/uml-record-components/record-field-name-unique</identifier> <classification> <tag>target</tag> <value>/req/uml-record-components/record-field-name-unique</value> </classification> <component class="test-purpose"> <p id="_6228d4ef-39bd-8f4a-b051-f433ccfa03c7">Verify that the implementation of the “DataRecord” class has a constraint that enforces the requirement.</p>
-</component>
-
-
005296_​39c41aab-68b6-6473-­42e8-53619743ad93Conformance test /conf/​uml-record-co­mponents/​vector-coor­d-name-unique has no corresponding Conformance class -
<requirement id="_39c41aab-68b6-6473-42e8-53619743ad93" model="ogc" type="abstracttest">
-<title>Each Vector coordinate has a unique name</title> <identifier>/conf/uml-record-components/vector-coord-name-unique</identifier> <classification> <tag>target</tag> <value>/req/uml-record-components/vector-coord-name-unique</value> </classification> <component class="test-purpose"> <p id="_72146362-7b61-2363-50d5-5900c437cf35">Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.</p>
-</component>
-
-
005313_​46ba33b2-f68c-9801-­fc66-b8d3ffbba236Conformance test /conf/​uml-record-co­mponents/​vector-comp­onent-no-ref-frame has no corresponding Conformance class -
<requirement id="_46ba33b2-f68c-9801-fc66-b8d3ffbba236" model="ogc" type="abstracttest">
-<title>The reference frame is not specified on individual coordinates of a Vector</title> <identifier>/conf/uml-record-components/vector-component-no-ref-frame</identifier> <classification> <tag>target</tag> <value>/req/uml-record-components/vector-component-no-ref-frame</value> </classification> <component class="test-purpose"> <p id="_1eda1423-e2d8-5fb4-d4d3-25015d57df24">Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.</p>
-</component>
-
-
005331_​3f8c9ae6-012f-4fa1-­f3ce-422be445d9b5Conformance test /conf/​uml-record-co­mponents/​vector-comp­onent-axis-defined has no corresponding Conformance class -
<requirement id="_3f8c9ae6-012f-4fa1-f3ce-422be445d9b5" model="ogc" type="abstracttest">
-<title>The axis ID is specified on all coordinates of a Vector</title> <identifier>/conf/uml-record-components/vector-component-axis-defined</identifier> <classification> <tag>target</tag> <value>/req/uml-record-components/vector-component-axis-defined</value> </classification> <component class="test-purpose"> <p id="_e6caa5f4-1751-c555-76e0-e02110e14ad2">Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.</p>
-</component>
-
-
005349_​79d162ad-847a-fc42-­ebfa-696cdacf9991Conformance test /conf/​uml-record-co­mponents/​vector-loca­l-frame-valid has no corresponding Conformance class -
<requirement id="_79d162ad-847a-fc42-ebfa-696cdacf9991" model="ogc" type="abstracttest">
-<title>The local and reference frames of a Vector component are different</title> <identifier>/conf/uml-record-components/vector-local-frame-valid</identifier> <classification> <tag>target</tag> <value>/req/uml-record-components/vector-local-frame-valid</value> </classification> <component class="test-purpose"> <p id="_707460cf-dda0-77c9-29b5-03c8a18a80ee">Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.</p>
-</component>
-
-
005369_​14e2586d-b8e3-5d67-­3f65-d624dc72f4c9Conformance class /conf/​uml-choice-co­mponents has no corresponding Conformance test -
<requirement id="_14e2586d-b8e3-5d67-3f65-d624dc72f4c9" model="ogc" type="conformanceclass">
-<title>Choice Components UML Package</title> <identifier>/conf/uml-choice-components</identifier> <inherit>/conf/uml-simple-components</inherit> <classification> <tag>Target Type</tag> <value>Derived Models and Software Implementations</value> </classification> <classification> <tag>target</tag> <value>/req/uml-choice-components</value> </classification>
-
-</requirement>
005386_​f77b7d75-af93-72a4-­c268-40cc8730a7d3Conformance test /conf/​uml-choice-co­mponents/​package-ful­ly-implemented has no corresponding Conformance class -
<requirement id="_f77b7d75-af93-72a4-c268-40cc8730a7d3" model="ogc" type="abstracttest">
-<title>Compliance with UML models defined in this package</title> <identifier>/conf/uml-choice-components/package-fully-implemented</identifier> <classification> <tag>target</tag> <value>/req/uml-choice-components/package-fully-implemented</value> </classification> <component class="test-purpose"> <p id="_199c8856-a324-9b62-6cb0-523dfa4d0082">Verify that the target implements all classes in the UML package.</p>
-</component>
-
-
005403_​85afff80-9532-e68f-­27fa-d4759d33a770Conformance test /conf/​uml-choice-co­mponents/​choice-item­-name-unique has no corresponding Conformance class -
<requirement id="_85afff80-9532-e68f-27fa-d4759d33a770" model="ogc" type="abstracttest">
-<title>Each DataChoice item has a unique name</title> <identifier>/conf/uml-choice-components/choice-item-name-unique</identifier> <classification> <tag>target</tag> <value>/req/uml-choice-components/choice-item-name-unique</value> </classification> <component class="test-purpose"> <p id="_cb97450d-39e6-5bff-814e-0363c13ca85e">Verify that the implementation of the “DataChoice” class has a constraint that enforces the requirement.</p>
-</component>
-
-
005423_​138f715c-32c3-5a93-­1e29-24e2b4f803c1Conformance class /conf/​uml-block-com­ponents has no corresponding Conformance test -
<requirement id="_138f715c-32c3-5a93-1e29-24e2b4f803c1" model="ogc" type="conformanceclass">
-<title>Block Components UML Package</title> <identifier>/conf/uml-block-components</identifier> <inherit>/conf/uml-simple-components</inherit> <classification> <tag>Target Type</tag> <value>Derived Models and Software Implementations</value> </classification> <classification> <tag>target</tag> <value>/req/uml-block-components</value> </classification>
-
-</requirement>
005440_​475c549d-10c9-c16e-­08b3-bd3c4ff8e02dConformance test /conf/​uml-block-com­ponents/​package-full­y-implemented has no corresponding Conformance class -
<requirement id="_475c549d-10c9-c16e-08b3-bd3c4ff8e02d" model="ogc" type="abstracttest">
-<title>Compliance with UML models defined in this package</title> <identifier>/conf/uml-block-components/package-fully-implemented</identifier> <classification> <tag>target</tag> <value>/req/uml-block-components/package-fully-implemented</value> </classification> <component class="test-purpose"> <p id="_941b78b3-7780-4a34-0f09-588ddf05c475">Verify that the target implements all classes in the UML package.</p>
-</component>
-
-
005457_​5adc2646-f7bf-ce36-­316d-d267851fddefConformance test /conf/​uml-block-com­ponents/​array-compon­ent-no-value has no corresponding Conformance class -
<requirement id="_5adc2646-f7bf-ce36-316d-d267851fddef" model="ogc" type="abstracttest">
-<title>Components nested in a block component are data descriptors</title> <identifier>/conf/uml-block-components/array-component-no-value</identifier> <classification> <tag>target</tag> <value>/req/uml-block-components/array-component-no-value</value> </classification> <component class="test-purpose"> <p id="_7787389d-4441-8dc1-c51b-cfa216b727b1">Verify that implementations of the block component classes have a constraint that enforces the requirement.</p>
-</component>
-
-
005475_​4469e3d1-0cd7-cd41-­4556-885c54e2373eConformance test /conf/​uml-block-com­ponents/​array-values­-properly-encoded has no corresponding Conformance class -
<requirement id="_4469e3d1-0cd7-cd41-4556-885c54e2373e" model="ogc" type="abstracttest">
-<title>An encoding method is specified whenever an encoded data block is included</title> <identifier>/conf/uml-block-components/array-values-properly-encoded</identifier> <classification> <tag>target</tag> <value>/req/uml-block-components/array-values-properly-encoded</value> </classification> <classification> <tag>target</tag> <value>/req/uml-block-components/datastream-array-valid</value> </classification> <component class="test-purpose"> <p id="_91c9f7f6-5258-36ad-3a19-fee1bd6daad1">Verify that the implementation of block component classes have a constraint that enforces the requirement.</p>
-</component>
-
-
005497_​aef43362-ff0f-f27a-­f969-87663b1ebe04Conformance test /conf/​uml-block-com­ponents/​matrix-eleme­nt-type-valid has no corresponding Conformance class -
<requirement id="_aef43362-ff0f-f27a-f969-87663b1ebe04" model="ogc" type="abstracttest">
-<title>Elements of a matrix are of scalar types or nested matrices</title> <identifier>/conf/uml-block-components/matrix-element-type-valid</identifier> <classification> <tag>target</tag> <value>/req/uml-block-components/matrix-element-type-valid</value> </classification> <component class="test-purpose"> <p id="_b3f992dd-570b-c038-c8f6-115146236782">Verify that the implementation of the “Matrix” class has a constraint that enforces the requirement.</p>
-</component>
-
-
005517_​d47f7506-c7d2-149d-­d973-83523e116cacConformance class /conf/​uml-simple-en­codings has no corresponding Conformance test -
<requirement id="_d47f7506-c7d2-149d-d973-83523e116cac" model="ogc" type="conformanceclass">
-<title>Simple Encodings UML Package</title> <identifier>/conf/uml-simple-encodings</identifier> <inherit>/conf/core</inherit> <classification> <tag>Target Type</tag> <value>Derived Models and Software Implementations</value> </classification> <classification> <tag>target</tag> <value>/req/uml-simple-encodings</value> </classification>
-
-</requirement>
005534_​695183a2-547d-e1ae-­3007-95bc968c1d56Conformance test /conf/​uml-simple-en­codings/​package-full­y-implemented has no corresponding Conformance class -
<requirement id="_695183a2-547d-e1ae-3007-95bc968c1d56" model="ogc" type="abstracttest">
-<title>Compliance with UML models defined in this package</title> <identifier>/conf/uml-simple-encodings/package-fully-implemented</identifier> <classification> <tag>target</tag> <value>/req/uml-simple-encodings/package-fully-implemented</value> </classification> <component class="test-purpose"> <p id="_6b62ef17-dd85-000d-7f34-c8df7a654721">Verify that the target implements all classes in the UML package.</p>
-</component>
-
-
005554_​8b91f92c-80ad-78ca-­2248-da82000fb0e9Conformance class /conf/​uml-advanced-­encodings has no corresponding Conformance test -
<requirement id="_8b91f92c-80ad-78ca-2248-da82000fb0e9" model="ogc" type="conformanceclass">
-<title>Advanced Encodings UML Package</title> <identifier>/conf/uml-advanced-encodings</identifier> <inherit>/conf/uml-simple-encodings</inherit> <classification> <tag>Target Type</tag> <value>Derived Models and Software Implementations</value> </classification> <classification> <tag>target</tag> <value>/req/uml-advanced-encodings</value> </classification>
-
-</requirement>
005571_​b043d1fe-abed-54bc-­f6dd-5094f8fd5c4fConformance test /conf/​uml-advanced-­encodings/​package-fu­lly-implemented has no corresponding Conformance class -
<requirement id="_b043d1fe-abed-54bc-f6dd-5094f8fd5c4f" model="ogc" type="abstracttest">
-<title>Compliance with UML models defined in this package</title> <identifier>/conf/uml-advanced-encodings/package-fully-implemented</identifier> <classification> <tag>target</tag> <value>/req/uml-advanced-encodings/package-fully-implemented</value> </classification> <component class="test-purpose"> <p id="_fcb039bf-d174-d67f-2bc8-0d2cc995f897">Verify that the target implements all classes in the UML package.</p>
-</component>
-
-
005594_​d040ba3a-ce52-3759-­013e-ce2f4017a481Conformance class /conf/​general-encod­ing-rules has no corresponding Conformance test -
<requirement id="_d040ba3a-ce52-3759-013e-ce2f4017a481" model="ogc" type="conformanceclass">
-<title>General Encoding Rules</title> <identifier>/conf/general-encoding-rules</identifier> <classification> <tag>Target Type</tag> <value>Encoded Values Instance</value> </classification> <classification> <tag>target</tag> <value>/req/general-encoding-rules</value> </classification>
-
-</requirement>
005608_​14c3ca23-b495-0275-­5a90-9f1e54f27f96Conformance test /conf/​general-encod­ing-rules/​record-enc­oding-rule has no corresponding Conformance class -
<requirement id="_14c3ca23-b495-0275-5a90-9f1e54f27f96" model="ogc" type="abstracttest">
-<title>DataRecord fields and Vector coordinates are encoded recursively</title> <identifier>/conf/general-encoding-rules/record-encoding-rule</identifier> <classification> <tag>target</tag> <value>/req/general-encoding-rules/record-encoding-rule</value> </classification>
-
-
-<description> <example id="_11b58026-da15-6a97-e45d-d6ad04b7b94f"> <p id="_41aee896-2c9c-2ae9-0e97-102c4770de62">Verify that the sequence of scalar values (obtained after decoding the section of the encoded data block corresponding to the “DataRecord” or “Vector”) includes values for the successive fields/coordinates in the right order.</p>
005622_​de1c18f7-0079-9ecc-­9be9-fc98f8eceb25Conformance test /conf/​general-encod­ing-rules/​choice-enc­oding-rule has no corresponding Conformance class -
<requirement id="_de1c18f7-0079-9ecc-9be9-fc98f8eceb25" model="ogc" type="abstracttest">
-<title>DataChoice selected item is properly encoded</title> <identifier>/conf/general-encoding-rules/choice-encoding-rule</identifier> <classification> <tag>target</tag> <value>/req/general-encoding-rules/choice-encoding-rule</value> </classification>
-
-
-<description> <example id="_54e640c2-0a55-7e40-945e-be57155302a4"> <p id="_9a6a841e-c1d8-79b5-8c61-434bc7057d00">Verify that the sequence of scalar values (obtained after decoding the section of the encoded data block corresponding to the “DataChoice”) includes a value identifying the selected item as well as values for the item itself.</p>
005636_​49b21f4f-933f-a99b-­5dd8-150927fe3702Conformance test /conf/​general-encod­ing-rules/​array-enco­ding-rule has no corresponding Conformance class -
<requirement id="_49b21f4f-933f-a99b-5dd8-150927fe3702" model="ogc" type="abstracttest">
-<title>DataArray elements are encoded recursively</title> <identifier>/conf/general-encoding-rules/array-encoding-rule</identifier> <classification> <tag>target</tag> <value>/req/general-encoding-rules/array-encoding-rule</value> </classification>
-
-
-<description> <example id="_6ff65d02-a858-808a-6ef2-f59927cbe917"> <p id="_4f91fcfb-0ca1-b090-760e-6a17ec6ce290">Verify that the sequence of scalar values obtained after decoding the section of the encoded data block corresponding to the “DataArray” includes values for the successive elements of the array.</p>
005650_​5a50d1f4-113f-c19f-­bc57-d49767a242d8Conformance test /conf/​general-encod­ing-rules/​array-size­-encoding-rule has no corresponding Conformance class -
<requirement id="_5a50d1f4-113f-c19f-bc57-d49767a242d8" model="ogc" type="abstracttest">
-<title>The length of variable size arrays is encoded in the data block</title> <identifier>/conf/general-encoding-rules/array-size-encoding-rule</identifier> <classification> <tag>target</tag> <value>/req/general-encoding-rules/array-size-encoding-rule</value> </classification>
-
-
-<description> <example id="_257e715e-4701-d169-45e3-ac322f31e253"> <p id="_a0efae92-5871-d446-350a-76b4c3da24e5">Verify that the sequence of values obtained after decoding the section of the encoded data block corresponding to a variable size “DataArray” includes a value specifying the size of the array.</p>
005667_​761a4897-4cf7-3bb3-­694a-7c35267ad7a2Conformance class /conf/​text-encoding­-rules has no corresponding Conformance test -
<requirement id="_761a4897-4cf7-3bb3-694a-7c35267ad7a2" model="ogc" type="conformanceclass">
-<title>Text Encoding Rules</title> <identifier>/conf/text-encoding-rules</identifier> <inherit>/conf/general-encoding-rules</inherit> <classification> <tag>Target Type</tag> <value>Encoded Values Instance</value> </classification> <classification> <tag>target</tag> <value>/req/text-encoding-rules</value> </classification>
-
-</requirement>
005684_​a5e7f904-8cea-6519-­2ea1-1bc52af69a97Conformance test /conf/​text-encoding­-rules/​abnf-syntax-v­alid has no corresponding Conformance class -
<requirement id="_a5e7f904-8cea-6519-2ea1-1bc52af69a97" model="ogc" type="abstracttest">
-<title>Compliance with ABNF grammar</title> <identifier>/conf/text-encoding-rules/abnf-syntax-valid</identifier> <classification> <tag>target</tag> <value>/req/text-encoding-rules/abnf-syntax-valid</value> </classification>
-
-
-<description> <example id="_52277c20-20c8-0cfd-a4b4-2fd0c88f87d1"> <p id="_7e587001-ed07-35e5-77bd-6fc8fbb7ea70">Verify that the text encoded data block is correct with respect to the ABNF grammar corresponding to the particular dataset (The complete ABNF grammar of the dataset should be dynamically constructed from the ABNF snippets provided in the specification).</p>
005684_​a5e7f904-8cea-6519-­2ea1-1bc52af69a97Conformance test /conf/​text-encoding­-rules/​abnf-syntax-v­alid has no corresponding Requirement -
<requirement id="_a5e7f904-8cea-6519-2ea1-1bc52af69a97" model="ogc" type="abstracttest">
-<title>Compliance with ABNF grammar</title> <identifier>/conf/text-encoding-rules/abnf-syntax-valid</identifier> <classification> <tag>target</tag> <value>/req/text-encoding-rules/abnf-syntax-valid</value> </classification>
-
-
-<description> <example id="_52277c20-20c8-0cfd-a4b4-2fd0c88f87d1"> <p id="_7e587001-ed07-35e5-77bd-6fc8fbb7ea70">Verify that the text encoded data block is correct with respect to the ABNF grammar corresponding to the particular dataset (The complete ABNF grammar of the dataset should be dynamically constructed from the ABNF snippets provided in the specification).</p>
005698_​6ee28b95-a4d2-cdaa-­6dfe-bccc288a401bConformance test /conf/​text-encoding­-rules/​separators-va­lid has no corresponding Conformance class -
<requirement id="_6ee28b95-a4d2-cdaa-6dfe-bccc288a401b" model="ogc" type="abstracttest">
-<title>Separator characters are well chosen</title> <identifier>/conf/text-encoding-rules/separators-valid</identifier> <classification> <tag>target</tag> <value>/req/text-encoding-rules/separators-valid</value> </classification>
-
-
-<description> <example id="_47e10d7c-6bf8-12a2-51ed-8ffbadf7cab2"> <p id="_65971efc-2b70-3a68-cb29-68ee1f51dca4">Verify that the values encoded in the data block never include the reserved separator characters. This can be detected by looking for invalid or superfluous values.</p>
005698_​6ee28b95-a4d2-cdaa-­6dfe-bccc288a401bConformance test /conf/​text-encoding­-rules/​separators-va­lid has no corresponding Requirement -
<requirement id="_6ee28b95-a4d2-cdaa-6dfe-bccc288a401b" model="ogc" type="abstracttest">
-<title>Separator characters are well chosen</title> <identifier>/conf/text-encoding-rules/separators-valid</identifier> <classification> <tag>target</tag> <value>/req/text-encoding-rules/separators-valid</value> </classification>
-
-
-<description> <example id="_47e10d7c-6bf8-12a2-51ed-8ffbadf7cab2"> <p id="_65971efc-2b70-3a68-cb29-68ee1f51dca4">Verify that the values encoded in the data block never include the reserved separator characters. This can be detected by looking for invalid or superfluous values.</p>
005712_​ef28f08b-c84a-4368-­fed2-7e9ebc93a8e1Conformance test /conf/​text-encoding­-rules/​optional-fiel­d-marker-present has no corresponding Conformance class -
<requirement id="_ef28f08b-c84a-4368-fed2-7e9ebc93a8e1" model="ogc" type="abstracttest">
-<title>Special flags are inserted before optional component values</title> <identifier>/conf/text-encoding-rules/optional-field-marker-present</identifier> <classification> <tag>target</tag> <value>/req/text-encoding-rules/optional-field-marker-present</value> </classification>
-
-
-<description> <example id="_44beacc8-6275-5525-74b1-a92a7a7cfb41"> <p id="_5d4130ff-a010-36a2-f724-f7db060693ab">Verify that the sequence of values corresponding to the optional field starts with the ‘Y’ or ‘N’ flag.</p>
005712_​ef28f08b-c84a-4368-­fed2-7e9ebc93a8e1Conformance test /conf/​text-encoding­-rules/​optional-fiel­d-marker-present has no corresponding Requirement -
<requirement id="_ef28f08b-c84a-4368-fed2-7e9ebc93a8e1" model="ogc" type="abstracttest">
-<title>Special flags are inserted before optional component values</title> <identifier>/conf/text-encoding-rules/optional-field-marker-present</identifier> <classification> <tag>target</tag> <value>/req/text-encoding-rules/optional-field-marker-present</value> </classification>
-
-
-<description> <example id="_44beacc8-6275-5525-74b1-a92a7a7cfb41"> <p id="_5d4130ff-a010-36a2-f724-f7db060693ab">Verify that the sequence of values corresponding to the optional field starts with the ‘Y’ or ‘N’ flag.</p>
005726_​fe53757f-7b2c-30f0-­132d-57d1144a36ddConformance test /conf/​text-encoding­-rules/​choice-select­ion-marker-valid has no corresponding Conformance class -
<requirement id="_fe53757f-7b2c-30f0-132d-57d1144a36dd" model="ogc" type="abstracttest">
-<title>The name of a selected choice item is inserted in the stream</title> <identifier>/conf/text-encoding-rules/choice-selection-marker-valid</identifier> <classification> <tag>target</tag> <value>/req/text-encoding-rules/choice-selection-marker-valid</value> </classification>
-
-
-<description> <example id="_a625b6fa-c96a-b48c-d8a7-2edd3ba96079"> <p id="_fd2c83bd-e10a-bf05-f3cb-b95b1c1ee025">Verify that the sequence of values corresponding to the “DataChoice” starts with a character string matching the name of one item of the choice descriptor.</p>
005726_​fe53757f-7b2c-30f0-­132d-57d1144a36ddConformance test /conf/​text-encoding­-rules/​choice-select­ion-marker-valid has no corresponding Requirement -
<requirement id="_fe53757f-7b2c-30f0-132d-57d1144a36dd" model="ogc" type="abstracttest">
-<title>The name of a selected choice item is inserted in the stream</title> <identifier>/conf/text-encoding-rules/choice-selection-marker-valid</identifier> <classification> <tag>target</tag> <value>/req/text-encoding-rules/choice-selection-marker-valid</value> </classification>
-
-
-<description> <example id="_a625b6fa-c96a-b48c-d8a7-2edd3ba96079"> <p id="_fd2c83bd-e10a-bf05-f3cb-b95b1c1ee025">Verify that the sequence of values corresponding to the “DataChoice” starts with a character string matching the name of one item of the choice descriptor.</p>
005743_​3b48707a-46b3-39ca-­de01-673ce695653bConformance class /conf/​binary-encodi­ng-rules has no corresponding Conformance test -
<requirement id="_3b48707a-46b3-39ca-de01-673ce695653b" model="ogc" type="conformanceclass">
-<title>Binary Encoding Rules</title> <identifier>/conf/binary-encoding-rules</identifier> <inherit>/conf/general-encoding-rules</inherit> <classification> <tag>Target Type</tag> <value>Encoded Values Instance</value> </classification> <classification> <tag>target</tag> <value>/req/binary-encoding-rules</value> </classification>
-
-</requirement>
005760_​e9efe42b-2464-8e2e-­89d1-24f2683c94d6Conformance test /conf/​binary-encodi­ng-rules/​abnf-syntax­-valid has no corresponding Conformance class -
<requirement id="_e9efe42b-2464-8e2e-89d1-24f2683c94d6" model="ogc" type="abstracttest">
-<title>Compliance with ABNF grammar</title> <identifier>/conf/binary-encoding-rules/abnf-syntax-valid</identifier> <classification> <tag>target</tag> <value>/req/binary-encoding-rules/abnf-syntax-valid</value> </classification>
-
-
-<description> <example id="_abb3a3b5-1b78-876f-b968-a75259cbf833"> <p id="_efca0ce5-e285-4295-b505-3c7d9b54a3b9">Verify that the binary encoded data block is correct with respect to the ABNF grammar of the particular dataset (The complete ABNF grammar of the dataset should be dynamically constructed from the ABNF snippets provided in the specification).</p>
005774_​21c9feea-e955-f828-­4647-8bef11f3a8b6Conformance test /conf/​binary-encodi­ng-rules/​type-encodi­ng-valid has no corresponding Conformance class -
<requirement id="_21c9feea-e955-f828-4647-8bef11f3a8b6" model="ogc" type="abstracttest">
-<title>Data types are encoded as specified in this standard</title> <identifier>/conf/binary-encoding-rules/type-encoding-valid</identifier> <classification> <tag>target</tag> <value>/req/binary-encoding-rules/type-encoding-valid</value> </classification>
-
-
-<description> <example id="_00b19140-d2f6-bba8-dd81-caedaf0de1f6"> <p id="_a24b30d2-c9b4-eec6-a5f7-5b1dfc356e75">Verify that valid and realistic scalar values are obtained when the binary data block is parsed by extracting the number of bits specified in the table and decoding the resulting bytes in the order specified by the “byteOrder” attribute. When the encoded data and the encoding parameters are not consistent, abberant values (such as -65502 for a temperature field, etc…) are usually obtained, which can be easily detected.</p>
005788_​62985ee3-a525-0e83-­7ea9-1e2b791daba7Conformance test /conf/​binary-encodi­ng-rules/​base64-tran­slation-applied has no corresponding Conformance class -
<requirement id="_62985ee3-a525-0e83-7ea9-1e2b791daba7" model="ogc" type="abstracttest">
-<title>Base64 encoding is implemented as defined by IETF</title> <identifier>/conf/binary-encoding-rules/base64-translation-applied</identifier> <classification> <tag>target</tag> <value>/req/binary-encoding-rules/base64-translation-applied</value> </classification>
-
-
-<description> <example id="_0ddc7ba7-ee3e-356b-112d-cf56741a0604"> <ul id="_362e2967-5f4a-4991-ba1f-06c25ea0e163"> <li> <p id="_b42ae5f9-12d7-da28-7dd8-c93df3d3d207">Verify that only characters allowed by base64 encoding are used in the encoded data content.</p>
005806_​b7b58a36-dcf8-be23-­b04e-d873c4be83c3Conformance test /conf/​binary-encodi­ng-rules/​optional-fi­eld-marker-present has no corresponding Conformance class -
<requirement id="_b7b58a36-dcf8-be23-b04e-d873c4be83c3" model="ogc" type="abstracttest">
-<title>Special flags are inserted before optional component values</title> <identifier>/conf/binary-encoding-rules/optional-field-marker-present</identifier> <classification> <tag>target</tag> <value>/req/binary-encoding-rules/optional-field-marker-present</value> </classification>
-
-
-<description> <example id="_4387bb95-ba8d-932c-61a8-d2b9f064162f"> <ul id="_c31ffe69-7cb6-8932-46bd-84b64467e6d9"> <li> <p id="_33cca6ed-7701-0d97-673c-21bcaa1131a0">Verify that any optional field is preceded by the a 1-byte ASCII character with value ‘Y’ or ‘N’.</p>
005824_​5bfaf0c3-a4ed-b179-­95ee-dd9171ca2a8cConformance test /conf/​binary-encodi­ng-rules/​choice-sele­ction-marker-valid has no corresponding Conformance class -
<requirement id="_5bfaf0c3-a4ed-b179-95ee-dd9171ca2a8c" model="ogc" type="abstracttest">
-<title>The name of a selected choice item is inserted in the stream</title> <identifier>/conf/binary-encoding-rules/choice-selection-marker-valid</identifier> <classification> <tag>target</tag> <value>/req/binary-encoding-rules/choice-selection-marker-valid</value> </classification>
-
-
-<description> <example id="_65547ce1-3fbd-be45-2899-7a754002365c"> <ul id="_1fe4db90-440e-b343-20f3-01fe83b94bd3"> <li> <p id="_3fde4108-4f6a-4b7c-669c-d2e307c702c4">Verify that the sequence of bytes corresponding to the “DataChoice” starts with a byte value that is greater or equal to 0 and less than the total number of items defined in the choice descriptor.</p>
-

Document Attributes

- - - - -
LineIDMessageContext
--draft is not an allowed status for standard
-

Metanorma XML Syntax

- - - - - - - - - - - - -
LineIDMessageContext
XML Line 000005:218character content of element "on" invalid; must be a string matching the regular expression "([\+\-]?​\d{4})((-?​)((0[1-9]​|1[0-2]​)((-?)([12]​\d|0[1-9]​|3[01]))?​|W([0-4]​\d|5[0-2])(-?​[1-7])?​|(00[1-9]|0[1-9]​\d|[12]​\d{2}|3([0-5]​\d|6[1-6]​))))?"
XML Line 000005:264character content of element "on" invalid; must be a string matching the regular expression "([\+\-]?​\d{4})((-?​)((0[1-9]​|1[0-2]​)((-?)([12]​\d|0[1-9]​|3[01]))?​|W([0-4]​\d|5[0-2])(-?​[1-7])?​|(00[1-9]|0[1-9]​\d|[12]​\d{2}|3([0-5]​\d|6[1-6]​))))?"
XML Line 000005:312character content of element "on" invalid; must be a string matching the regular expression "([\+\-]?​\d{4})((-?​)((0[1-9]​|1[0-2]​)((-?)([12]​\d|0[1-9]​|3[01]))?​|W([0-4]​\d|5[0-2])(-?​[1-7])?​|(00[1-9]|0[1-9]​\d|[12]​\d{2}|3([0-5]​\d|6[1-6]​))))?"
XML Line 000079:60element "clause" not allowed here; expected the element end-tag or element "submitters"
XML Line 000096:89element "clause" not allowed here; expected the element end-tag or element "submitters"
XML Line 000220:107IDREF "ISO19156" without matching ID
XML Line 000232:107IDREF "ISO19156" without matching ID
XML Line 000243:107IDREF "ISO19143" without matching ID
XML Line 000341:15element "definitions" incomplete; missing required element "dl"
- diff --git a/swecommon/standard/24-014.html b/swecommon/standard/24-014.html deleted file mode 100644 index 57569edb..00000000 --- a/swecommon/standard/24-014.html +++ /dev/null @@ -1,4676 +0,0 @@ - - -OGC SWE Common Data Model Encoding Standard - - - - - - - - - - - - - - - - -
-

Draft

-
- -
-

OGC Standard

-
- - - -
- -
- - -
-
- -
- -
- OGC SWE Common Data Model Encoding Standard - -
-
- - - - - -
- - - - - - - Alexandre Robin Editor - - -
- - - -
- - Version: 3.0.0
- - -
- -
- -
- -
-
- OGC Standard -
- -
-

Draft

-
-
- -
- -
- - - -
- - - - - - -
Document number:24-014
Document type:OGC Standard
Document subtype:Implementation
Document stage:Draft
Document language:English
-
- -
- - -
-
-
-

-
- -

License Agreement

- -

Use of this document is subject to the license agreement at https://www.ogc.org/license

-
-
- - -
- -
-

Suggested additions, changes and comments on this document are welcome and encouraged. Such suggestions may be submitted using the online change request form on OGC web site: http://ogc.standardstracker.org/

-
-
- - -
- - - - -
-

- - - - - - -


I.  Abstract

The primary focus of the SWE Common Data Model is to define and package data in a self-describing and semantically enabled way. The main objective is to achieve interoperability, first at the syntactic level, and later at the semantic level (by using ontologies and probably semantic mediation) so that (sensor) data can be better understood by machines, processed automatically in complex workflows and easily shared between intelligent nodes.

This standard is one of several implementation standards produced under OGC’s Connected Systems activity, and is a revision of content that was previously developed in the context of the Sensor Web Enablement initiative. These common data models are intended to be used in various OGC standards, and in particular, SensorML and OGC API — Connected Systems.

II.  Keywords

The following are keywords to be used by search engines and document catalogues.

ogcdoc, OGC document, html, SWE, sensor, sensorweb, connected systems, json, encoding, observation, command, tasking, property


III.  Preface

The OGC SWE Common Data Model Encoding Standard is the result of worked done by the Connected Systems Working Group of the OGC, with the aim of modernizing the Sensor Wen Enablement (SWE) suite of Standards.

To increase the brevity and readability of this Standard, many OGC document titles are shortened and/or abbreviated. Therefore, in the context of this document, the following phrases are defined:

“this Standard” shall be interpreted as equivalent to “OGC SWE Common Data Model Encoding Standard”. -“SensorML” or “SensorML Standard” shall be interpreted as equivalent to “OGC Sensor Modeling Language Encoding Standard”

IV.  Security considerations

No security considerations have been made for this Standard.

V.  Submitting Organizations

The following organizations submitted this Document to the Open Geospatial Consortium (OGC):

  • GeoRobotix, Inc.
  • -
  • Botts Innovative Research, Inc.
  • -
  • Cesium GS, Inc.
  • -
  • 52° North Initiative for Geospatial Open Source Software GmbH
  • -
  • Pelagis Data Solutions
  • -
  • National Geospatial-Intelligence Agency (NGA)

VI.  Submitters

All questions regarding this submission should be directed to the editor or the submitters:

NameAffiliation
Alex Robin (Editor)GeoRobotix, Inc.
Christian Autermann52° North Initiative
Chuck HeazelHeazeltech
Mike BottsBotts Innovative Research, Inc.

Additional contributors to this Standard include the following:

NameAffiliation
Arne Broering52° North Initiative
Barry ReffUS DHS
Ingo SimonisiGSI
Johannes EchterhoffiGSI
John HerringOracle USA
Luis BermudezSURA
Nick GarayBotts Innovative Research, Inc.
Peter TaylorCSIRO

VII.  Foreword

This document deprecates version 2.0 of the OGC® SWE Common Data Model Encoding Standard (OGC 08-094r2).

The following changes have been made:

  • Addition of the JSON encodings and schemas

    -
  • -
  • Addition of the Geometry data component (modeled on OGC simple feature geometries)

    -
  • -
  • Deprecation of the XML encodings

    -
  • -
  • Technical revision and improved explanations in various clauses

    -
  • -

This release is not fully backward compatible with version 2.0 even though changes were kept to a minimum.

1.  Scope

This standard defines low level data models for exchanging sensor related data between nodes of the OGC® Connected Systems framework (previously Sensor Web Enablement (SWE) framework). These models allow applications and/or servers to structure, encode and transmit sensor datasets in a self describing and semantically enabled way.

More precisely, the SWE Common Data Model is used to define the representation, nature, structure and encoding of sensor related data. These four pieces of information, essential for fully describing a data stream, are further defined in section 6.

The SWE Common Data Model is intended to be used for describing static data (files) as well as dynamically generated datasets (on the fly processing), data subsets, process and web service inputs and outputs, and real time streaming data and commands. All categories of sensor observations are in scope ranging from simple in-situ temperature data to satellite imagery and full motion video.

This standard defines JSON encodings for the dataset/datastream description, while the data itself can be encoded in JSON, text or binary form. This standard is used by other existing OGC standards such as the Sensor Model Language (SensorML) and OGC API — Connected Systems. One goal of the SWE Common Data Model is to maintain the functionality and consistency between these related standards.

2.  Conformance

This standard has been written to be compliant with the OGC Specification Model – A Standard for Modular Specification (OGC 08-131r3). Extensions of this standard shall themselves be conformant to the OGC Specification Model.

Conformance with this specification shall be checked using all the relevant tests specified in Annex A. The framework, concepts, and methodology for testing, and the criteria to be achieved to claim conformance are specified in ISO 19105: Geographic information — Conformance and Testing. In order to conform to this OGC™ encoding standard, a standardization target shall implement the core conformance class, and choose to implement any one of the other conformance classes.

Additionally, it is highly recommended that JSON based implementations of the conceptual models do implement requirement classes from clause 8 and clause 9 of this standard, respectively, and pass the corresponding conformance classes instead of defining new encodings.

TODO

This standard defines XXXX.

Requirements for N standardization target types are considered:

  • AAAA

    -
  • -
  • BBBB

    -
  • -

Conformance with this standard shall be checked using all the relevant tests specified in Annex A (normative) of this document. The framework, concepts, and methodology for testing, and the criteria to be achieved to claim conformance are specified in the OGC Compliance Testing Policies and Procedures and the OGC Compliance Testing web site.

In order to conform to this OGC® interface standard, a software implementation shall choose to implement:

  • Any one of the conformance levels specified in Annex A (normative).

    -
  • -
  • Any one of the Distributed Computing Platform profiles specified in Annexes TBD through TBD (normative).

    -
  • -

All requirements-classes and conformance-classes described in this document are owned by the standard(s) identified.

3.  Normative references

-

The following documents are referred to in the text in such a way that some or all of their content constitutes requirements of this document. For dated references, only the edition cited applies. For undated references, the latest edition of the referenced document (including any amendments) applies.

- - - - -

Policy SWG: OGC 08-131r3, The Specification Model — Standard for Modular specifications. Open Geospatial Consortium (2009).

-

John Herring: OGC 06-103r4, OpenGIS Implementation Specification for Geographic information — Simple feature access — Part 1: Common architecture. Open Geospatial Consortium (2011). http://www.opengis.net/doc/is/sfa/1.2.1.

-

Linda van den Brink, Clemens Portele, Panagiotis (Peter) A. Vretanos: OGC 10-100r3, Geography Markup Language (GML) simple features profile (with Corrigendum). Open Geospatial Consortium (2011).

-

ISO: ISO 8601:2019, Date and time — Representations for information interchange — Part 1: Basic rules. International Organization for Standardization, Geneva (2019). .. ISO (2019).

-

ISO: ISO 8601:2019, Date and time — Representations for information interchange — Part 2: Extensions. International Organization for Standardization, Geneva (2019). .. ISO (2019).

-

ISO/IEC: ISO/IEC 11404:2007, Information technology. International Organization for Standardization, International Electrotechnical Commission, Geneva (2007). https://www.iso.org/standard/39479.html.

-

ISO: ISO 19101-1:2014, Geographic information. International Organization for Standardization, Geneva (2014). https://www.iso.org/standard/59164.html.

-

ISO: ISO 19103:2005, Conceptual Schema Language. ISO (2005).

-

ISO: ISO 19107:2003, Spatial Schema. ISO (2003).

-

ISO: ISO 19108:2002, Geographic information. International Organization for Standardization, Geneva (2002). https://www.iso.org/standard/26013.html.

-

ISO: ISO 19111:2007, Spatial Referencing by Coordinates. ISO (2007).

-

Unified Code for Units of Measure (UCUM), Version 2.1, November 2017, https://ucum.org/ucum

-

Unicode Technical Std #18, Unicode Regular Expressions, Version 13, Aug. 2009

-

The Unicode Standard, Version 5.2, October 2009

- -

T. Bray (ed.): IETF RFC 8259, The JavaScript Object Notation (JSON) Data Interchange Format. RFC Publisher (2017). https://www.rfc-editor.org/info/rfc8259.

-

H. Butler, M. Daly, A. Doyle, S. Gillies, S. Hagen, T. Schaub: IETF RFC 7946, The GeoJSON Format. RFC Publisher (2016). https://www.rfc-editor.org/info/rfc7946.

-

M. Nottingham: IETF RFC 8288, Web Linking. RFC Publisher (2017). https://www.rfc-editor.org/info/rfc8288.

-

JSON Schema Validation: A Vocabulary for Structural Validation of JSON, Version 2020-12, https://json-schema.org/draft/2020-12/json-schema-validation.html

-

N. Freed, N. Borenstein: IETF RFC 2045, Multipurpose Internet Mail Extensions (MIME) Part One: Format of Internet Message Bodies. RFC Publisher (1996). https://www.rfc-editor.org/info/rfc2045.

-

P. Overell: IETF RFC 5234, Augmented BNF for Syntax Specifications: ABNF. RFC Publisher (2008). https://www.rfc-editor.org/info/rfc5234.

-

IEEE: IEEE 754-2008, IEEE Standard for Floating-Point Arithmetic. Institute of Electrical and Electronics Engineers (2013). https://ieeexplore.ieee.org/document/4610935.

-

4.  Terms and definitions

-

This document uses the terms defined in OGC Policy Directive 49, which is based on the ISO/IEC Directives, Part 2, Rules for the structure and drafting of International Standards. In particular, the word “shall” (not “must”) is the verb form used to indicate a requirement to be strictly followed to conform to this document and OGC documents do not use the equivalent phrases in the ISO/IEC Directives, Part 2.

-

This document also uses terms defined in the OGC Standard for Modular specifications (OGC 08-131r3), also known as the ‘ModSpec’. The definitions of terms such as standard, specification, requirement, and conformance test are provided in the ModSpec.

-

For the purposes of this document, the following additional terms and definitions apply.

- -

This document uses the terms defined in Sub-clause 5.3 of [OGC06-121r9], which is based on the ISO/IEC Directives, Part 2, Rules for the structure and drafting of International Standards. In particular, the word “shall” (not “must”) is the verb form used to indicate a requirement to be strictly followed to conform to this standard.

- -

For the purposes of this document, the following additional terms and definitions apply.

- -

TODO

- -

4.1. Feature

-

Abstraction of real-world phenomena

- - -

[SOURCE: ISO-19101, definition 4.11]

- -

4.2. Observation

-

Act of observing a property

- - -

[SOURCE: ISO-19156, definition 4.10]

- -

4.3. Observation Procedure

-

Method, algorithm or instrument, or system of these which may be used in making an observation

Note: In the context of the sensor web, an observation procedure is often composed of one or more sensors that transform a real world phenomenon into digital information, plus additional processing steps.

- - - - -

[SOURCE: ISO-19156, definition 4.11]

- -

4.4. Property

-

Facet or attribute of an object referenced by a name -Example : Abby’s car has the colour red, where “colour red” is a property of the car instance

- - -

[SOURCE: ISO-19143]

- -

4.5. Sensor

-

Type of observation procedure that provides the estimated value of an observed property at its output -Note: A sensor uses a combination of physical, chemical or biological means in order to estimate the underlying observed property. At the end of the measuring chain electronic devices often produce signals to be processed

- - -

4.6. Sensor Network

-

A collection of sensors and processing nodes, in which information on properties observed by the sensors may be transferred and processed -Note: A particular type of a sensor network is an ad hoc sensor network.

- - -

4.7. Sensor Data

-

List of digital values produced by a sensor that represents estimated values of one or more observed properties of one or more features -Note: Sensor data is usually available in the form of data streams or computer files.

- - - -

List of digital values produced by a sensor that contains auxiliary information that is not directly related to the value of observed properties -Example: sensor status, quality of measure, quality of service, etc… When such data is measured, it is sometimes considered sensor data as well.

- - -

4.9. Data Component

-

Element of sensor data definition corresponding to an atomic or aggregate data type -Note: A data component is a part of the overall dataset definition. The dataset structure can then be seen as a hierarchical tree of data components.

- -

6.  Conventions

6.1.  Identifiers

- -

The normative provisions in this standard are denoted by the URI

- -

http://www.opengis.net/spec/SWE/3.0

- -

All requirements and conformance tests that appear in this document are denoted by partial URIs which are relative to this base.

-

6.2.  Abbreviated terms

- -

In this document the following abbreviations and acronyms are used or introduced:

- -
  • CRS: Coordinate Reference System

    -
  • -
  • CSML: Climate Science Modeling Language

    -
  • -
  • GPS: Global Positioning System

    -
  • -
  • ISO International Organization for Standardization

    -
  • -
  • MISB Motion Imagery Standards Board

    -
  • -
  • OGC Open Geospatial Consortium

    -
  • -
  • SAS Sensor Alert Service

    -
  • -
  • SensorML Sensor Model Language

    -
  • -
  • SI Système International (International System of Units)

    -
  • -
  • SOS Sensor Observation Service

    -
  • -
  • SPS Sensor Planning Service

    -
  • -
  • SWE Sensor Web Enablement

    -
  • -
  • TAI Temps Atomique International (International Atomic Time)

    -
  • -
  • UML Unified Modeling Language

    -
  • -
  • UTC Coordinated Universal Time

    -
  • -
  • XML eXtended Markup Language

    -
  • -
  • 1D One Dimensional

    -
  • -
  • 2D Two Dimensional

    -
  • -
  • 3D Three Dimensional

    -
  • -
-

6.3.  UML Notation

- -

The diagrams that appear in this standard are presented using the Unified Modeling Language (UML) static structure diagram. The UML notations used in this standard are described in the diagram below.

- -

Figure 1

-

7.  Requirements Class: Core Concepts (normative core)

Requirements class 1: Core Concepts

Identifier/req/core
Target typeDerived Models and Software Implementations
Conformance classConformance class A.1: /conf/core

7.1.  Introduction

- -

The generic SWE Common data model defined by this standard aims at providing verbose information to robustly describe sensor related datasets. We define Sensor Data as data resulting from the observation of properties of virtual or real world objects (or features) by any type of Observation Procedure (See the Observation and Measurements specification OGC 07-022r1 for a more complete description of the observation model used in SWE).

- -

Sensor related datasets however are not limited to sensor observation values, but can also include auxiliary information such as status or ancillary data. In the following sections, we will use the term ‘property’ in a broader sense, which does not necessarily imply “property measured by a sensor”.

- -

A dataset is composed of Data Components whose values need to be put into context in order to be fully understood and interpreted, by either humans or machines. The SWE Common Data Model provides several pieces of information that are necessary to achieve this goal. More precisely, the SWE Common Data Model covers the following aspects of datasets description:

- -
  • Representation

    -
  • -
  • Nature of data and semantics (by using identifiers pointing to external semantics)

    -
  • -
  • Quality

    -
  • -
  • Structure

    -
  • -
  • Encoding

    -
  • -
- -

This requirement class constitutes the core of this standard. The standardization target types of this core are all models or software implementations seeking compliance with this standard.

- -

Requirement 1

Identifier/req/core/core-concepts-used
Statement

A derived model or software implementation shall correctly implement the concepts defined in the core of this standard.

-

7.2.  Data Representation

- -

Data representation deals with how property values are represented and stored digitally. Each component (or field) in a dataset carries a value that represents the state of a property. This representation will vary depending on the nature of the method used to capture the data and/or the target usage. For instance, a fluid temperature can be represented as a decimal number expressed in degrees Celsius (i.e. 25.4 °C), or as a categorical value taken from a list of possible choices (such as “freezing, cold, normal, warm, hot”).

- -

The following types of representations have been identified: Boolean, Categorical, Continuous Numerical, Discrete Countable and Textual. The paragraphs below explain basic features of each of these representation types.

- -

7.2.1.  Boolean

- -

A Boolean representation of a property can take only two values that should be “true/false” or “yes/no”. In a sense, this type of representation is a particular case of the categorical representation with only two predefined options.

- -

Examples

- -

Motion detectors output can be represented by a boolean value -– TRUE if there is motion in the room, FALSE otherwise.

- -

On/Off status of a measurement system can be represented by a boolean value -– TRUE if the system in on, FALSE if the system is off.

-
- -

Requirement 2

Identifier/req/core/boolean-rep-valid
Statement

A boolean representation shall at least consist of a boolean value.

- -

The “Boolean” class described in Clause 8.2.4 is used to define a data component with a Boolean representation.

-
- -

7.2.2.  Categorical

- -

A categorical representation is a type of discrete representation of a property that only allows picking a value from a well defined list of possibilities (i.e. categories). This list is called a code space in this standard, following ISO 19103 terminology.

- -

The different possible values constituting a code space are usually listed explicitly in an out-of-band dictionary or ontology. This is necessary because each value should be defined formally and unambiguously, so that it can be interpreted correctly.

- -

Examples

- -

Biological or chemical species data is usually represented by a categorical data component that can leverage on existing controlled vocabulary.

- -

A camera mode can be represented by a categorical value: AUTO_FOCUS, MANUAL_FOCUS, etc…​

-
- -

Requirement 3

Identifier/req/core/categorical-rep-valid
Statement

A categorical representation shall at least consist of a category identifier and information describing the value space of this identifier.

- -

The “Category” class described in Clause 8.2.6 is used to define a data component with a categorical representation.

-
- -

7.2.3.  Numerical (continuous)

- -

Perhaps the most used representation of a property value, especially in the science and technical communities, is the numerical one, as the majority of properties measured by sensors can be represented by numbers.

- -

Numerical representation is often used for continuous values and, in this case, the representation consists of a decimal (often floating point) number associated to a scale or unit of measure. The unit specification is mandatory even for quantities such as ratios that have no physical unit (in this case a scale factor is provided such as 1, 1/100 for percents, 1/1000 for per thousands, etc.).

- -

Examples

- -

Temperature measurements can be represented by a number associated to a unit such as degrees Celsius or Fahrenheit: 23.51°C, 94°F

- -

A velocity vector is composed of several values (usually 2 or 3) associated to a unit of speed: [1.0 2.0 3.0] m/s.

-
- -

Requirement 4

Identifier/req/core/numerical-rep-valid
Statement

A continuous numerical representation shall at least consist of a decimal number and the scale (or unit) used to express this number.

- -

The “Quantity” class described in Clause 8.2.8 is used to define a data component with a decimal representation and a unit of measure.

-
- -

7.2.4.  Countable (discrete)

- -

Discrete countable properties are also of interest and are most accurately captured with a numerical integer representation. They do not require a unit since the unit is always the unit of count (i.e. the person if we are counting persons, the pixel if we are counting pixels, etc). Note that continuous properties can also be represented as integers with certain combinations of scale and precision. This case should not be confused with the countable properties described here.

- -

Examples

- -

Array indices and sizes are countable properties with no unit.

- -

There are numerous other countable properties such as number of persons, number of bytes, number of frames, etc. for which the unit is obvious from the definition of the property itself.

-
- -

A discrete countable representation should not be confused with a continuous numerical representation whose scale and precision allow encoding the property value as an integer.

- -

Requirement 5

Identifier/req/core/countable-rep-valid
Statement

A countable representation shall at least consist of an integer number.

- -

The “Count” class described in Clause 8.2.7 is used to define a data component with an integer representation and no unit of measure.

-
- -

7.2.5.  Textual

- -

A textual representation is useful for providing human readable data, expressed in natural language, as well as various alpha numeric tokens that cannot be assigned to well-defined categories.

- -

Examples

- -

Comments or notes written by humans (ex: data annotations, quality assessments).

- -

Machine generated messages for which there is no taxonomy (ex: automatic alert messages).

- -

Alphanumeric identifier schemes leading to a large number of possibilities that cannot be explicitly enumerated (ex: UUID, ISBN code, URN).

-
- -

Requirement 6

Identifier/req/core/textual-rep-valid
Statement

A textual representation shall at least consist of a character string.

- -

The “Text” class described in Clause 8.2.5 is used to define a data component with a textual representation.

-
- -

7.2.6.  Constraints

- -

Constraints can be added to some representation types to further restrict the set of possible values allowed for a given property:

- -
  • A boolean representation cannot be restricted further since it is already limited to only two possibilities.

    -
  • -
  • A numerical representation can be constrained by a list of allowed values and/or bounded or unbounded intervals. A decimal representation can also be constrained by the number of significant digits after the decimal point.

    -
  • -
  • A categorical representation can be constrained by a list of possible choices, which should be a subset of the list of possibilities defined by the code space.

    -
  • -
  • A textual representation can be constrained by a pattern expressed in a well known language such as regular expression syntax.

    -
  • -
- -

These constraints apply only to the value of the data component to which they are associated. They shall not be used to express constraints on other data components or on any other information than the value.

- -

Examples

- -

A decimal representation of an angular property such as latitude can be constrained to the [-90° 90°] interval.

- -

A temperature reading produced by a sensor can be constrained to the [-50°C +250°C] range.

-
-
-

7.3.  Nature of Data

- -

We define “Nature of data” as the information needed to understand what property the value represents. It is thus connected to semantics and the semantic details are often provided by external sources such as dictionaries, taxonomies or ontologies. Note that it is independent of the type of representation used and it does not include information about how the data was actually measured or acquired. This lineage information should be described by other means as explained in Clause 7.4.3.

- -

7.3.1.  Human readable information

- -

The first means by which nature of data can be communicated is through human readable text. The data component’s description, which is present in all data types defined in this specification, can hold any length of text for this purpose. The data component’s label is used to carry short human readable information (i.e. a short name); this is useful to allow data consumers to quickly identify the represented property.

- -

It is not recommended to use the concepts of “description” and “label” in a way that they contain robust semantic information (i.e. that machines can rely upon). The content of such fields is intended to be interpretable solely by humans.

-
- -

7.3.2.  Robust semantics

- -

All SWE Common data types allow for associating each data component in a dataset with the definition of the Property that it represents.

- -

Requirement 7

Identifier/req/core/semantics-defined
Statement

All data values shall be associated with a clear definition of the property that the value represents.

- -

It is recommended that a model uses references to out-of-band dictionaries rather than inline information because semantics are supposed to be shared by multiple datasets. Using references also helps by providing a framework that is independent from the actual semantic technology used.

- -

The SWE Common UML models and XML schemas desribed in this standard can be used in combination with any semantic web technology. It is thus possible to connect a SWE dataset description to an existing taxonomy provided the external register exposes a unique identifier for each entry.

- -

These semantic references point to out-of-band semantic information that can be encoded in various languages, such as the Ontology Web Language (OWL) or GML dictionary.

- -

Requirement 8

Identifier/req/core/semantics-resolvable
Statement

If semantic information is provided by referencing out-of-band data, the locators or identifiers used to point to this information shall be resolvable by some well-defined method.

-
- -

7.3.3.  Time, space and projected quantities

- -

Temporal, spatial and other projected quantities need to be further defined by specifying the reference frame and axis with respect to which the quantity is expressed. In SWE Common, any simple component type can be associated to a particular axis of a given reference frame.

- -

Examples

- -

Satellite position data can be defined as a vector of 3 components, expressed in the J2000 ECI Cartesian frame, the 1st component being associated to the X axis, the 2nd to the Y axis and the 3rd to the Z axis.

- -

Angular velocity data from an Inertial Measurement Unit can be defined as a vector of 3 components, expressed in the plane reference frame (for instance ENU defined by local East, North, Up directions), the Euler components being mapped to X, Y, Z respectively.

- -

Relative time data can be given with respect to an arbitrary epoch itself positioned in a well defined reference frame such as TAI (from the French “Temps Atomique International” = International Atomic Time).

-
- -

Requirement 9

Identifier/req/core/temporal-frame-defined
Statement

A temporal quantity shall be expressed with respect to a well defined temporal reference frame and this frame shall be specified.

- -

Requirement 10

Identifier/req/core/spatial-frame-defined
Statement

A spatial quantity shall be expressed with respect to the axes of a well defined spatial reference frame and this frame shall be specified.

- -

The “Time” class described in Clause 8.2.9 is designed for carrying a temporal reference frame or a time of reference in the case of relative time data.

- -

The “Vector” class detailed in Clause 8.3.2 is a special type of record used to assign a reference frame to all its child-components.

- -

The “Matrix” class defined in Clause 8.5.2 allows the definition of higher order tensor quantities.

- -

This standard does not impose requirements on the type of reference frames that a standardization target shall support. Standards that are dependent on this specification can (and often should) however define a minimum set of reference frames that shall be supported by all implementations.

-
-

7.4.  Data Quality

- -

Quality information can be essential to the data consumer and the SWE Common Data Model provides simple and flexible ways to associate qualitative information with each component of a dataset.

- -

7.4.1.  Simple quality information

- -

Simple quality information can be associated with any scalar data component, in the form of another scalar or range value. The quality information defined here applies solely to the value of the associated data component (i.e. the measurement value) and, depending on its data type, quality can be represented by a numerical, categorical or textual value, or by a range of values.

- -

This quality information can be static, i.e. constant over the whole dataset, or dynamic and provided with the data itself. In this case, the quality value is in fact carried by another component of the dataset (and described in SWE Common as such).

- -

The exact type of quality information provided should be specified via semantic tagging just like with any other property in SWE Common.

- -

Examples

- -

Examples of quality measures are “absolute accuracy”, “relative accuracy”, “absolute precision”, “tolerance”, and “confidence level”.

- -

Quality related comments can also describe operating conditions, such as “sensor contained blockage and was removed” or “engineer on site, values may be affected”. This information can inform the user of potential inaccuracy in the data across certain periods.

-
-
- -

7.4.2.  Nil Values

- -

The concept of NIL value is used to indicate that the actual value of a property cannot be given in the data stream, and that a special code (i.e. reserved value) is used instead. It is thus a kind of quality information. The reason for which the value is not included is essential for a good interpretation of the data, so each reserved value is associated to a well-defined reason. In that sense, a NIL value definition is essentially a mapping between a reserved value and a reason.

- -

Each component of a dataset can define one or several NIL values corresponding to one or more reasons.

- -

Example

- -

In low level satellite imagery with, for instance, 8-bits per channel, the imagery metadata often defines: -- A reserved value to indicate that a pixel value was “Below Detection Limit” usually set to ‘0’ -- A reserved value to indicate that a pixel value was “Above Detection Limit” usually set to ‘255’

-
- -

Requirement 11

Identifier/req/core/nil-reasons-defined
Statement

A model of a NIL value shall always include a mapping between the selected reserved value and a well-defined reason.

-
- -

7.4.3.  Full lineage and traceability

- -

Full lineage and traceability is not in the scope of this specification. It is fully addressed by the OGC® Sensor Model Language Standard, which allows robust definition of measurement chains, with detailed information about the processing that takes place at each stage of the chain. This means that complex lineage guarantying full traceability can be recorded in a SensorML process chain, separately from the data itself.

- -

Datasets can be associated to lineage information described using the Sensor Model Language by using a metadata wrapper such as the “Observation” object defined in the OGC® Observations and Measurements Standard (O&M). In this standard, the “procedure” property of the “Observation” class allows attaching detailed information about the measurement procedure, that is to say a description of how the data was obtained (i.e. lineage), to the data itself.

-
-

7.5.  Data Structure

- -

Data structure defines how individual pieces of data are grouped, ordered, repeated and interleaved to form a complete data stream. The SWE Common models are based on data structures commonly accepted in computer science and formalized in ISO 11404. -Classical aggregate datatypes are defined below:

- -
  • Record: consists of a list of fields, each of them being keyed by a field identifier and defining its own type that can be any scalar or aggregate structure.

    -
  • -
  • Array: consists of many elements of the same type, usually indexed by an integer. The element type can be any data structure including scalars and aggregates. The array size constitutes the upper bound of the index.

    -
  • -
  • Choice: consists of a list of alternatives, each of them being keyed by a tag value and having its own type. Only values for one alternative at a time are actually present in the data stream described by such a structure.

    -
  • -
- -

Requirement 12

Identifier/req/core/aggregates-model-valid
Statement

Aggregate data structures shall be implemented in a way that is consistent with definitions of ISO 11404.

- -

This standard also defines the concept of “data component” as any part of the structure of a dataset, aggregate or not. It is thus the superset of all the aggregate structures described above and of all scalar elements implementing the representations described in Clause 7.2.

- -

Example

- -

A dataset representing a time series of observations acquired by a mobile sensor can be encoded with various methods depending on the requirements:

- -
  • XML encoding can be used when data needs to be easily styled to other markup formats (such as HTML) or when precise error localization (in the case of an error in the stream) is needed.

    -
  • -
  • ASCII encoding can be used to achieve a good compromise between readability and size efficiency.

    -
  • -
  • Binary encoding can be used (eventually with embedded compression) when pure performance (i.e. size but also reading and writing throughput) is the main concern.

    -
  • -
-
- -

A data component can be both a data descriptor and a data container:

- -
  • A data component used as a data descriptor defines the structure, representation, semantics, quality, and other metadata of a data set but does not include the actual data values.

    -
  • -
  • A data component used as a data container equally defines the dataset but also includes the actual property values.

    -
  • -
-

7.6.  Data Encoding

- -

A key concept of the SWE Common Data Model is the ability to separate data values themselves from the description of the data structure, semantics and representation. This allows verbose metadata to be used in order to robustly define the content and meaning of a dataset while still being able to package the data values in very efficient manners.

- -

Data encoding methods define how the data is packed as blocks that can efficiently be transferred or stored using various protocols and formats. Different methods allow encoding the data as JSON, text (CSV like), binary and even compressed or encrypted formats in a way that is agnostic to a particular structure. This allows any of the encodings methods to be selected and used based on a particular requirement, such as performance, re-use of tools, alignment with existing standards and so on.

- -

Requirement 13

Identifier/req/core/encoding-method-valid
Statement

All encoding methods shall be applicable to any arbitrarily complex data structures as long as they are made of the data components described in Clause 7.5.

-

8.  UML Conceptual Models (normative)

This standard defines normative UML models with which derived encoding models as well as all future separate extensions should be compliant. The standardization target type for the UML requirements classes defined in this clause is thus a software implementation or an encoding model that directly implements the conceptual models defined in this standard.

8.1.  Package Dependencies

- -

The following packages are defined by the SWE Common Data Model:

- -
- -

Figure 2 — Internal Package Dependencies

- -

This standard also has dependencies on external packages defined by other standards, namely ISO 19103, ISO 19108 and ISO 19111, as show below:

- -
- -

Figure 3 — External Package Dependencies

-

8.2.  Requirements Class: Basic Types and Simple Components Packages

- -

Requirements class 2: Simple Components UML Package

Identifier/req/uml-simple-components
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.2: /conf/uml-simple-components
PrerequisiteRequirements class 1: /req/core
- -

Data components are the most essential part of the SWE Common Data Model. They are used to describe all types of data structures, whether they represent data stream contents, tasking messages, alert messages or process inputs/outputs.

- -

The “Simple Components” UML package contains classes modeling simple data components, that is to say scalar components and range components (i.e. value extents). These classes implement concepts defined in the core section of this standard, and are designed to collect information about nature, representation and quality of data. These include six scalar types – Boolean, Text, Category, Count, Quantity, and Time – as well as four range types – CategoryRange, CountRange, QuantityRange and TimeRange.

- -

The “Basic Types” UML package from which the “Simple Components” package is dependent is also included in this requirements class.

- -

As an overview, conceptual models of the six scalar component types are shown on the following UML class diagram:

- -
- -

Figure 4 — Scalar Data Components

- -

Classes representing the four range data components are shown on the diagram below:

- -
- -

Figure 5 — Range Data Components

- -

Details and requirements about each of these classes are given in the following sections.

- -

Requirement 14

Identifier/req/uml-simple-components/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Simple Components” and “Basic Types” UML packages.

- -

Several dependencies to ISO standards exist and are detailed below.

- -

Data types from several packages of the ISO 19103 standard are used directly which makes this requirement class dependent on it. These data types are “CharacterString”, “Boolean”, “Real”, “Integer”, “Date”, “Time”, “DateTime”, “ScopedName”, “UnitOfMeasure” and “UomTime”.

- -

Requirement 15

Identifier/req/uml-simple-components/iso19103-implemented
Statement

The encoding or software shall correctly implement all UML classes defined in ISO 19103 that are referenced directly or indirectly by this standard.

- -

The “TM_Position” data type from the “Temporal Reference System” package of the ISO 19108 standard is also used.

- -

Requirement 16

Identifier/req/uml-simple-components/iso19108-implemented
Statement

The encoding or software shall correctly implement all UML classes defined in ISO 19108 that are referenced directly or indirectly by this standard.

- -

The “SC_CRS” and “TM_Temporal_CRS” classifiers are referenced conceptually from ISO 19111 but their implementation is not required by this standard. Implementations are allowed to simply use a CRS identifier as a mean of recognizing predefined coordinate reference systems. The use of identifiers from the EPSG database is recommended in this case. However, when new CRS definitions need to be created (e.g. engineering CRS attached to sensors or platforms), the models defined in ISO 19111 shall be used.

- -

8.2.1.  Basic Data Types

- -

This requirement class also includes requirements for the “Basic Types” UML package. This package defines low level data types that are used as property types by classes defined in the other packages.

- -

Data types defined in this package relate to defining pairs of data types defined in ISO 19103 for use within classes describing value extents:

- -
- -

Figure 6 — Basic types for pairs of scalar types

-
- -

8.2.2.  Attributes shared by all data components

- -

All SWE Common data component classes carry standard attributes inherited (transitively) from the “AbstractDataComponent” and “AbstractSWEValue” classes (The “AbstractSWEValue” class is actually defined in the “Basic Types” package but is shown here for clarity). The class hierarchy is shown on the following UML diagram:

- -
- -

Figure 7 — AbstractDataComponent Class

- -

Extension Slot

- -

The “extension” attribute is used as a container for future extensions. It allows adding new extended properties to an existing class at the instance level.

- -

Name and Description

- -

The optional “name” and “description” attributes can be used to provide human readable information describing what property the component represents. The “name” is meant to hold a short descriptive name whereas “description” can carry any length of plain text. These two fields should not be used to specify robust semantic information (see Clause 7.3.2). Instead, the “definition” attribute described below should be used for that purpose.

- -

Identifier

- -

The optional “identifier” attribute allows assigning a unique identifier to the component, so that it can be referenced later on. It can be used, for example, when defining the unique identifier of a universal constant.

- -

Definition

- -

The “definition” attribute identifies the property (often an observed property in our context) that the data component represents by using a scoped name. It should map to a controlled term defined in an (web accessible) dictionary, registry or ontology. Such terms provide the formal textual definition agreed upon by one or more communities, eventually illustrated by pictures and diagrams as well as additional semantic information such as relationships to units and other concepts, ontological mappings, etc.

- -

Examples

- -

The definition may indicate that the value represents an atmospheric temperature using a URN such as “urn:ogc:def:property:OGC::SamplingTime” referencing the complete definition in a register.

- -

The definition may also be a URL linking to a concept defined in an ontology such as [http//www.opengis.net/def/OGC/0/SamplingTime]. -The label could be “Sampling Time”, which allows quick identification by human data consumers.

- -

The description could be “Time at which the observation was made as measured by the on-board clock” which adds contextual details.

-
- -

Flags

- -

The “optional” attribute is an optional flag indicating if the component value can be omitted in the data stream. It is only meaningful if the component is used as a schema descriptor (i.e. not for a component containing an inline value). It is ‘false’ by default.

- -

The “updatable” attribute is an optional flag indicating if the component value is fixed or can be updated. It is only applicable if the data component is used to define the input of a process (i.e. when used to define the input or parameter of a service, process or sensor, but not when used to define the content of a dataset).

- -

Examples

- -

The “updatable” flag can be used to identify what parameters of a system are changeable. The exact semantics depends on the context. For example:

- -
  • In SensorML process chains, the “updatable” flag is used to identify process parameters that can accept an incoming connection (and thus can get changed while the process is in execution).

    -
  • -
  • In a SensorML System it is used to indicate whether or not a system parameter is changeable, either by an operator (i.e. by turning a screw or inserting a jumper) or remotely by sending a command.

    -
  • -
  • In the Sensor Planning Service it is used to indicate if tasking parameters are changeable by the client (i.e. by using the Update operation) after a task has been submitted.

    -
  • -
-
-
- -

8.2.3.  Attributes shared by all simple data components

- -

As shown on Figures 4 and 5, classes modeling simple data components inherit attributes from the “AbstractSimpleComponent” class from which they are directly derived. This abstract class is shown again below:

- -
- -

Figure 8 — AbstractSimpleComponent Class

- -

The definition attribute inherited from the “AbstractDataComponent” class is mandatory on this class and thus on all its descendants.

- -

Requirement 17

Identifier/req/uml-simple-components/definition-present
Statement

The “definition” attribute shall be specified by all instances of concrete classes derived from “AbstractSimpleComponent”.

- -

Reference Frames and Axes

- -

It provides two attributes allowing the association of a data component to a reference frame and an axis and thus implements core concepts introduced in Clause 7.3.3. These attributes are used for a component which value is the projection of a property along a temporal or spatial axis.

- -

The “referenceFrame” attribute identifies the reference frame (as defined by the “SC_CRS” object) relative to which the coordinate value is given. The “axisID” attribute takes a string that uniquely identifies one of the reference frame’s axes along which the coordinate value is given.

- -

Requirement 18

Identifier/req/uml-simple-components/axis-valid
Statement

The value of the “axisID” attribute shall correspond to the “axisAbbrev” attribute of one of the coordinate system axes listed in the specified reference frame definition.

- -

The union of these two attributes thus uniquely identifies one axis of one given reference frame along which the value of the component is expressed. Note that even though the ISO 19111 model assigns units to CRS axes in addition to a direction, only the direction is used in this standard and the unit is defined by the data component itself. This allows expressing other quantities than the one predefined along the CRS’s axes such as velocity, acceleration or rotation.

- -

A component representing a projected quantity can be defined in isolation or can be contained within a “Vector” or ”Matrix” aggregate when it contributes to the specification of a multi-dimensional quantity (see Clauses 8.3.2 and 8.5.2). In this last case the reference frame definition is usually inherited from the parent “Vector” or ”Matrix” instance and is thus omitted from the scalar component itself. However, the “axisID” attribute still needs to be specified on “Vector” components.

- -

Requirement 19

Identifier/req/uml-simple-components/axis-defined
Statement

The “axisID” attribute shall be specified by all instances of concrete classes derived from “AbstractSimpleComponent” and representing a property projected along a spatial axis.

- -

Requirement 20

Identifier/req/uml-simple-components/ref-frame-defined
Statement

The “referenceFrame” attribute shall be specified by all instances of concrete classes derived from “AbstractSimpleComponent” and representing a property projected along a spatial or temporal axis, except if it is inherited from a parent aggregate (Vector or Matrix).

- -

Quality

- -

The optional “quality” attribute is used to provide simple quality information as discussed in Clause 7.4.1. It is of type “Quality” which is a union of several classes as defined in Clause 8.2.15. Its multiplicity is more than one which means that several quality measures can be given on for a single data component.

- -

Example

- -

Both precision and accuracy of the value associated to a data component can be specified concurrently (see http://en.wikipedia.org/wiki/Accuracy_and_precision for a good explanation of the difference between the two).

-
- -

Nil Values

- -

The optional “nilValues” attribute is used to provide a list (i.e. one or more) of NIL values as defined in Clause 7.4.2. The model of the “NilValues” class is detailed in Clause 8.2.16.

- -

Concrete sub-classes of “AbstractSimpleComponent” can also define a “constraint” attribute that allows further restriction of the possible values allowed by the corresponding representation. This implements concepts defined in Clause 7.2.6. These constraints always apply to the value of the property as represented by the corresponding data component whether this value is given inline (data container case) or out-of-band (data descriptor case).

- -

Constraints

- -

Requirement 21

Identifier/req/uml-simple-components/value-constraint-valid
Statement

The property value (formally the representation of the property value) attached to an instance of a class derived from “AbstractSimpleComponent” shall satisfy the constraints specified by this instance.

- -

All concrete sub-classes of “AbstractSimpleComponent” also define a “value” attribute. This attribute is not defined in this abstract class because it has a different primitive type in each concrete data component class (See following clauses).

- -

Requirement 22

Identifier/req/uml-simple-components/value-attribute-present
Statement

All concrete classes derived from the “AbstractSimpleComponent” class (directly or indirectly) shall define an optional “value” attribute and use it as defined by this standard.

- -

The “value” attribute is always optional on any simple data component in order to allow for both data descriptor and data container cases:

- -
  • When the data component is used as a data container, this attribute always carries the value of the associated property (formally the representation of the estimated or asserted value of the property). Quality information, nil values definitions and constraints thus apply to the value taken by this attribute.

    -
  • -
  • When the data component is used as a data descriptor, its actual value is provided somewhere else, often encoded as part of a larger data block. In this case, quality information, nil values definitions and constraints apply to the out-of-band value and not to the “value” attribute. Instead, the “value” attribute can then be used to specify a default value.

    -
  • -
- -

Whether the data component is used as a descriptor or a container depends on the context and should be explicitly stated by any standard that makes use of the SWE Common Data Model.

- -

All UML classes in this package that derive from “AbstractSimpleComponent” define a “value” attribute with the adequate primitive type and whose meaning is the one explained above.

-
- -

8.2.4.  Boolean Class

- -

The “Boolean” class is used to specify a scalar data component with a Boolean representation as defined in Clause 7.2.1. It derives from “AbstractSimpleComponent” and is shown below:

- -
- -

Figure 9 — Boolean Class

- -

The “value” attribute of this class is of the boolean primitive type.

NOTE:    The boolean primitive type is defined in ISO19103 and is not to be confused with the “Boolean” class defined in this standard. This clause is the only place in this standard where the ISO 19103 boolean data type is referenced. All other occurrences of the “Boolean” class in this standard refer to the class defined in this clause.

- - -
- -

8.2.5.  Text Class

- -

The “Text” class is used to specify a component with a textual representation as defined in Clause 7.2.5. It derives from “AbstractSimpleComponent” and is shown below:

- -
- -

Figure 10 — Text Class

- -

Constraints

- -

The “constraint” attribute allows further restricting the range of possible values by using the “AllowedTokens” class defined in Clause 8.2.17. This class allows the definition of the constraint by either enumerating the allowed tokens and/or by specifying a pattern that the value must match.

- -

Value

- -

The “value” attribute (or the corresponding value in out-of-band data) is a string that must match the constraint.

NOTE:    The “Text” component can be used to wrap a string representing complex content such as an expression in a programming language, xml or html content. This practice should however be used only for systems that don’t require high level of interoperability since the client must know how to interpret the content. Also care must be taken to properly escape such content before it is inserted in an XML document or in a SWE Common data stream.

- - -
- -

8.2.6.  Category Class

- -

The “Category” class is used to specify a scalar data component with a categorical representation as defined in Clause 7.2.2. It derives from “AbstractSimpleComponent” and is shown below:

- -
- -

Figure 11 — Category Class

- -

Code Space

- -

The “codeSpace” attribute is of type “Dictionary” and allows listing and defining the meaning of all possible values for this component. It is expected that instances of the “Dictionary” class will usually be referenced (rather than included inline) by implementations of this class since the code space definition is usually obtained from a controlled vocabulary maintained at a remote location. This type of implementation is the one chosen in the XML encodings defined by this standard.

- -

Constraints

- -

The “constraint” attribute allows further restricting the list of possible values by using the “AllowedTokens” class defined in Clause 8.2.17. This is usually done by specifying a limited list of possible values, which have to be extracted from the code space.

- -

Requirement 23

Identifier/req/uml-simple-components/category-constraint-valid
Statement

When an instance of the “Category” class specifies a code space, the list of allowed tokens provided by the “constraint” property of this instance shall be a subset of the values listed in this code space.

- -

It is also possible to use this class without a code space, even though it is not recommended as values allowed in the component would then not be formally defined. However, as the intent of this class is to always represent a value extracted from a set of possible options, a constraint shall be defined if no code space is specified.

- -

Requirement 24

Identifier/req/uml-simple-components/category-enum-defined
Statement

An instance of the “Category” class shall either specify a code space or an enumerated list of allowed tokens, or both.

- -

Value

- -

The “value” attribute (or the corresponding value in out-of-band data) is a string that must be one of the items of the code space and also match the constraint.

- -

Requirement 25

Identifier/req/uml-simple-components/category-value-valid
Statement

When an instance of the “Category” class specifies a code space, the value of the property represented by this instance shall be equal to one of the entries of the code space.

-
- -

8.2.7.  Count Class

- -

The “Count” class is used to specify a scalar data component with a discrete countable representation as defined in Clause 7.2.4. It derives from “AbstractSimpleComponent” and is shown below:

- -
- -

Figure 12 — Count Class

- -

Constraints

- -

The “constraint” attribute can be used to restrict the range of possible values to a list of inclusive intervals and/or single values using the “AllowedValues” class defined in Clause 8.2.18. Numbers used to define these constraints should be integers and expressed in the same scale as the count value itself. The “significantFigures” constraint allowed by the “AllowedValues” class is not applicable to the “Count” class.

- -

Value

- -

The “value” attribute (or the corresponding value in out-of-band data) is an integer that must be within one of the constraint intervals or exactly one of the enumerated values.

-
- -

8.2.8.  Quantity Class

- -

The “Quantity” class is used to specify a component with a continuous numerical representation as defined in Clause 7.2.3. It derives from “AbstractSimpleComponent” and is shown below:

- -
- -

Figure 13 — Quantity Class

- -

Unit of Measure (UoM)

- -

In addition to attributes inherited from the “AbstractSimpleComponent” class, this class provides a unit of measure declaration through the “uom” attribute. This unit is essential for the correct interpretation of data represented as decimal numbers and is thus mandatory. Quantities with no physical unit still have a scale (such as unity, percent, per thousands, etc.) that must be specified with this property.

- -

Constraints

- -

The “constraint” attribute is used to restrict the range of possible values to a list of inclusive intervals and/or single values using the “AllowedValues” class defined in Clause 8.2.18. Numbers used to define these constraints must be expressed in the same unit as the quantity value itself. Additionally, it is possible to constrain the number of significant digits that can be added after the decimal point.

- -

Value

- -

The “value” attribute (or the corresponding value in out-of-band data) is a real value that is within one of the constraint intervals or exactly one of the enumerated values, and most importantly is expressed in the unit specified.

-
- -

8.2.9.  Time Class

- -

The “Time” class is used to specify a component with a date-time representation and whose value is projected along the axis of a temporal reference frame. This class is also necessary to specify that a time value is expressed in a calendar system. This class derives from “AbstractSimpleComponent” and is shown below:

- -
- -

Figure 14 — Time Class

- -

Time is treated as a special type of continuous numerical quantity that can be either expressed as a scalar number with a temporal unit or a calendar date with or without a time of day. Consequently, this class has all properties of the “Quantity” class, plus some others that are specific to the treatment of time.

- -

Reference Frame

- -

As time is always expressed relative to a particular reference frame, the “referenceFrame” attribute inherited from the parent class “AbstractSimpleComponent” shall always be set on instances on this class unless the default ‘UTC’ is meant.

- -

Requirement 26

Identifier/req/uml-simple-components/time-ref-frame-defined
Statement

The “referenceFrame” attribute inherited from “AbstractSimple Component” shall always be set on instance of the “Time” class unless the UTC temporal reference system is used.

- -

Note that specifying the frame of reference is required even when using ISO notation because there can be ambiguities between several universal time references such as UTC, TAI, GPS, UT1, etc… Differences between these different time reference systems are indeed in the order of a few seconds (and increasing), that is to say not negligible in various situations.

- -

Example

- -

J2000 is a well known epoch in astronomy and is equal to:

- -
  • January 1, 2000, 11:59:27.816 in the TAI time reference system

    -
  • -
  • January 1, 2000, 11:58:55.816 in the UTC time reference system

    -
  • -
  • January 1, 2000, 11:59:08.816 in the GPS time reference system

    -
  • -
- -

These offsets are not always constant and depend on the irregular insertion of leap seconds in UTC.

-
- -

The “axisID” attribute inherited from the parent class does not need to be set since a time reference system always has a single dimension. However it can be set to ‘T’ for consistency with spatial axes.

- -

Reference Time

- -

The “referenceTime” attribute is used to specify a different time origin than the one sometimes implied by the “referenceFrame”. This is used to express a time relative to an arbitrary epoch (i.e. different from the origin of a well known reference frame). The new time origin specified by “referenceTime” shall be expressed with respect to the reference frame specified and is of type “DateTime”. This forces the definition of this origin as a calendar date/time combination.

- -

Requirement 27

Identifier/req/uml-simple-components/time-ref-time-valid
Statement

The value of the “referenceTime” attribute shall be expressed with respect to the system of reference indicated by the “referenceFrame” attribute.

- -

Example

- -

This class can be used to define a value expressed as a UNIX time (i.e. number of seconds elapsed since January 1, 1970, 00:00:00 GMT) by:

- -
  • Specifying that the reference frame is the UTC reference system

    -
  • -
  • Setting the reference time to January 1, 1970, 00:00:00 GMT.

    -
  • -
  • Setting the unit of measure to seconds

    -
  • -
- -

See definitions of some commonly accepted time standards at http://en.wikipedia.org/wiki/Time_standard or http://stjarnhimlen.se/comp/time.html.

-
- -

Local Frame

- -

The optional “localFrame” attribute allows for the definition of a local temporal frame of reference through the value of the component (i.e. we are specifying a time origin), as opposed to the referenceFrame which specifies that the value of the component is in reference to this frame.

- -

Requirement 28

Identifier/req/uml-simple-components/time-local-frame-valid
Statement

The “localFrame” attribute of an instance of the “Time” class shall have a different value than the “referenceFrame” attribute.

- -

This feature allows chaining several relative time positions. This is similar to what is done with spatial position in a geopositioning algorithm (and which is also supported by this standard using the “Vector” class).

- -

Example 1

- -

In the case of a whiskbroom scanner instrument, the “sampling time” is often expressed relative to the “scan start time” which is itself given relative to the “mission start time”. It is important to properly identify the chain of time reference systems at play so that the adequate process can compute the absolute time of every measurement made (Note that it is often not practical to record the absolute time of each single measurement when high sampling rates are used).

- -

Example 2

- -

A model forecast may represent its result times relative to the “run time” of the model for efficient encoding. The values of the output will be in reference to this base epoch. In this example the “referenceFrame” attribute of the model time is set to UTC and the “localFrame” set as “ModelTime”. The model result would then define its “referenceFrame” as “ModelTime”, allowing the time values to be encoded relative to the specified time origin.

-
- -

Unit of Measure (UoM)

- -

The “uom” attribute is mandatory since time is a continuous property that shall always be expressed in a well defined scale. The only units allowed are obviously time units.

- -

Constraints

- -

Similarly to the “Quantity” class, the “constraint” attribute allows further restricting the range of possible time values by using the “AllowedTimes” class defined in Clause 8.2.19.

- -

Value

- -

The “value” attribute (or the corresponding value in out-of-band data) is of type “TimePosition” (see Clause 8.2.1) and must match the constraint.

-
- -

8.2.10.  Requirements applicable to all range classes

- -

This UML package defines four classes “CategoryRange”, “CountRange”, “QuantityRange” and “TimeRange” that are used for representing extents of property values. These classes have common requirements that are expressed in this clause.

- -

The “value” attribute of all these classes takes a pair of values (with a datatype corresponding to the representation) that represent the inclusive minimum and maximum bounds of the extent. These values must both satisfy the constraints specified by an instance of the class, and be expressed in the unit specified when applicable.

- -

Requirement 29

Identifier/req/uml-simple-components/range-value-valid
Statement

Both values specified in the “value” property of an instance of a class representing a property range (i.e. “CategoryRange”, “CountRange”, “QuantityRange” and “TimeRange”) shall satisfy the same requirements as the scalar value used in the corresponding scalar classes.

- -

NOTE:    These classes are intentionally not derived from their scalar counterparts because they are aggregates of two values and should be treated as such by implementations (especially by encoding methods defined in this standard).

-
- -

8.2.11.  CategoryRange Class

- -

The “CategoryRange” class is used to express a value extent using the categorical representation of a property. It defines the same attributes as the “Category” class and those should be used in the same way (see Clause 8.2.6):

- -
- -

Figure 15 — CategoryRange Class

- -

Requirement 30

Identifier/req/uml-simple-components/category-range-valid
Statement

All requirements associated to the “Category” class defined in Clause 8.2.6 apply to the “CategoryRange” class.

- -

Code Space

- -

The “CategoryRange” class also requires that the underlying code space is well-ordered (i.e. the ordering of the different categories in the code space is clearly defined) so that the range is meaningful.

- -

Requirement 31

Identifier/req/uml-simple-components/category-range-codespace-order
Statement

The code space specified by the “codeSpace” attribute of an instance of the “CategoryRange” class shall define a well-ordered set of categories.

- -

Example

- -

A “CategoryRange” can be used to specify the approximate time of a geological event by using names of geological eons, eras or periods such as [Archean — Proterozoic] or [Jurassic — Cretaceous].

-
- -

Value

- -

The “value” attribute of the “CategoryRange” class takes a pair of tokens representing the inclusive minimum and maximum bounds of the extent.

-
- -

8.2.12.  CountRange Class

- -

The “CountRange” class is used to express a value extent using the discrete countable representation of a property. It defines the same attributes as the “Count” class and those should be used in the same way (see Clause 8.2.7):

- -
- -

Figure 16 — CountRange Class

- -

Value

- -

The “value” attribute of the “CountRange” class takes a pair of integer numbers representing the inclusive minimum and maximum bounds of the extent.

-
- -

8.2.13.  QuantityRange Class

- -

The “QuantityRange” class is used to express a value extent using the discrete countable representation of a property. It defines the same attributes as the “Quantity” class and those should be used in the same way (see Clause 8.2.8):

- -
- -

Figure 17 — QuantityRange Class

- -

Value

- -

The “value” attribute of the “QuantityRange” class takes a pair of real numbers representing the inclusive minimum and maximum bounds of the extent.

-
- -

8.2.14.  TimeRange Class

- -

The “TimeRange” class is used to express a value extent of a time property. It defines the same attributes as the “Time” class and those should be used in the same way (see Clause 8.2.9):

- -
- -

Figure 18 — TimeRange Class

- -

Requirement 32

Identifier/req/uml-simple-components/time-range-valid
Statement

All requirements associated to the “Time” class defined in Clause 8.2.9 apply to the “TimeRange” class.

- -

The “value” attribute of the “TimeRange” class takes a pair of values of type “TimePosition” representing the inclusive minimum and maximum bounds of the extent.

-
- -

8.2.15.  Quality Union

- -

The “Quality” class is a union allowing the use of different representations of quality.

- -

Quality can be indeed be specified as a decimal value, an interval, a categorical value or a textual statement. In our model, quality objects are in fact data components used in a recursive way, as shown on the following diagram:

- -
- -

Figure 19 — Quality Union

- -

These different representations of quality are useful to cover most use cases where simple quality information is provided with the data.

- -

Examples

- -

“Quantity” is used to specify quality as a decimal number such as accuracy, variance and mean, or probability.

- -

“QuantityRange” is used to specify a bounded interval of variation such as a bi-directional tolerance.

- -

“Category” is used for a quality statement based on a well defined taxonomy such as certification levels.

- -

“Text” is used to include a textual quality statement such as a comment written by a field operator.

-
- -

The “definition” attribute of the chosen quality component helps to further define the type of quality information given just like any other data component, and the “uom” should be specified in the case of a decimal quality value or interval.

NOTE:    Reusing data components to specify quality also allows the inclusion of quality values in the data stream itself. This is useful if the quality is varying and re-estimated for each measurement. This is for example the case in a GPS receiver where both horizontal and vertical errors are given along with the geographic position. See the XML implementation clause for more information on this use case.

- - -
- -

8.2.16.  NilValues Class

- -

The “NilValues” class is used by all classes deriving from “AbstractSimpleComponent”. It allows the specification of one or more reserved values that may be included in a data stream when the normal measurement value is not available (see Clause 7.4.2). The UML model of this class is given below:

- -
- -

Figure 20 — NilValues Class

- -

An instance of the “NilValues” class is composed of one to many “NilValue” objects, each of which specifies a mapping between a reserved value and a reason.

- -

The mandatory “reason” attribute indicates the reason why a measurement value is not available. It is a resolvable reference to a controlled term that provides the formal textual definition of this reason (usually agreed upon by one or more communities).

- -

Requirement 33

Identifier/req/uml-simple-components/nil-reason-resolvable
Statement

The “reason” attribute of an instance of the “NilValue” class shall map to the complete human readable definition of the reason associated with the NIL value.

- -

The mandatory “value” attribute specifies the data value that would be found in the stream to indicate that a measurement value is missing for the corresponding reason. The range of values allowed here is the range of values allowed by the datatype of the parent data component.

- -

Requirement 34

Identifier/req/uml-simple-components/nil-value-type-coherent
Statement

The value used in the “value” property of an instance of the “NilValue” class shall be compatible with the datatype of the parent data component object.

- -

This means that when specifying NIL values for a “Quantity” component, only real values are allowed (in most implementations, this includes NaN, -INF and INF) and for a “Count” component only integer values are allowed.

- -

Consequently, it is also impossible to specify NIL values for a “Boolean” data component since it allows only two possible values. In this case a “Category” component should be used.

- -

There are no restrictions on the choice of NIL values for “Category” and “Text” components since their datatype is String.

-
- -

8.2.17.  AllowedTokens Class

- -

The “AllowedTokens” class is used to express constraints on the value of a data component represented by a “Text” or a “Category” class. The UML class is shown below:

- -
- -

Figure 21 — AllowedTokens Class

- -

This class allows defining the constraint either by enumerating a list of allowed values by using one or more “value” attributes and/or by specifying a pattern that the value must match. The value must then either be one of the enumerated tokens or match the pattern.

-
- -

8.2.18.  AllowedValues Class

- -

The “AllowedValues” class is used to express constraints on the value of a data component represented by a “Count” or a “Quantity” class. The UML class is shown below:

- -
- -

Figure 22 — AllowedValues Class

- -

This class allows constraints to be defined either by enumerating a list of allowed values and/or a list of inclusive intervals. To be valid, the value must either be one of the enumerated values or included in one of the intervals. The numbers used in the “value” and “interval” properties shall be expressed in the same unit as the parent data component.

- -

Requirement 35

Identifier/req/uml-simple-components/allowed-values-unit-coherent
Statement

The scale of the numbers used in the “enumeration” and “interval” properties of an instance of the “AllowedValues” class shall be expressed in the same scale as the value(s) that the constraint applies to.

- -

If the parent data component instance is used to define a projected quantity (i.e. when the “axisID” is set), then the constraints given by this class are expressed along the same spatial reference frame axis.

- -

The number of significant digits can also be specified with the “significantFigures” property though it is only applicable when used with a decimal representation (i.e. within the “Quantity” class). This limits the total number of digits that can be included in the number represented whether a scientific notation is used or not.

- -

Examples

- -

All non-zero digits are considered significant. 123.45 has five significant figures: 1, 2, 3, 4 and 5.

- -

Zeros between two non-zero digits are significant. 101.12 has five significant figures: 1, 0, 1, 1 and 2.

- -

Leading zeros are not significant. 0.00052 has two significant figures: 5 and 2 and is equivalent to 5.2×10-4 and would be valid even if the number of significant figures is restricted to 2.

- -

Trailing zeros are significant. 12.2300 has six significant figures: 1, 2, 2, 3, 0 and 0 and would thus be invalid if the number of significant figures is restricted to 4.

-
- -

NOTE:    The number of significant figures and/or an interval constraint (i.e. min/max values) can help a software implementation choosing the best data type to use (i.e. ‘float’ or ‘double’, ‘short’, ‘int’ or ‘long’) to store values associated to a given data component.

-
- -

8.2.19.  AllowedTimes Class

- -

The “AllowedTimes” class is used to express constraints on the value of a data component represented by a “Time” class. The UML class is shown below:

- -
- -

Figure 23 — AllowedTimes Class

- -

This class is almost identical to the “AllowedValues” class and in fact all properties are used in the same way. The only difference with this class is that the “value” and “interval” properties allow the use of time data types as defined in Clause 8.2.1.

- -

The constraints given by this class are expressed along the same time reference frame axis as the value attached to the parent data component.

-
- -

8.2.20.  Unions of simple component classes

- -

Several useful groups of classes are also defined in this package. These unions can be used as attribute types and they are shown on the following diagram:

- -
- -

Figure 24 — Simple Component Unions

- -

The “AnyScalar” union groups all classes representing scalar components, numerical or not. The “AnyNumerical” union includes all classes corresponding to numerical scalar representations. The “AnyRange” union regroups all range components.

-
-

8.3.  Requirements Class: Record Components Package

- -

Requirements class 3: Record Components UML Package

Identifier/req/uml-record-components
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.3: /conf/uml-record-components
PrerequisiteRequirements class 2: /req/uml-simple-components
- -

As detailed in the following clauses, this package defines classes modeling record style component types that can be nested to build complex structures from the simple component types introduced in Clause 8.2.

- -

The classes defined in this package are “DataRecord” and “Vector” (other aggregates are defined in the “Choice Components” and “Block Components” packages defined in Clauses 8.4 and 8.5 respectively). The UML model is exposed below:

- -
- -

Figure 25 — Record Data Components

- -

Requirement 36

Identifier/req/uml-record-components/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Record Components” UML package.

- -

As with simple component types, all data aggregates inherit attributes from the “AbstractDataComponent” class. In this case, however, these attributes provide information about the group as a whole rather than its individual components.

- -

Examples

- -

A particular “DataRecord” might represent a standard collection of error codes coming from a GPS device.

- -

A particular “Vector” might represent the linear or angular velocity vector of an aircraft.

- -

In these two cases, the “definition” attribute should reference a semantic description in a registry, so that the data consumer knows what kind of data the aggregate represents. This semantic description can then be interpreted appropriately by consuming clients: for example to automatically decide how to style the data in visualization software.

-
- -

8.3.1.  DataRecord Class

- -

The “DataRecord” class is modeled on the definition of ‘Record’ from ISO 11404. In this definition, a record is a composite data type composed of one to many fields, each of which having its own name and type definition. Thus it defines some logical collection of components of any type that are grouped for a given purpose.

- -

As shown on the following figure, the “DataRecord” class in SWE Common is based on a full composite design pattern, such that each one of its “field” can be of a different type, including simple component types as well as any aggregate component type.

- -
- -

Figure 26 — DataRecord Class

- -

The “DataRecord” class derives from the “AbstractDataComponent” class, which is necessary to enable the full composite pattern in which a “DataRecord” can be used to group scalar components, but also other records, arrays and choices recursively.

- -

Fields

- -

Each “field” attribute can take an instance of any concrete sub-class of “AbstractDataComponent”, which is the superset of all data component types defined in this standard. The name of each field must be unique within a given “DataRecord” instance so that it can be used as a key to uniquely identify and/or index each one of the record components.

- -

Requirement 37

Identifier/req/uml-record-components/record-field-name-unique
Statement

Each “field” attribute in a given instance of the “DataRecord” class shall be identified by a name that is unique to this instance.

- -

Example

- -

A “DataRecord” can group related values such as “temperature”, “pressure” and “wind speed” into a structure called “weather measurements”. This feature is often used to organize the data and present it in a clear way to the user.

- -

Similarly a “DataRecord” can be used to group values of several spectral bands in multi-spectral sensor data. However, using a “DataArray” may be easier to describe hyper spectral datasets with several hundreds of bands.

-
- -

NOTE:    The slightly different definition of record found in ISO 19103 provides for its schema to be specified in an associated “RecordType”. When used as a descriptor, the “DataRecord” implements the ISO 19103 “RecordType”. When used as a data container, it is self-describing: the descriptive information is then interleaved with the record values.

-
- -

8.3.2.  Vector Class

- -

The “Vector” class is used to express multi-dimensional quantities with respect to a well defined referenced frame (usually a spatial or spatio-temporal reference frame). This is done by projecting the quantity on one or several axes that define the reference frame and assigning a value to each of the axis projections.

- -

The “Vector” class is a special case of a record that takes a collection of coordinates that are restricted to a numerical representation. Coordinates of a “Vector” can thus only be of type “Quantity”, “Count” or “Time”. Its UML diagram is shown below:

- -
- -

Figure 27 — Vector Class

- -

Coordinates

- -

Just like record fields, vector coordinates must have a unique name:

- -

Requirement 38

Identifier/req/uml-record-components/vector-coord-name-unique
Statement

Each “coordinate” attribute in a given instance of the “Vector” class shall be identified by a name that is unique to this instance.

- -

Reference Frame

- -

This class contains a mandatory “referenceFrame” attribute that identifies the frame of reference with respect to which the vector quantity is expressed. The coordinates of the vector correspond to values projected on the axes of this frame.

- -

The “referenceFrame” attribute is inherited by all components of the “Vector”, so that it shall not be redefined for each coordinate. However the “axisID” attribute shall be specified for each coordinate, in order to unambiguously indicate what axis of the reference frame it corresponds to.

- -

Requirement 39

Identifier/req/uml-record-components/vector-component-no-ref-frame
Statement

The “referenceFrame” attribute shall be ommited from all data components used to define coordinates of a “Vector” instance.

- -

Requirement 40

Identifier/req/uml-record-components/vector-component-axis-defined
Statement

The “axisID” attribute shall be specified on all data components used as children of a “Vector” instance.

- -

Local Frame

- -

The optional “localFrame” attribute allows identifying the frame of interest, that is to say the frame we are positioning with the coordinate values associated to this component (by opposition to the “referenceFrame” that specifies the frame with respect to which the values of the coordinates are expressed).

- -

Requirement 41

Identifier/req/uml-record-components/vector-local-frame-valid
Statement

The “localFrame” attribute of an instance of the “Vector” class shall have a different value than the “referenceFrame” attribute.

- -

Correctly identifying the local and reference frame is an important feature that allows chaining several relative positions, something that is essential to correctly compute accurate position of sensor data (especially remote sensing data).

- -

Example 1

- -

A position vector (or location vector) is used to locate the origin of a frame of interest (the local frame) relative to the origin of a frame of reference (the reference frame) through a linear translation. It is composed of three coordinates of type “Quantity”, each with a definition indicating that the coordinate represents a length expressed in the desired unit. The definition of the “Vector” itself should also indicate that it is a “location vector”.

- -
- -

Example 2

- -

An orientation vector is used to indicate the rotation of the axes of a frame of interest (the local frame) relative to a frame of reference (the reference frame). It is composed of three coordinates of type “Quantity” with a definition indicating an angular property. The “Vector” definition should indicate the type of orientation vector such as “Euler Angles” or “Quaternion”. Depending on the exact definition, the order in which the coordinates are listed in the vector may matter.

-
- -

NOTE:    “Vector” aggregates are most commonly used to describe position, orientation, velocity, and acceleration within temporal and spatial domains, but can also be used to express relationships between any two coordinate frames.

-
-

8.4.  Requirements Class: Choice Components Package

- -

Requirements class 4: Choice Components UML Package

Identifier/req/uml-choice-components
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.4: /conf/uml-choice-components
PrerequisiteRequirements class 2: /req/uml-simple-components
- -

As detailed in the following clauses, this package defines a class modeling a disjoint union component type. This aggregate type can be nested with other aggregate components to build complex structures.

- -

Requirement 42

Identifier/req/uml-choice-components/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Choice Components” UML package.

- -

8.4.1.  DataChoice Class

- -

The “DataChoice” class (also called Disjoint Union) is modeled on the definition of ‘Choice’ from ISO 11404. It is a composite component that allows for a choice of child components. By opposition to records that carry all their fields simultaneously, only one item at a time can be present in the data when wrapped in a “DataChoice”. The following diagram shows the “DataChoice” class as implemented in the SWE Common Data Model:

- -
- -

Figure 28 — DataChoice Class

- -

This class implements a full composite pattern, so that each “item” can be any data component, including simple and aggregate types.

- -

The “choiceValue” attribute is used to represent the token value that would be present in the data stream and that indicates the actual choice selection before the corresponding data can be given (i.e. knowing what choice item was selected ahead of time is necessary for proper decoding of encoded data streams).

- -

Items

- -

Each “item” attribute can take an instance of any concrete sub-class of “AbstractDataComponent”, which is the superset of all data component types defined in this standard. The name of each item shall be unique within a given “DataChoice” instance so that it can be used as a key to uniquely identify and/or index each one of the choice components.

- -

Requirement 43

Identifier/req/uml-choice-components/choice-item-name-unique
Statement

Each “item” attribute in a given instance of the “DataChoice” class shall be identified by a name that is unique to this instance.

- -

The “DataChoice” component is used to describe a data structure (or a part of the structure) that can alternatively contain different types of objects. It can also be used to define the input of a service or process that allows a choice of structures as its input.

- -

Examples

- -

NMEA 0183 compatible devices can output several types of sentences in the same data stream. Some sentences include GPS location, while some others contain heading or status data. This can be described by a “DataChoice” which items represent all the possible types of sentences output by the device.

- -

A Sensor Planning Service (SPS) can define a choice in the tasking messages that the service can accept, thus leaving more possibilities to the users.

-
-
-

8.5.  Requirements Class: Block Components Package

- -

Requirements class 5: Block Components UML Package

Identifier/req/uml-block-components
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.5: /conf/uml-block-components
PrerequisitesRequirements class 2: /req/uml-simple-components
Requirements class 7: /req/uml-simple-encodings
- -

This package defines additional aggregate components for describing arrays of values that are designed to be encoded as efficient data blocks. These additional aggregate components are purposely defined in a separate requirement class because they require a more advanced implementation for handling data values as encoded blocks.

- -

The UML models for these additional aggregate components are shown below:

- -
- -

Figure 29 — Array Components

- -

Requirement 44

Identifier/req/uml-block-components/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Block Components” UML package.

- -

The principle of these two classes is that the number and type of elements contained in the array is defined once, while the actual array values are listed separately without being redefined with each value. In order to achieve this, all array values are encoded as a single data block in the “values” attribute. Consequently, these classes are restricted to cases where all elements are homogeneous and thus can be described only once even though the array data may in fact contain many of them.

- -

This package also defines the “DataStream” class that is similar in principle to the “DataArray” class but cannot be nested within other aggregate data components. It is a top level class that encapsulates the description of a full data stream.

- -

8.5.1.  DataArray Class

- -

The “DataArray” class is modeled on the corresponding definition of ISO 11404. This definition states that an array is a collection of elements of the same type (as opposed to a record where each field can have a different type), with a defined size. This class is shown on the following UML diagram:

- -
- -

Figure 30 — DataArray Class

- -

This class implements a full composite pattern, so that the “elementType” can be any data component, including simple and aggregate types. It can be used to group identical scalar components as well as records, choices and arrays in a recursive manner.

- -

Element Count

- -

The “elementCount” attribute is used to indicate the size of the array, that is to say the number of elements of the given type in the array. Note that each element is not necessarily scalar but can be a record, another array, etc.

- -

Element Type

- -

The content of the “elementType” attribute defines the exact structure of each element in the array. The data component used and all of its children shall not include any inline values, as these will be block encoded in the “values” attribute of the parent “DataArray”.

- -

Requirement 45

Identifier/req/uml-block-components/array-component-no-value
Statement

Data components that are children of an instance of a block component shall be used solely as data descriptors. Their values shall be block encoded in the “values” attribute of the block component rather than included inline.

- -

However, the “DataArray” class itself, like any other data component can be used either as a data descriptor or as a data container. To use it as a data descriptor the “encoding” and “values” attributes are not set. To use it as a data container, these attributes are both set as described below.

- -

Encoding and Values

- -

The “encoding” and “values” fields are there to provide array data as an efficient block which can be encoded in several ways. The different encoding methods are described in Clauses 8.7 and 8.8. The “encoding” field shall have a value if the “values” field is present, and the data shall be encoded using the specified encoding.

- -

Requirement 46

Identifier/req/uml-block-components/array-values-properly-encoded
Statement

Whenever an instance of a block component contains values, an encoding method shall be specified by the “encoding” property and array values shall be encoded as specified by this method.

- -

The choice of simple encodings (defined in the “Simple Encodings” package) allows encoding data as text using a delimiter separated values (DSV, a variant of CSV) format or as XML tagged values. The “Advanced Encodings” package defines binary encodings that can be used to efficiently package large datasets.

- -

Nested Components

- -

By combining instances of “DataArray”, “DataRecord” and scalar components, one can obtain the complex data structures that are necessary to fully describe any kind of sensor data. In particular, the possibility of nesting a “DataRecord” or “Vector” inside a “DataArray” allows defining structures such as trajectories, profiles, multi-band images, etc.

- -

Example 1

- -

The “DataArray” class can be used to describe a simple 1D array of measurements such as radiance values obtained using a 12000 cells (1 row) CCD strip for instance. This can be done by using the “Quantity” class as the element type. In such a case, describing the dataset as a “DataRecord” would be a very repetitive task given the number of elements (12000 in this case!).

- -
- -

Example 2

- -

The “DataArray” class can be used as a descriptor for a trajectory dataset by using a vector of [latitude, longitude] coordinates as its element type. Note that this can also be considered as a 1D coverage in a 2D CRS.

- -
-
- -

Multi-dimensional Arrays

- -

Since the “DataArray” class alone can only represent 1-dimensional arrays, the construction of multi-dimensional arrays is done by nesting “DataArray” objects inside each other.

- -

Example

- -

The structure of panchromatic imagery data can be described with two nested arrays, which sizes indicate the two dimensions of the image. A “Quantity” is used as the element type of the nested array in order to indicate that the repeated element of the 2D array is of type infrared radiance with a given unit.

- -
- -

In this example, the image is described as an array of rows, each row being an array of samples. It is also possible to describe an image as an array of columns by reversing the two dimensions. Note that this would change the order in which the data values would appear in a stream (by rows vs. by columns).

-
- -

Array Size

- -

One powerful feature of the “DataArray” model is that it allows for the element count to be either fixed or variable, thus allowing the description of data streams with variable number of repetitive elements as is often the case with many kinds of sensor.

- -

In a fixed size array, the number of elements can be provided in the descriptor as an instance of the “Count” class with an inline value. This value is only present in the data description and not in the encoded block of array values. The definition of the “Count” instance is not required.

- -

In a variable size array, the “elementCount” attribute either contains an instance of the “Count” class with no value or references an instance of a “Count” class in a parent or sibling data component. The value giving the actual array size is then included in the stream, before the array values themselves, so that the block can be properly decoded. One obvious implementation constraint is that the value representing the array size must be received before the array values. This is detailed further in the XML implementation section.

- -

Examples

- -

Argo profiling floats can measure ocean salinity and temperature profiles of variable lengths by diving at different depths and depending on the conditions. A variable size “DataArray” could be used to describe their output data as well as a dataset aggregating data from several Argo floats.

- -

Variable size arrays can often be used to avoid unnecessary padding of fixed size array data. However for efficiency reasons (usually to enable fast random access w/o preliminary indexation), padding can also be specified in SWE Common when using the binary encoding.

-
- -

Array Semantics

- -

As with any other data component, the “name” and “description” can be used to better describe the array and more importantly the “definition” attribute can be used to formally indicate the semantics behind the array.

- -

Example

- -

When a “DataArray” is used to package data relative to the spectral response of a sensor, the array “definition” attribute can be used to point to the formal out-of-band definition of the “spectral response” concept.

- -

Similarly a “DataArray” used to describe the output data of an Argo float would have its “definition” attribute reference the formal definition of a “profile”.

-
- -

The value of the “definition” attribute of the “Count” instance used as the “elementCount” is also especially important, since it is used to define the meaning of the array dimension. Thanks to this, it is possible to tag the dimension of an array as spatial, temporal, spectral, or any other kind. However it is not mandatory as it is on other simple components.

- -

Examples

- -

In the CCD strip example described as a 1D array, the array index is the cell number in the strip.

- -

In the 2D image example, the outer array index is the row number, while the inner array index is the column (or sample) number.

- -

In a 1D array representing a time series, the array index is along the temporal dimension.

- -

In a 2D array representing a spatial coverage, the two array indices are along spatial dimensions.

- -

In a 3D array representing hyper-spectral imagery, the two first arrays have indices along spatial dimension while the most inner array is indexed along the spectral dimension.

-
- -

This extra information can be used by software to make decisions (or at least ask the user by providing him this information) about how to represent or even interpolate the data.

-
- -

8.5.2.  Matrix Class

- -

The “Matrix” extends the “DataArray” class by providing a reference frame within which the matrix elements are expressed and a local frame of interest. The UML diagram of this class is shown below:

- -
- -

Figure 31 — Matrix Class

- -

The “Matrix” class is usually used to represent a position matrix or a tensor quantity of second or higher order. Each matrix element is expressed along the axis of a well defined reference frame.

- -

Element Type

- -

The “elementType” attribute inherited from the “DataArray” class can only take a nested “Matrix” instance or a scalar numerical component. Nested matrix objects allow the full description of N-dimensional matrices.

- -

Requirement 47

Identifier/req/uml-block-components/matrix-element-type-valid
Statement

The “elementType” attribute of an instance of the “Matrix” class can only be an instance of “Matrix” or of the classes listed in the “AnyNumerical” union.

- -

Reference Frame

- -

The “referenceFrame” attribute is used in the same way as with the “Vector” class to specify the frame of reference with respect to which the matrix element values are expressed. It is inherited by all child components.

- -

Local Frame

- -

The “localFrame” attribute is used to identify the frame of interest, that is to say the frame whose orientation or position is given with the matrix in the case where it is a position matrix. If the matrix does not specify position, “localFrame” should not be used. Whether an instance of the “Matrix” class represents a position matrix or not should be disambiguated by setting the value of its “definition” attribute.

- -

Examples

- -

The “Matrix” class can be used to represent for instance: -- A 3D 3×3 stress tensor -- A 4D 4×4 homogeneous affine transformation matrix

- -

In particular it is often used to specify the orientation of an object relative to another one, like for instance the attitude of a plane relative to the earth.

-
-
- -

8.5.3.  DataStream Class

- -

The “DataStream” class has a structure similar than the “DataArray” class but is not a data component (i.e. it does not derive from “AbstractDataComponent”) and thus cannot be used as a child of other aggregate components. Below is its UML diagram:

- -
- -

Figure 32 — DataStream Class

- -

This class should be used as the wrapper object to define a complete data stream. It defines a data stream as containing a list of elements with an arbitrary complex structure. An important feature is that the data stream can be open ended (i.e. the number of elements is not known in advance) and is thus designed to support real time streaming of data.

- -

Element Count

- -

The “elementCount” attribute is optional and can be used to indicate the number of elements in the stream if it is known. This is done by instantiating an instance of the “Count” class whose “value” attribute would be set to the number of elements.

- -

Element Type

- -

The “elementType” attribute is used to define the structure of each element in the stream. The data component used as the element type and all of its children shall be used solely as data descriptors, meaning that they shall not include any inline values. These values will instead be block encoded in the “values” attribute of the parent “DataStream”.

- -

Encoding and Values

- -

The “encoding” and “values” fields are there to provide the stream values as an efficient block which can be encoded in several ways. The same encoding methods as for the “DataArray” class are available and are described in Clauses 8.7 and 8.8. The “values” attribute is optional as the DataStream class can be used as a simple descriptor.

- -

Requirement 48

Identifier/req/uml-block-components/datastream-array-valid
Statement

Data components that are children of an instance of the ”DataStream” class shall be used solely used as data descriptors. Their values shall never be included inline since they will be block encoded in the stream described by the ”DataStream”.

-
-

8.6.  Requirements Class: Geometry Components Package

- -

Requirements class 6: Geometry Components UML Package

Identifier/req/uml-geom-components
Target typeSoftware Implementation or Encoding of the Conceptual Models
PrerequisiteRequirements class 2: /req/uml-simple-components
- -

This package defines an additional component for representing simple feature geometries, as defined by OGC 06-103r4, within an encoded SWE Common data block or stream.

- -

Requirement 49

Identifier/req/uml-geom-components/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Geometry Components” UML package.

- -

8.6.1.  Geometry Class

- -

The “Geometry” class extends the “AbstractDataComponent” class with a value of type geometry and a constraint that can be used to limit the types of allowed geometries. This class is shown on the following UML diagram:

- -
- -

Figure 33 — Geometry Class

- -

Coordinate Reference System

- -

The “crs” attribute provides the URI of the coordinate reference system w.r.t which the geometry coordinates are expressed. The unit of the coordinates is also provided by the coordinate reference system.

- -

Requirement 50

Identifier/req/uml-geom-components/srs-valid
Statement

The “srs” attribute shall reference the definition of a valid 2D or 3D spatial reference system.

- -

Constraints

- -

The “constraint” attribute is used to restrict the possible geometries that can be provided using this component when it is used as a descriptor. The constraint is provided using the “AllowedGeometries” class that includes a list of allowed geometry types.

- -

Value

- -

The value of this component must be a geometry instance, whether it’s provided inline using the “value” attribute, or as part of a datastream.

- -

Requirement 51

Identifier/req/uml-geom-components/geom-value-valid
Statement

The “value” attribute shall be one of the concrete geometry value classes defined in OGC 06-103r4: “Point”, “MultiPoint”, “LineString”, “MultiLineString”, “Polygon”, or “MultiPolygon”.

- -

NOTE:    Encoding sections in this standard define how the geometry value is encoded:

-
-

8.7.  Requirements Class: Simple Encodings Package

- -

Requirements class 7: Simple Encodings UML Package

Identifier/req/uml-simple-encodings
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.6: /conf/uml-simple-encodings
PrerequisiteRequirements class 1: /req/core
- -

Encoding methods describe how structured array and stream data is encoded into a low level byte stream (see related concepts in Clause 7.6). Once encoded as a sequence of bytes, the data can then be transmitted using various digital means such as files on a disk or network connections.

- -

This package includes two classes that provide definitions of simple encoding methods. They are used as descriptors of the method used to encode data component values wrapped by aggregate classes defined in the “Block Components” package. There model is shown on the diagram below:

- -
- -

Figure 34 — Simple Encodings

- -

Requirement 52

Identifier/req/uml-simple-encodings/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Simple Encodings” UML package.

- -

All classes defining encoding methods derive from a common abstract class called “AbstractEncoding”. Extensions to this standard that define new encoding methods shall derive encoding classes from this abstract class.

- -

The intent of this standard is to provide a set of core encodings covering most common needs. Each encoding has specific benefits that match the needs of different applications. Sometimes several encodings of the same dataset can be offered in order to satisfy several types of consumers and/or use cases.

- -

In the model provided in this standard, the encoding specification is provided separately from the data component tree describing the dataset structure, thus enabling several encodings to be applied to the same data structure without changing it.

- -

8.7.1.  TextEncoding Class

- -

The “TextEncoding” class defines a method allowing encoding arbitrarily complex data using a text based delimiter separated values (DSV) format. The class used to specify this encoding method is shown below:

- -
- -

Figure 35 — TextEncoding Class

- -

The “tokenSeparator” attribute specifies the characters to use for separating each scalar value from one another. Scalar values appear sequentially in the stream alternatively with the token separator characters, in an order unambiguously defined by the data component structure. The detailed rules are given in the implementation Clause 10.3.

- -

The “blockSeparator” attribute specifies characters used to mark the end of a “block”, corresponding to the complete structure defined by the data component tree (in a “DataArray”, “Matrix” or “DataStream” one block corresponds to one element, that is to say the structure defined by the “elementType” property). Stream or array data can then be composed of several blocks of the same type separated by block separator characters.

- -

The “decimalSeparator” attribute specifies the character used as the decimal point in decimal number. This attribute is optional and the default is a period (‘.’).

- -

Example

- -

In the case of a “DataStream” with an element type that is a “DataRecord” containing three fields – one of type “Category” and two of type “Quantity” — a data stream encoded using the Text method would look like the following:

- -

STATUS_OK,24.5,1022.5¶
-STATUS_OK,24.5,1022.5¶
-STATUS_OK,24.5,1022.5¶

- -

Where , (comma) is the token separator and (carriage return) is the block separator (i.e. this is the CSV format). -Note that there could be many more values in a single block if the data set has a large number of fields, or if it contains an array of values.

-
- -

The “collapseWhiteSpaces” attribute is a boolean flag used to specify if extra white spaces (including line feeds, tabs, spaces and carriage returns) surrounding the token and block separators should be ignored (skipped) when processing the stream. This is useful for encoded blocks of data that are embedded in an XML document, since formatting (indenting with spaces or tabs especially) is often done in XML content.

- -

This type of encoding is used when compactness is important but balanced by a desire of human readability. This type of encoding is easily readable (for debugging or manual usage) as well as easily imported in various spreadsheet, charting or scientific software.

- -

The main drawback of such an encoding is the impossibility of locating an error in the stream with certitude. Secondly, if only one expected value is missing, the whole block is usually lost since the parser cannot resynchronize correctly before the next block separator. This last issue can however be solved by transmitting this type of encoded stream using error resilient protocols when needed.

-
-

8.8.  Requirements Class: Advanced Encodings Package

- -

Requirements class 8: Advanced Encodings UML Package

Identifier/req/uml-advanced-encodings
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.7: /conf/uml-advanced-encodings
PrerequisiteRequirements class 7: /req/uml-simple-encodings
- -

This package defines an additional encoding method for packaging sensor data as raw or base 64 binary blocks. When this package is implemented, the binary encoding method is usable, as any other encoding method, within the “DataArray” and “DataStream” classes.

- -

Requirement 53

Identifier/req/uml-advanced-encodings/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Advanced Encodings” UML package.

- -

8.8.1.  BinaryEncoding Class

- -

The “BinaryEncoding” class defines a method that allows encoding complex structured data using primitive data types encoded directly at the byte level, in the same way that they are usually represented in memory.

- -

The binary encoding method can lead to very compact streams that can be optimized for efficient parsing and fast random access. However this comes with the lack of human readability of the data and sometimes lack of compatibility with other software (i.e. software that is not SWE Common enabled).

- -

More information is needed to fully define a binary encoding, so the model is more complex than the other encodings. It is shown below:

- -
- -

Figure 36 — BinaryEncoding Class

- -

The main class “BinaryEncoding” specifies overall characteristics of the encoded byte stream such as the byte order (big endian or little endian) and the byte encoding (raw or base64). The two corresponding attributes, respectively “byteOrder” and “byteEncoding” are mandatory. Base64 encoding is usually chosen to insert binary content within an XML document.

- -

The “byteLength” attribute is optional and can be used to specify the overall length of the encoded data as a total number of bytes. This should be indicated whenever possible if the data size is known in advance as it can be useful for efficient memory allocation.

- -

The “BinaryEncoding” class also has several “member” attributes that contain detailed information about parts of the data stream. This attribute can take a choice of instance of two classes: “Component” or “Block”.

- -

The “Component” class is used to specify binary encoding details of a given scalar component in the stream. The following information can be provided for each scalar field:

- -
  • The “ref” attribute allows identifying the data component in the dataset structure for which we’re specifying the encoding parameters. Soft-typed property names are used to uniquely identify a given component in the tree.

    -
  • -
  • The “dataType” attribute allows selecting a data type among commonly accepted ones such as ‘byte’, ‘short’, ‘int’, ‘long’, ‘double’, ‘float’, ‘string’, etc…

    -
  • -
  • The “byteLength” or “bitLength” attributes are mutually exclusive and used to further specify the length of the data type in the case where it is not a standard length (i.e. to encode integer numbers on more than 8 bytes or less than 8 bits for instance).

    -
  • -
  • The “significantBits” can be used to signal that only some of the bits of the data type are actually used to carry the value (i.e. a value may be encoded as a byte but only use 4 bits to encode a value between 0 and 15). This is mostly informational.

    -
  • -
  • The “encryption” attribute can be used to select the method with which the value is encrypted before being written to the stream.

    -
  • -
- -

The “Block” class is used to specify binary encoding details of a given aggregate component representing a block of values in the data stream. This is used either to specify padding before and/or after a block of data or to enable compression or encryption of all or part of a dataset.

- -
  • The “ref” attribute allows identifying the data component in the dataset structure for which we’re specifying the encoding parameters. Soft-typed property names are used to uniquely identify a given component in the tree.

    -
  • -
  • The optional “byteLength” attribute allows indicating the overall length of the encoded block to facilitate memory allocation.

    -
  • -
  • The “paddingBytes-before” and “paddingBytes-after” are used to specify the number of empty bytes (i.e. usually 0 bytes) that are inserted in the stream respectively before and after data for the referenced component. This is sometimes used to align data on N-bytes block for faster access.

    -
  • -
  • The “encryption” attribute identifies the encryption method that is used to encrypt the block of data before it is inserted in the stream.

    -
  • -
  • The “compression” attribute identifies the compression method that is used to compress the block of data before it is inserted in the stream.

    -
  • -
- -

This standard does not define any concrete encryption and compression methods, so that software implementations of this requirement class are not required to support any value in the “encryption” and “compression” attributes of the “Component” and “Block” classes. Extensions of this standard that define binary encryption and compression methods shall describe how the encrypted or compressed data is inserted in the SWE Common data stream.

-
-

9.  JSON Implementation (normative)

This standard defines a normative JSON implementation of the conceptual models presented in Clause 8. The standardization target type for all requirements classes in this clause is a JSON instance document that seeks compliance with this JSON encoding model.

JSON schemas defined in this section are a direct implementation of the UML conceptual models described in Clause 8. They have been generated from these models by strictly following well-defined encoding rules. All attributes and composition/aggregation associations contained in the UML models are encoded as JSON object members.

All JSON examples given in this section are informative and are used solely for illustrating features of the normative model. Many of these examples reference semantic information by using URLs that resolve to the following online ontologies:

Some of the JSON examples contain inline values while others don’t. This is meant to illustrate that the component objects defined by the JSON implementation can be used as value objects for properties of larger metadata objects (e.g. SensorML system descriptions), but can also be used as descriptors to describe, for instance, the content of a datastream or the rangeset of a coverage.

9.1.  Requirements Class: Basic Types and Simple Components JSON Schemas

- -

Requirements class 9: Basic Types and Simple Components JSON Schemas

Identifier/req/json-simple-components
Target typeJSON Document
PrerequisiteRequirements class 2: /req/uml-simple-components
- -

Validation patterns that implement all classes defined respectively in the “Basic Types” and “Simple Components” UML packages are provided as JSON schema files at https://raw.githubusercontent.com/opengeospatial/connected-systems/master/swecommon/schemas/json.

- -

The entry point schema used for validation is “sweCommon.json”.

- -

Requirement 54

Identifier/req/json-simple-components/schema-valid
Statement

The JSON document instance shall be valid with respect to the JSON schema “sweCommon.json”.

- -

9.1.1.  General JSON Principles

- -

The following rules were used when generating the JSON schemas:

- -
  • Classes are implemented as JSON Objects;

    -
  • -
  • Any property with a multiplicty greater than one is implemented as a JSON Array and its name is converted to plural form;

    -
  • -
  • Textual fields are implemented as a JSON String;

    -
  • -
  • Decimal fields are implemented as a union of JSON Number and JSON String value types (the string value allowing for special values, see Clause 9.1.2);

    -
  • -
  • ISO8601 date/time fields are implemented as a JSON String with a union of date/time formats.

    -
  • -
-
- -

9.1.2.  Special Numerical Values

- -

JSON does not define special decimal values for ‘Not a Number’, positive infinity and negative infinity. It is thus necessary to encode them as strings.

- -

Requirement 55

Identifier/req/json-simple-components/special-numerical-values
Statement

The special JSON Strings NaN, -Infinity and +Infinity shall be allowed as the inline or out-of-band value for Quantity and Time (and Count?) components (except when the Time component uses the ISO 8601 format).

- -

NOTE:    These special value strings have been chosen because they are supported natively by Javascript/ECMA Script implementations. The + unary operator can be used to transparently parse one of these strings to a Number type (see https://262.ecma-international.org/13.0/#sec-unary-plus-operator).

These values also correspond to infinities and NaN values defined in IEEE 754-2008.

-
- -

9.1.3.  Abstract Base Classes

- -

The three abstract base classes defined in the UML models are implemented by the following JSON schemas:

- - - -

Requirement 56

Identifier/req/json-simple-components/definition-resolvable
Statement

The “definition” object member defined in the “AbstractDataComponent.json” schema shall contain a URI that can be resolved to the complete human readable definition of the property that is represented by the data component.

- -

Requirement 57

Identifier/req/json-simple-components/inline-value-constraint-valid
Statement

The inline value included in a JSON instance validating against the “AbstractSimpleComponent.json” schema shall satisfy the constraints specified by this instance.

-
- -

9.1.4.  Boolean Object

- -

The “Boolean” object is the JSON schema implementation of the “Boolean” UML class defined in Clause 8.2.4. The schema for this class is provided in Boolean.json.

- -

The following snippet shows an example boolean component with an inline value:

- -
{
 
"type": "Boolean",
 
"definition": "http://sweet.jpl.nasa.gov/2.0/physDynamics.owl#Motion",
 
"label": "Motion Detected",
 
"description": "True when motion was detected in the room",
 
"value": true
}
- - -

The next snippet is an example of boolean component used as data descriptor, hence with no value:

- -
{
 
"type": "Boolean",
 
"definition": "http://mmisw.org/ont/q2o/test/timeContinuityTest",
 
"label": "Time Continuity Test",
 
"description": "Set to true to enable time continuity test"
}
- -
- -

9.1.5.  Text Object

- -

The “Text” object is the JSON schema implementation of the “Text” UML class defined in Clause 8.2.5. The schema for this class is provided in Text.json.

- -

Constraints on a “Text” representation are expressed using the AllowedTokens Object.

- -

The following snippets show how the “Text” component can be used to define human readable text fields, as well as any other alpha-numerical properties:

- -
{
 
"type": "Text",
 
"definition": "http://sensorml.com/ont/swe/property/Manufacturer",
 
"label": "Manufacturer",
 
"value": "Ocean Devices, Inc."
}
- - -
{
 
"type": "Text",
 
"definition": "http://sensorml.com/ont/x-swe/property/VehicleRegistrationNumber",
 
"label": "License Plate",
 
"value": "45ER-EJK-235"
}
- - -

Constraints can also be used — typically when the component is used as a descriptor — to limit the possible text values, either by enumeration or a regular expression pattern:

- -
{
 
"type": "Text",
 
"definition": "http://sensorml.com/ont/x-swe/property/VehicleRegistrationNumber",
 
"label": "License Plate",
 
"constraint": {
   
"pattern": "^[0-9][A-Z]{4}-[A-Z]{3}-[0-9]{3}$"
 
}
}
- - -

NOTE:    This standard does not define any limit on the size of the text data than can be included as the value of a “Text” component, either inline or as part of a datastream. Implementations are responsible for documenting this upper limit.

-
- -

9.1.6.  Category Object

- -

The “Category” object is the JSON schema implementation of the “Category” UML class defined in Clause 8.2.6. The schema for this class is provided in Category.json.

- -

Constraints on a “Category” representation are expressed using the AllowedTokens Object.

- -

The following examples illustrate how the “Category” component is used to define various fields with categorical representations. The categorical scale is defined either via a code space, an enumeration constraint, or both (in which case the enumeration constraint defines a subset of possible values from a code space):

- -
{
 
"type": "Category",
 
"definition": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#GeologicTime",
 
"label": "Geological Period",
 
"description": "Name of the geological period according to the nomenclature of the International Commission on Stratigraphy",
 
"codeSpace": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#Period",
 
"value": "Jurassic"
}
- - -
{
 
"type": "Category",
 
"definition": "http://sweet.jpl.nasa.gov/2.0/biol.owl#Species",
 
"label": "Bird Species",
 
"description": "Bird species according to the classification of the World Bird Database",
 
"codeSpace": "http://www.birdlife.org/datazone/species/index.html"
}
- -
- -

9.1.7.  Count Object

- -

The “Count” object is the JSON schema implementation of the “Count” UML class defined in Clause 8.2.7. The schema for this class is provided in Count.json.

- -

Constraints on a “Count” representation are expressed using the AllowedValues Object.

- -

The following snippet shows a “Count” component used to define the size of a row in a raster dataset:

- -
{
 
"type": "Count",
 
"definition": "http://www.opengis.net/def/property/OGC/0/NumberOfPixels",
 
"label": "Row Size",
 
"description": "Number of pixels in each row of the image",
 
"value": 1024
}
- -
- -

9.1.8.  Quantity Object

- -

The “Quantity” object is the JSON schema implementation of the “Quantity” UML class defined in Clause 8.2.8. The schema for this class is provided in Quantity.json.

- -

Constraints on a “Quantity” representation are expressed using the AllowedValues Object.

- -

The unit of measure is defined using either a URI or a code expressed using the Unified Code for Units of Measure (UCUM) standard.

- -

Requirement 58

Identifier/req/json-simple-components/ucum-code-used
Statement

Whenever it can be constructed using the UCUM specification, the unit of measure shall be specified using a UCUM code as the value of the “uom/code” property. Otherwise the “uom/href” property shall be used to reference an external unit definition.

- -

The following snippets show how “Quantity” components are used to define various (observable or controllable) properties with continuous decimal representations:

- -
{
 
"type": "Quantity",
 
"definition": "http://qudt.org/vocab/quantitykind/Temperature",
 
"label": "Outside Temperature",
 
"description": "Outside temperature taken at the top of the antenna",
 
"uom": { "code": "Cel" },
 
"value": 21.5
}
- - -
{
 
"type": "Quantity",
 
"definition": "http://sensorml.com/ont/swe/property/SpectralRadiance",
 
"label": "Radiance",
 
"description": "Radiance measured on band1",
 
"uom": { "code": "W.m-2.Sr-1.um-1" },
 
"value": 2.83e-2
}
- - -
{
 
"type": "Quantity",
 
"definition": "http://sensorml.com/ont/swe/property/HeightAboveMSL",
 
"referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/5714",
 
"axisID": "H",
 
"label": "MSL Height",
 
"description": "Height above mean sea level",
 
"uom": { "code": "m" }
}
- -
- -

9.1.9.  Time Object

- -

The “Time” object is the JSON schema implementation of the “Time” UML class defined in Clause 8.2.9. The schema for this class is provided in Time.json.

- -

Constraints on a “Time” representation are expressed using the AllowedTimes Object.

- -

The unit of measure is defined using either a URI or a code expressed using the Unified Code for Units of Measure (UCUM) standard. When the temporal property is provided in the ISO 8601:2019 format, this is indicated by using a specific URI.

- -

Requirement 59

Identifier/req/json-simple-components/iso8601-uom-used
Statement

When ISO 8601 notation is used to express the value associated to a “Time” element, the URI “http://www.opengis.net/def/uom/ISO-8601/0/Gregorian” shall be used as the value of the “uom/href” property.

- -

The following snippets show how “Time” components are used to define various temporal properties, with different time scales:

- -

ISO8601 formatted time stamp based on the UTC time standard:

- -
{
 
"type": "Time",
 
"definition": "http://www.opengis.net/def/property/OGC-EO/0/MissionStartTime",
 
"referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC",
 
"localFrame": "urn:org:systems:001#MISSION-START-TIME",
 
"label": "Flight Time",
 
"description": "Time at take-off in UTC",
 
"uom": {
   
"href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"
 
},
 
"value": "2009-01-26T10:21:45+01:00"
}
- - -

ISO8601 formatted time stamp based on the GPS time standard:

- -
{
 
"type": "Time",
 
"definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime",
 
"referenceFrame": "http://www.opengis.net/def/trs/USNO/0/GPS",
 
"label": "Sampling Time",
 
"description": "Time at which the measurement was made",
 
"uom": {
   
"href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"
 
},
 
"value": "2009-11-05T16:29:26Z"
}
- - -

Time stamp in seconds past the Unix epoch:

- -
{
 
"type": "Time",
 
"definition": "http://www.opengis.net/def/property/OGC/0/RunTime",
 
"referenceTime": "1970-01-01T00:00:00Z",
 
"label": "Model Run Time",
 
"description": "Run time of the model expressed as a Unix time",
 
"uom": {"code": "s" },
 
"value": 1257415633
}
- - -

Time stamp in seconds past a custom time reference called MISSION_START_TIME:

- -
{
 
"type": "Time",
 
"definition": "http://www.opengis.net/def/property/OGC-EO/0/ScanStartTime",
 
"referenceFrame": "urn:org:systems:001#MISSION-START-TIME",
 
"localFrame": "urn:org:systems:001#SCAN-START-TIME",
 
"label": "Scanline Time",
 
"description": "Acquisition time of the scan line",
 
"uom": { "code": "s" }
}
- -
- -

9.1.10.  CategoryRange Object

- -

The “CategoryRange” object is the JSON schema implementation of the “CategoryRange” UML class defined in Clause 8.2.11. The schema for this class is provided in CategoryRange.json.

- -

“CategoryRange” objects share most properties with “Category” object, as shown on the following snippet:

- -
{
 
"type": "CategoryRange",
 
"definition": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#GeologicTime",
 
"label": "Approximate Dating",
 
"description": "Approximate geological dating expressed as a range of geological eras",
 
"codeSpace": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#Era",
 
"value": ["Paleozoic", "Mesozoic"]
}
- -
- -

9.1.11.  CountRange Object

- -

The “CountRange” object is the JSON schema implementation of the “CountRange” UML class defined in Clause 8.2.12. The schema for this class is provided in CountRange.json.

- -

“CountRange” objects share most properties with “Count” object, as shown on the following snippet:

- -
{
 
"type": "CountRange",
 
"definition": "http://www.opengis.net/def/property/OGC/0/ArrayIndex",
 
"label": "Index Range",
 
"value": [0, 3000]
}
- -
- -

9.1.12.  QuantityRange Object

- -

The “QuantityRange” object is the JSON schema implementation of the “QuantityRange” UML class defined in Clause 8.2.13. The schema for this class is provided in QuantityRange.json.

- -

“QuantityRange” objects share most properties with the “Quantity” object, as shown on the following snippet:

- -
{
 
"type": "QuantityRange",
 
"definition": "http://mmisw.org/ont/mmi/device/OperationalRange",
 
"label": "Operational Range",
 
"description": "Operational temperature range of the cryogenic thermometer",
 
"uom": { "code": "K" },
 
"value": [10, 300]
}
- -
- -

9.1.13.  TimeRange Object

- -

The “TimeRange” object is the JSON schema implementation of the “TimeRange” UML class defined in Clause 8.2.14. The schema for this class is provided in TimeRange.json.

- -

“TimeRange” objects share most properties with the “Time” object, as shown on the following snippet:

- -
{
 
"type": "TimeRange",
 
"definition": "http://www.opengis.net/def/property/EO/0/SurveyPeriod",
 
"referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC",
 
"label": "Survey Period",
 
"uom": {
   
"href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"
 
},
 
"value": ["2008-01-05T11:02:54Z", "2009-11-05T16:29:26Z"]
}
- -
- -

9.1.14.  NilValues Object

- -

The “NilValues” object is the JSON schema implementation of the “NilValues” UML class defined in Clause 8.2.16. Schema patterns for this class are provided in basicTypes.json. Several sub-patterns are defined for the decimal, integer and text cases.

- -

Examples of NIL values definitions are provided below, in the case of numerical, countable and textual representations:

- -
{
 
"type": "Quantity",
 
"definition": "http://sweet.jpl.nasa.gov/2.0/physRadiation.owl#IonizingRadiation",
 
"label": "Radiation Dose",
 
"description": "Radiation dose measured by Gamma detector",
 
"uom": { "code": "uR" },
 
"nilValues": [
   
{ "reason": "http://www.opengis.net/def/nil/OGC/0/BelowDetectionRange", "value": "-Infinity" },
   
{ "reason": "http://www.opengis.net/def/nil/OGC/0/AboveDetectionRange", "value": "Infinity" }
 
]
}
- - -
{
 
"type": "Count",
 
"definition": "http://sweet.jpl.nasa.gov/2.0/physRadiation.owl#Radiance",
 
"label": "Band 1",
 
"nilValues": [
   
{ "reason": "http://www.opengis.net/def/nil/OGC/0/BelowDetectionRange", "value": 0 },
   
{ "reason": "http://www.opengis.net/def/nil/OGC/0/AboveDetectionRange", "value": 255 }
 
]
}
- - -
{
 
"type": "Text",
 
"definition": "http://sensorml.com/ont/x-swe/property/VehicleRegistrationNumber",
 
"label": "License Plate",
 
"nilValues": [
   
{ "reason": "http://www.opengis.net/def/nil/OGC/0/Missing", "value": "Missing" },
   
{ "reason": "http://www.opengis.net/def/nil/OGC/0/Unknown", "value": "Unknown" }
 
]
}
- -
- -

9.1.15.  AllowedTokens Object

- -

The “AllowedTokens” object is the JSON schema implementation of the “AllowedTokens” UML class defined in Clause 8.2.17. The schema for this class is provided in basicTypes.json (see #definitions/AllowedTokens).

- -

Examples of constraints for textual or categorical properties are provided below:

- -
{
 
"type": "Text",
 
"definition": "http://sensorml.com/ont/swe/property/ModelNumber",
 
"label": "Model Number",
 
"constraint": {
   
"pattern": "^[0-9][A-Z]{3}[0-9]{2}S1$"
 
}
}
- - -
{
 
"type": "Category",
 
"definition": "http://www.opengis.net/def/property/OGC/0/SensorStatus",
 
"label": "Sensor Status",
 
"description": "Current connection status of the sensor",
 
"constraint": {
   
"values": [ "Off", "Stand-by", "Ready", "Busy" ]
 
}
}
- -
- -

9.1.16.  AllowedValues Object

- -

The “AllowedValues” object is the JSON schema implementation of the “AllowedValues” UML class defined in Clause 8.2.18. The schema for this class is provided in basicTypes.json (see #definitions/AllowedValues).

- -

Examples of constraints for various numerical properties are provided below:

- -
{
 
"type": "Quantity",
 
"definition": "http://qudt.org/vocab/quantitykind/Angle",
 
"label": "Planar Angle",
 
"uom": { "code": "deg" },
 
"constraint": {
   
"intervals": [[-180, 180]]
 
}
}
- - -
{
 
"type": "Count",
 
"definition": "http://www.opengis.net/def/property/OGC/0/NumberOfPixels",
 
"label": "Image Width",
 
"constraint": {
   
"values": [256, 512, 1024]
 
}
}
- - -
{
 
"type": "Quantity",
 
"definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude",
 
"label": "Latitude",
 
"uom": { "code": "deg" },
 
"constraint": {
   
"intervals": [[-90, 90]],
   
"significantFigures": 6
 
}
}
- - -

Numerical constraints can also be unbounded:

- -
{
 
"type": "Quantity",
 
"definition": "http://qudt.org/vocab/quantitykind/RadialDistance",
 
"label": "Radial Distance",
 
"description": "Radial distance is always positive",
 
"uom": { "code": "m" },
 
"constraint": {
   
"intervals": [[0, "+Infinity"]]
 
}
}
- -
- -

9.1.17.  AllowedTimes Object

- -

The “AllowedTimes” object is the JSON schema implementation of the “AllowedTimes” UML class defined in Clause 8.2.19. The schema for this class is provided in basicTypes.json (see #definitions/AllowedTimes).

- -

Examples of constraints for various temporal properties, expressed as ISO-8601 or decimal values, are provided below:

- -
{
 
"type": "Time",
 
"definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime",
 
"referenceFrame": "http://www.opengis.net/def/trs/USNO/0/GPS",
 
"label": "Acquisition Time",
 
"uom": {
   
"href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"
 
},
 
"constraint": {
   
"intervals": [["2009-01-01T00:00:00Z", "+Infinity"]]
 
}
}
- - -
{
 
"type": "Time",
 
"definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime",
 
"referenceFrame": "urn:org:systems:001#SCAN-START-TIME",
 
"label": "Lidar Pulse Time",
 
"description": "Time stamp of LiDAR pulse relative to start of scan",
 
"uom": { "code": "ms" },
 
"constraint": {
   
"intervals": [[0, 1e6]]
 
}
}
- -
-

9.2.  Requirements Class: Record Components JSON Schema

- -

Requirements class 10: Record Components JSON Schema

Identifier/req/json-record-components
Target typeJSON Document
PrerequisitesRequirements class 3: /req/uml-record-components
Requirements class 9: /req/json-simple-components
- -

9.2.1.  DataRecord Object

- -

The “DataRecord” object is the JSON schema implementation of the “DataRecord” UML class defined in Clause 8.3.1. The schema for this class is provided in DataRecord.json.

- -

The example below describes a record composed of weather data fields. In this case the “DataRecord” element is used as a descriptor for records of data that are provided as part of a datastream:

- -
{
 
"type": "DataRecord",
 
"label": "Weather Data Record",
 
"fields": [
   
{
     
"name": "time",
     
"type": "Time",
     
"definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime",
     
"referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC",
     
"label": "Sampling Time",
     
"uom": {
       
"href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"
     
}
   
},
   
{
     
"name": "temperature",
     
"type": "Quantity",
     
"definition": "http://mmisw.org/ont/cf/parameter/air_temperature",
     
"label": "Air Temperature",
     
"uom": { "code": "Cel" }
   
},
   
{
     
"name": "pressure",
     
"type": "Quantity",
     
"definition": "http://mmisw.org/ont/cf/parameter/air_pressure_at_mean_sea_level",
     
"label": "Air Pressure",
     
"uom": { "code": "mbar" }
   
},
   
{
     
"name": "windSpeed",
     
"type": "Quantity",
     
"definition": "http://mmisw.org/ont/cf/parameter/wind_speed",
     
"label": "Wind Speed",
     
"uom": { "code": "km/h" }
   
},
   
{
     
"name": "windDirection",
     
"type": "Quantity",
     
"definition": "http://mmisw.org/ont/cf/parameter/wind_to_direction",
     
"label": "Wind Direction",
     
"uom": { "code": "deg" }
   
}
 
]
}
- - -
{
 
"type": "DataRecord",
 
"definition": "urn:x-ogc:def:property:CSM::RadialDistortionCoefficients",
 
"label": "Radial Distortion Coefficients",
 
"fields": [
   
{
     
"name": "k1",
     
"type": "Quantity",
     
"definition": "urn:x-ogc:def:property:CSM::DISTOR_RAD1",
     
"label": "Coef k1",
     
"uom": { "code": "mm-2" },
     
"value": 1.92709e-5
   
},
   
{
     
"name": "k2",
     
"type": "Quantity",
     
"definition": "urn:x-ogc:def:property:CSM::DISTOR_RAD2",
     
"label": "Coef k2",
     
"uom": { "code": "mm-2" },
     
"value": -5.14206e-10
   
},
   
{
     
"name": "k3",
     
"type": "Quantity",
     
"definition": "urn:x-ogc:def:property:CSM::DISTOR_RAD3",
     
"label": "Coef k3",
     
"uom": { "code": "mm-2" },
     
"value": -3.33356e-12
   
}
 
]
}
- -
- -

9.2.2.  Vector Object

- -

The “Vector” object is the JSON schema implementation of the “Vector” UML class defined in Clause 8.3.2. The schema for this class is provided in Vector.json.

- -
{
 
"type": "Vector",
 
"definition": "http://www.opengis.net/def/property/OGC/0/PlatformLocation",
 
"referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/4326",
 
"label": "Platform Location",
 
"coordinates": [
   
{
     
"name": "lat",
     
"type": "Quantity",
     
"definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude",
     
"label": "Latitude",
     
"axisID": "Lat",
     
"uom": { "code": "deg" },
     
"value": 45.36
   
},
   
{
     
"name": "lon",
     
"type": "Quantity",
     
"definition": "http://sensorml.com/ont/swe/property/Longitude",
     
"label": "Longitude",
     
"axisID": "Lon",
     
"uom": { "code": "deg" },
     
"value": 5.2
   
}
 
]
}
- - -
{
 
"type": "Vector",
 
"definition": "http://qudt.org/vocab/quantitykind/LinearVelocity",
 
"referenceFrame": "http://www.opengis.net/def/crs/OGC/0/ECI_J2000",
 
"label": "Platform Velocity",
 
"coordinates": [
   
{
     
"name": "vx",
     
"type": "Quantity",
     
"definition": "http://qudt.org/vocab/quantitykind/Speed",
     
"label": "Velocity X",
     
"uom": { "code": "m/s" }
   
},
   
{
     
"name": "vy",
     
"type": "Quantity",
     
"definition": "http://qudt.org/vocab/quantitykind/Speed",
     
"label": "Velocity Y",
     
"uom": { "code": "m/s" }
   
},
   
{
     
"name": "vz",
     
"type": "Quantity",
     
"definition": "http://qudt.org/vocab/quantitykind/Speed",
     
"label": "Velocity Z",
     
"uom": { "code": "m/s" }
   
}
 
]
}
- - -
{
 
"type": "Vector",
 
"definition": "http://sensorml.com/ont/swe/property/RotationQuaternion",
 
"referenceFrame": "http://www.opengis.net/def/crs/OGC/0/ECI_J2000",
 
"localFrame": "urn:org:systems:001#PLATFORM_FRAME",
 
"label": "Platform Orientation",
 
"coordinates": [
   
{
     
"name": "qx",
     
"type": "Quantity",
     
"definition": "http://sensorml.com/ont/swe/property/Coordinate",
     
"label": "QX",
     
"uom": { "code": "1" }
   
},
   
{
     
"name": "qy",
     
"type": "Quantity",
     
"definition": "http://sensorml.com/ont/swe/property/Coordinate",
     
"label": "QY",
     
"uom": { "code": "1" }
   
},
   
{
     
"name": "qz",
     
"type": "Quantity",
     
"definition": "http://sensorml.com/ont/swe/property/Coordinate",
     
"label": "QZ",
     
"uom": { "code": "1" }
   
},
   
{
     
"name": "qw",
     
"type": "Quantity",
     
"definition": "http://sensorml.com/ont/swe/property/Coordinate",
     
"label": "QW",
     
"uom": { "code": "1" }
   
}
 
]
}
- -
-

9.3.  Requirements Class: Choice Components JSON Schema

- -

Requirements class 11: Choice Components JSON Schema

Identifier/req/json-choice-components
Target typeJSON Document
PrerequisitesRequirements class 4: /req/uml-choice-components
Requirements class 9: /req/json-simple-components
- -

9.3.1.  DataChoice Object

- -

The “DataChoice” object is the JSON schema implementation of the “DataChoice” UML class defined in Clause 8.4.1. The schema for this class is provided in DataChoice.json.

- -
{
 
"type": "DataChoice",
 
"label": "Weather Data Message",
 
"items": [
   
{
     
"name": "TEMP",
     
"type": "DataRecord",
     
"label": "Temperature Measurement",
     
"fields": [
       
{
         
"name": "time",
         
"type": "Time",
         
"definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime",
         
"referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC",
         
"label": "Sampling Time",
         
"uom": {
           
"href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"
         
}
       
},
       
{
         
"name": "temp",
         
"type": "Quantity",
         
"definition": "http://mmisw.org/ont/cf/parameter/air_temperature",
         
"label": "Air Temperature",
         
"uom": { "code": "Cel" }
       
}
     
]
   
},
   
{
     
"name": "PRESS",
     
"type": "DataRecord",
     
"label": "Pressure Measurement",
     
"fields": [
       
{
         
"name": "time",
         
"type": "Time",
         
"definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime",
         
"referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC",
         
"label": "Sampling Time",
         
"uom": {
           
"href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"
         
}
       
},
       
{
         
"name": "press",
         
"type": "Quantity",
         
"definition": "http://mmisw.org/ont/cf/parameter/air_pressure_at_mean_sea_level",
         
"label": "Air Pressure",
         
"uom": { "code": "HPa" }
       
}
     
]
   
}
 
]
}
- -
-

9.4.  Requirements Class: Block Components JSON Schema

- -

Requirements class 12: Block Components JSON Schema

Identifier/req/json-block-components
Target typeJSON Document
PrerequisitesRequirements class 5: /req/uml-block-components
Requirements class 9: /req/json-simple-components
- -

9.4.1.  DataArray Object

- -

The “DataArray” element is the JSON schema implementation of the “DataArray” UML class defined in Clause 8.5.1. The schema for this class is provided in DataArray.json.

- -
{
 
"type": "DataArray",
 
"label": "Calibration Table",
 
"elementType": {
   
"name": "point",
   
"type": "DataRecord",
   
"label": "Data Point",
   
"fields": [
     
{
       
"name": "t",
       
"type": "Quantity",
       
"definition": "https://qudt.org/vocab/quantitykind/Temperature",
       
"label": "Temperature",
       
"uom": { "code": "Cel" }
     
},
     
{
       
"name": "r",
       
"type": "Quantity",
       
"definition": "https://qudt.org/vocab/quantitykind/Resistance",
       
"label": "Resistance",
       
"uom": { "code": "KOhm" }
     
}
   
]
 
},
 
"values": [
   
{"t": 12, "r": 3.03},
   
{"t": 30.1, "r": 1.68},
   
{"t": 40.0, "r": 1.16},
   
{"t": 50.1, "r": 0.85},
   
{"t": 59.8, "r": 0.62}
 
]
}
- - -

When provided inline, “DataArray” values are encoded using the method defined in Clause 9.4.4.

- -

The following example shows how to define a 1D variable size array whose data is provided separately.

- -
{
 
"type": "DataArray",
 
"definition": "http://sensorml.com/ont/swe/property/Trajectory",
 
"label": "Mobile Trajectory",
 
"elementCount": {
   
"definition": "http://www.opengis.net/def/property/OGC/0/NumberOfPoints",
   
"label": "Implicit Size"
 
},
 
"elementType": {
   
"name": "point",
   
"type": "Vector",
   
"definition": "http://www.opengis.net/def/property/OGC/0/PlatformLocation",
   
"referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/4326",
   
"label": "Location Point",
   
"coordinates": [
     
{
       
"name": "lat",
       
"type": "Quantity",
       
"definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude",
       
"label": "Latitude",
       
"axisID": "Lat",
       
"uom": { "code": "deg" }
     
},
     
{
       
"name": "lon",
       
"type": "Quantity",
       
"definition": "http://sensorml.com/ont/swe/property/Longitude",
       
"label": "Longitude",
       
"axisID": "Lon",
       
"uom": { "code": "deg" }
     
}
   
]
 
}
}
- - -

“DataArray” components can also be nested to form multi-dimensional arrays, as shown in the following example of a 2D array:

- -
{
 
"type": "DataArray",
 
"definition": "http://sensorml.com/ont/swe/property/RasterImage",
 
"label": "Satellite Image",
 
"elementCount": {
   
"definition": "http://www.opengis.net/def/property/OGC/0/NumberOfRows",
   
"value": 3000
 
},
 
"elementType": {
   
"name": "row",
   
"type": "DataArray",
   
"definition": "http://sensorml.com/ont/swe/property/RasterImage",
   
"elementCount": {
     
"definition": "http://www.opengis.net/def/property/OGC/0/NumberOfSamples",
     
"value": 3000
   
},
   
"elementType": {
     
"name": "pixel",
     
"type": "DataRecord",
     
"definition": "http://sensorml.com/ont/swe/property/GridCell",
     
"fields": [
       
{
         
"name": "band1",
         
"type": "Quantity",
         
"definition": "http://qudt.org/vocab/quantitykind/Radiance",
         
"label": "Radiance",
         
"description": "Radiance measured on band1",
         
"uom": { "code": "W.m-2.Sr-1" }
       
},
       
{
         
"name": "band2",
         
"type": "Quantity",
         
"definition": "http://qudt.org/vocab/quantitykind/Radiance",
         
"label": "Radiance",
         
"description": "Radiance measured on band2",
         
"uom": { "code": "W.m-2.Sr-1" }
       
},
       
{
         
"name": "band3",
         
"type": "Quantity",
         
"definition": "http://qudt.org/vocab/quantitykind/Radiance",
         
"label": "Radiance",
         
"description": "Radiance measured on band3",
         
"uom": { "code": "W.m-2.Sr-1" }
       
}
     
]
   
}
 
}
}
- -
- -

9.4.2.  Matrix Object

- -

The “Matrix” object is the JSON schema implementation of the “Matrix” UML class defined in Clause 8.5.2. The schema for this class is provided in Matrix.json.

- -
{
 
"type": "Matrix",
 
"definition": "http://sensorml.com/ont/swe/property/RotationMatrix",
 
"referenceFrame": "http://www.opengis.net/def/crs/OGC/0/ECI_J2000",
 
"label": "3D Orientation Matrix",
 
"elementType": {
   
"name": "row",
   
"type": "Matrix",
   
"elementType": {
     
"name": "coef",
     
"type": "Quantity",
     
"definition": "http://sensorml.com/ont/swe/property/Coordinate",
     
"label": "Matrix Coef",
     
"uom": { "code": "1" }
   
}
 
},
 
"values": [
   
[0.36,0.48,-0.8],
   
[-0.8,0.6,0],
   
[0.48,0.64,0.6]
 
]
}
- - -

When provided inline, “Matrix” values are encoded using the method defined in Clause 9.4.4.

-
- -

9.4.3.  DataStream Object

- -

The “DataStream” object is the JSON schema implementation of the “DataStream” UML class defined in Clause 8.5.3. The schema for this class is provided in DataStream.json.

- -
{
 
"type": "DataStream",
 
"label": "Aircraft Navigation",
 
"elementType": {
   
"name": "navData",
   
"type": "DataRecord",
   
"fields": [
     
{
       
"type": "Time",
       
"definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime",
       
"referenceFrame": "http://www.opengis.net/def/trs/USNO/0/GPS",
       
"referenceTime": "1970-01-01T00:00:00Z",
       
"label": "Sampling Time",
       
"uom": { "code": "s" }
     
},
     
{
       
"name": "location",
       
"type": "Vector",
       
"definition": "http://www.opengis.net/def/property/OGC/0/PlatformLocation",
       
"referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/4979",
       
"label": "Platform Location",
       
"coordinates": [
         
{
           
"name": "lat",
           
"type": "Quantity",
           
"definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude",
           
"label": "Latitude",
           
"axisID": "Lat",
           
"uom": { "code": "deg" }
         
},
         
{
           
"name": "lon",
           
"type": "Quantity",
           
"definition": "http://sensorml.com/ont/swe/property/Longitude",
           
"label": "Longitude",
           
"axisID": "Lon",
           
"uom": { "code": "deg" }
         
},
         
{
           
"name": "alt",
           
"type": "Quantity",
           
"definition": "http://sensorml.com/ont/swe/property/HeightAboveEllipsoid",
           
"label": "Altitude",
           
"axisID": "h",
           
"uom": { "code": "m" }
         
}
       
]
     
},
     
{
       
"name": "attitude",
       
"type": "Vector",
       
"definition": "http://www.opengis.net/def/property/OGC/0/PlatformOrientation",
       
"referenceFrame": "http://www.opengis.net/def/cs/OGC/0/ENU",
       
"label": "Platform Attitude",
       
"coordinates": [
         
{
           
"name": "heading",
           
"type": "Quantity",
           
"definition": "http://sensorml.com/ont/swe/property/TrueHeading",
           
"label": "Heading",
           
"axisID": "Z",
           
"uom": { "code": "deg" }
         
},
         
{
           
"name": "pitch",
           
"type": "Quantity",
           
"definition": "http://sensorml.com/ont/swe/property/PitchAngle",
           
"label": "Pitch",
           
"axisID": "X",
           
"uom": { "code": "deg" }
         
},
         
{
           
"name": "roll",
           
"type": "Quantity",
           
"definition": "http://sensorml.com/ont/swe/property/RollAngle",
           
"label": "Roll",
           
"axisID": "Y",
           
"uom": { "code": "deg" }
         
}
       
]
     
}
   
]
 
},
 
"encoding": {
   
"type": "TextEncoding",
   
"tokenSeparator": ",",
   
"blockSeparator": "\n",
   
"decimalSeparator": "."
 
}
}
- - -

When provided inline, “DataStream” values are encoded using the method defined in Clause 9.4.4.

-
- -

9.4.4.  Inline Value Blocks

- -

This clause specifies how inline vaues for “DataArray”, “Matrix” and “DataStream” components shall be encoded when provided within a JSON document. No other method is allowed within a JSON document compliant with this standard.

- -

However, when values are provided separately from the component description (e.g. when datastream values are provided separately), any encoding methods defined in Clause 10 can be used.

- -

Inline block component values shall always be wrapped using JSON Arrays.

-
-

9.5.  Requirements Class: Geometry Components JSON Schema

- -

Requirements class 13: Geometry Components JSON Schema

Identifier/req/json-geom-components
Target typeJSON Document
PrerequisitesRequirements class 6: /req/uml-geom-components
Requirements class 9: /req/json-simple-components
- -

9.5.1.  Geometry Object

- -

The “Geometry” object is the XML schema implementation of the “Geometry” UML class defined in Clause 8.6.1. The schema for this class is provided in Geometry.json.

- -
{
 
"type": "Geometry",
 
"definition": "http://sensorml.com/ont/swe/property/TargetLocation",
 
"srs": "http://www.opengis.net/def/crs/EPSG/0/4326",
 
"label": "Target Location",
 
"description": "A point geometry",
 
"value": {
   
"type": "Point",
   
"coordinates": [12.34, 56.36]
 
}
}

{
 
"type": "Geometry",
 
"definition": "http://sensorml.com/ont/swe/property/Trajectory",
 
"srs": "http://www.opengis.net/def/crs/EPSG/0/4326",
 
"label": "Desired Trajectory",
 
"description": "Desired UxS trajectory defined as a line string",
 
"value": {
   
"type": "LineString",
   
"coordinates": [[12.34, 56.36], [12.45, 56.37], [12.45, 56.39], [12.34, 56.36]]
 
}
}

{
 
"type": "Geometry",
 
"definition": "http://sensorml.com/ont/x-swe/property/SurveillanceArea",
 
"srs": "http://www.opengis.net/def/crs/EPSG/0/4326",
 
"label": "Surveillance Area",
 
"description": "Desired UxS surveillance area defined as a polygon",
 
"value": {
   
"type": "Polygon",
   
"coordinates": [
     
[[12.34, 56.36], [12.45, 56.37], [12.45, 56.39], [12.34, 56.36]]
   
]
 
}
}
- -
-

9.6.  Requirements Class: Simple Encodings JSON Schema

- -

Requirements class 14: Simple Encodings JSON Schema

Identifier/req/json-simple-encodings
Target typeJSON Document
PrerequisitesRequirements class 14: /req/json-simple-encodings
Requirements class 18: /req/text-encoding-rules
Requirements class 17: /req/json-encoding-rules
- -

Validation patterns that implement classes defined respectively in the “Simple Encodings” UML packages are provided in the JSON schema encodings.json.

- -

When datastream or data array values are provided out-of-band (i.e. not inline in the “DataArray”, “Matrix” or “DataStream” description), a different encoding than JSON can be selected. This is specified by using one of the following classes.

- -

9.6.1.  TextEncoding Object

- -

The “TextEncoding” object is the JSON schema implementation of the “TextEncoding” UML class defined in Clause 8.7.1. The schema for this class is provided in encodings.json#/definitions/TextEncoding.

- -
{
 
"type": "TextEncoding",
 
"tokenSeparator": ",",
 
"blockSeparator": "\n",
 
"decimalSeparator": "."
}
- -
-

9.7.  Requirements Class: Advanced Encodings JSON Schema

- -

Requirements class 15: Advanced Encodings JSON Schema

Identifier/req/json-advanced-encodings
Target typeJSON Document
PrerequisitesRequirements class 8: /req/uml-advanced-encodings
Requirements class 14: /req/json-simple-encodings
Requirements class 19: /req/binary-encoding-rules
- -

This requirement class defines an additional encoding method that can be used to encode data values as raw or base64 binary blocks.

- -

9.7.1.  BinaryEncoding Object

- -

The “BinaryEncoding” object is the JSON schema implementation of the “BinaryEncoding” UML class defined in Clause 8.8.1. The schema for this class is provided in encondings.json#/definitions/BinaryEncoding.

- -

-
-

These elements allow for the detailed specification of the encoding parameters associated to components of the data description tree as discussed in Clause 8.8.1. The “ref” attribute takes a value of a particular syntax that allows pointing to any data component. The syntax is a ‘/’ separated list of component names, starting with the name of the root component and listed hierarchically. Each of these component names shall match the value of the “name” attribute defined in the data definition tree.

- -

Requirement 60

Identifier/req/xsd-advanced-encodings/ref-syntax-valid
Statement

The “ref” attribute of the “Component” and “Block” elements shall contain a hierarchical ‘/’ separated list of data component names.

- -

The “ref” attribute used on the “Component” element shall point exclusively to a scalar component.

- -

Requirement 61

Identifier/req/xsd-advanced-encodings/scalar-ref-component-valid
Statement

The “ref” attribute of a “Component” element shall reference a scalar or range component.

- -

This standard defines the list of data types that are allowed for scalar values when encoded with the binary encoding method. The corresponding URIs listed below shall be used as the value of the datatype attribute of an instance of the “Component” element.

- -

Requirement 62

Identifier/req/xsd-advanced-encodings/datatype-valid
Statement

The value of the “dataType” XML attribute of the “Component” element shall be one of the URIs listed in Table 1.

- -

These data types are specified in the normative table below:

- -

Table 1 — Allowed Binary Data Types

Common NameURI to use in “dataType” attributeDescription
Signed Bytehttp://www.opengis.net/def/dataType/OGC/0/signedByte8-bits signed binary integer.
- Range: −128 to +127
Unsigned Bytehttp://www.opengis.net/def/dataType/OGC/0/unsignedByte8-bits unsigned binary integer.
- Range: 0 to +255
Signed Shorthttp://www.opengis.net/def/dataType/OGC/0/signedShort16-bits signed binary integer.
- Range: −32,768 to +32,767
Unsigned Shorthttp://www.opengis.net/def/dataType/OGC/0/unsignedShort16-bits unsigned binary integer.
- Range: 0 to +65,535
Signed Inthttp://www.opengis.net/def/dataType/OGC/0/signedInt32-bits signed binary integer.
- Range: −2,147,483,648 to +2,147,483,647
Unsigned Inthttp://www.opengis.net/def/dataType/OGC/0/unsignedInt32-bits unsigned binary integer.
- Range: 0 to +4,294,967,295
Signed Longhttp://www.opengis.net/def/dataType/OGC/0/signedLong64-bits signed binary integer.
- Range: −263 to +263 — 1
Unsigned Longhttp://www.opengis.net/def/dataType/OGC/0/unsignedLong64-bits unsigned binary integer.
- Range: 0 to +264 — 1
Half Precision - Floathttp://www.opengis.net/def/dataType/OGC/0/float1616-bits single precision floating point number as defined in IEEE 754.
Floathttp://www.opengis.net/def/dataType/OGC/0/float3232-bits single precision floating point number as defined in IEEE 754.
Doublehttp://www.opengis.net/def/dataType/OGC/0/double or
- http://www.opengis.net/def/dataType/OGC/0/float64
64-bits double precision floating point number as defined in IEEE 754.
Long Doublehttp://www.opengis.net/def/dataType/OGC/0/float128128-bits quadruple precision floating point number as defined in IEEE 754.
UTF-8 String
- (Variable Length)
http://www.opengis.net/def/dataType/OGC/0/string-utf-8
- “byteLength” attribute is not set.
Variable length string composed of a 2-bytes unsigned short value indicating its length followed by a sequence of UTF-8 encoded characters as specified by the Unicode Standard (2.5).
UTF-8 String*
- (Fixed Length)
http://www.opengis.net/def/dataType/OGC/0/string-utf-8
- “byteLength” attribute is set.
Fixed length string composed of a sequence of UTF-8 encoded characters as specified by the Unicode Standard (2.5), and padded with 0 characters.
- -

The data type should be chosen so that its range allows the encoding of all possible values for a field (i.e. compatible with the field representation and constraints) including NIL values. This means that certain combinations of data type and components are not allowed. If a scalar component does not specify any constraint, any data type compatible with its representation can be used and it is the responsibility of the implementation to insure that all future values for the component will “fit” in the data type.

- -

Requirement 63

Identifier/req/xsd-advanced-encodings/datatype-compatible
Statement

The chosen data type shall be compatible with the scalar component representation, constraints and NIL values.

- -

Only data types marked with an asterisk allow the usage of the “byteLength” or “bitLength” attribute to customize their size. Usage of these attributes is forbidden on all other data types since their size is fixed and already specified in this standard (in the case of a variable length string, the size is included in the stream). This is enforced by a Schematron pattern.

- -

Requirement 64

Identifier/req/xsd-advanced-encodings/no-datatype-length
Statement

The “bitLength” and “byteLength” XML attributes shall not be set when a fixed size data type is used.

- -

The value of the “byteEncoding” XML attribute allows the selection of either the ‘raw’ or ‘base64’ encoding methods. When ‘base64’ is selected each byte is converted to its base 64 representation before it is included in encoded block, making it possible to include the values directly inline in the XML instance.

- -

The following binary encoded image data illustrates how the BinaryEncoding element is used to specify encoding options to each scalar value in the dataset:

-
-

10.  Data Blocks and Streams Encoding Rules (normative)

10.1.  Requirements Class: General Encoding Rules

- -

Requirements class 16: General Encoding Rules

Identifier/req/general-encoding-rules
Target typeEncoded Values Instance
Conformance classConformance class A.8: /conf/general-encoding-rules
Indirect prerequisiteRequirements class 7: /req/uml-simple-encodings
- -

All encodings defined in this standard follow general principles so that it is possible to implement them in a similar way.

- -

The way values are encoded is linked to the data structure specified using a hierarchy of data components. The values are included sequentially in the data stream by recursively processing all data components composing the dataset definition tree.

- -

10.1.1.  Rules for Scalar Components

- -

The value of each scalar component is encoded as a single scalar value. The actual binary representation of this scalar value depends on the encoding method. For example, in “TextEncoding”, a numerical value is represented by its string representation that usually span several bytes (e.g. ‘1.2345’ spans 6 bytes), why with the “BinaryEncoding” encode a similar value would likely be encoded as an IEEE 754 single precision floating-point format.

- -

The value of a “Time” component is encoded either as a decimal value or as a string in the case where a calendar representation or indeterminate value is used.

- -

When the value of a scalar component is NIL, the appropriate nil value is used in the stream and replaces the actual measurement value. This is always possible because nil values are required to be expressed with a data type that is compatible with the representation of the corresponding field.

-
- -

10.1.2.  Rules for Range Components

- -

The values of range components are encoded as a sequence of two successive values, first the lower bound of the range, then the upper bound. Each of these values is encoded exactly like the values of scalar components.

-
- -

10.1.3.  Rules for DataRecord and Vector

- -

Both “DataRecord” and “Vector” components are aggregates consisting of an ordered sequence of child components. The values contained in these aggregates are encoded by successively encoding each child component in the order in which they are listed in the XML description and including the resulting values sequentially in the stream.

- -

The definition of a “DataRecord” (or “Vector”) structure composed of N fields (or coordinates for vectors) can be represented in the following way:

- -
- -

The data block corresponding to such a structure would sequentially include all values for field 1, then all values for field 2, etc. until the last field is reached. Each field may consist of a single value if it is a scalar but may also consist of multiple values if it is itself an aggregate or a range component.

- -

Requirement 65

Identifier/req/general-encoding-rules/record-encoding-rule
Statement

“DataRecord” fields or “Vector” coordinates shall be encoded sequentially in a data block in the order in which these fields or coordinates are listed in the data descriptor.

-
- -

10.1.4.  Rules for DataChoice

- -

The “DataChoice” is an aggregate consisting of a choice of several child components called items. When values of a data choice are encoded, the resulting data block consists of two things: A token identifying the selecting item and the item values themselves. Only values of a single item can be encoded in each instance of a choice.

- -
- -

The data block corresponding to such a structure would then sequentially include the item identifier (i.e. the choice value) and then the value(s) for the selected item. The item may consist of a single value if it is a scalar or multiple values if it is itself an aggregate or a range component.

- -

Requirement 66

Identifier/req/general-encoding-rules/choice-encoding-rule
Statement

Encoded values for the selected item of a “DataChoice” shall be provided along with information that unambiguously identifies the selected item.

-
- -

10.1.5.  Rules for DataArray and Matrix

- -

The “DataArray” is an aggregate consisting of a number of repeated elements, all of the same type as defined by the element type. Values contained by a “DataArray” are encoded by sequentially including the values of each element.

- -

The definition of a “DataArray” (“Matrix”) structure composed of the array dimension and size and the element type definition. This can be represented in the following way:

- -
- -

The data block corresponding to such a structure would sequentially include the number representing the array size (only if it is variable) followed by one or more values corresponding to each array element. The number of values encoded for each element depends only on the array element definition, and the total number of values also depends on the array size.

- -

Requirement 67

Identifier/req/general-encoding-rules/array-encoding-rule
Statement

“DataArray” elements shall be encoded sequentially in a data block in the order of their index in the array (i.e. from low to high index).

- -

Requirement 68

Identifier/req/general-encoding-rules/array-size-encoding-rule
Statement

Encoded data for a variable size “DataArray” shall include a number specifying the array size whatever the encoding method used.

-
-

10.2.  Requirements Class: JSON Encoding Rules

- -

Requirements class 17: JSON Encoding Rules

Identifier/req/json-encoding-rules
Target typeEncoded Values Instance
PrerequisiteRequirements class 16: /req/general-encoding-rules
Indirect prerequisiteRequirements class 7: /req/uml-simple-encodings
- -

The “JSON Encoding” method encodes field values by their JSON representation.

- -

Requirement 69

Identifier/req/json-encodings-rules/json-valid
Statement

Data blocks and datastreams encoded using the JSON Encoding rules shall be valid JSON documents as defined by IETF RFC 8259.

- -

The encoding rules defined in this document refer to JSON data types defined by IETF RFC 8259. Their definitions are recalled below:

- -

JSON Object: An object structure is represented as a pair of curly brackets surrounding zero or more name/value pairs (or members). Members are separated by commas. Each member must have a distinct name.

- -

JSON Array: An array structure is represented as square brackets surrounding zero or more values (or elements). Elements are separated by commas.

- -

JSON Number: A decimal or integer number represented in base 10, with a sign and optional exponent.

- -

JSON String: A string of Unicode characters that begins and ends with quotation marks.

- -

10.2.1.  Rules for Scalar Components

- -

Scalar components are encoded as specified in Table 2. Special numerical values allowed for “Quantity” and “Time” components are defined in Clause 9.1.2.

- -

Requirement 70

Identifier/req/json-encoding-rules/scalar-value-valid
Statement

The value of a scalar component shall be represented using a JSON Number, a JSON String, or a boolean literal value, as defined in Table 2.

- -

Table 2 — Simple Component to JSON Value Types Mapping

Component TypeJSON Value TypeExamples
BooleanBoolean literaltrue
- false
TextJSON String"word"
- "a full sentence"
- "BYC-589-AA"
CategoryJSON String"ON"
- "Paleozoic"
- "diesel"
CountJSON Number12
- 0
QuantityJSON Number, or
- JSON String with special numerical value.
12
- 23.1
- "NaN"
- "-Infinity"
- "+Infinity"
TimeJSON String with a ISO8601 date/time string, or - JSON Number, or
- JSON String with special numerical value.
"2023-03-15T12:45:56Z"
- -23.1
- 12
- "NaN"
- "-Infinity"
- "+Infinity"
-
- -

10.2.2.  Rules for Range Components

- -

A range component is encoded using a JSON array of two values.

- -

Requirement 71

Identifier/req/json-encoding-rules/range-value-valid
A

Values of range components shall be wrapped in a JSON Array with exactly 2 scalar values.

-
B

Each value is encoded in the same manner as the corresponding scalar component as defined in Table 2.

-
- -

Table 3 — Range Component to JSON Mapping

Component TypeExamples
CategoryRange["Cenozoic", "Paleozoic"]
CountRange[0, 12]
QuantityRange[-12, 35]
- [-180.0, 180.0]
- ["-Infinity", 0.0]
- [10.0, "+Infinity"]
- ["NaN", "NaN"]
TimeRange["2023-01-01T00:00:00Z", "2023-03-15T12:45:56Z"]
- ["2023-01-01T00:00:00Z", "+Infinity"]
- ["-Infinity", "2023-01-01T00:00:00Z"]
- ["2023-01-01T00:00:00Z", "+Infinity"]
- ["NaN", "NaN"]
-
- -

10.2.3.  Rules for DataRecord and Vector

- -

“DataRecord” components are encoded using a JSON Object whose members are named like the record fields.

- -

Requirement 72

Identifier/req/json-encoding-rules/record-object-valid
A

“DataRecord” values shall be wrapped in a JSON Object.

-
B

The name of the JSON object members shall be the same as the “DataRecord” field names.

-
C

The value of each JSON Object member shall be chosen by following the encoding rules of the data component used as the record field with the same name.

-
D

If a record field is marked as ‘optional’, the corresponding JSON object member can be omitted or its JSON value can be set to null.

-
- -

Requirement 73

Identifier/req/json-encoding-rules/vector-object-valid
A

“Vector” values shall be wrapped in a JSON Object.

-
B

The name of the JSON object members shall be the same as the “Vector” coordinate names.

-
C

The value of each JSON Object member shall be chosen by following the encoding rules of the data component used as the vector coordinate field with the same name.

-
- -

When a field has its ‘optional’ flag set to true, its value can be either omitted or set to the literal value null.

- -

See the following examples:

- - -
- -

10.2.4.  Rules for DataChoice

- -

Values of “DataChoice” components are encoded using a JSON Object with a single member whose name is the name of the selected choice item.

- -

Requirement 74

Identifier/req/json-encoding-rules/choice-object-valid
A

“DataChoice” values shall be encapsulated in a JSON Object.

-
B

The JSON object shall contain a single member whose name is the same as the selected choice item.

-
C

The JSON value of this unique member shall be chosen according to the encoding rules of the data component corresponding to the selected item.

-
- -

See example: Datastream with choice (navigation data)

-
- -

10.2.5.  Rules for DataArray and Matrix

- -

Values of “DataArray” and “Matrix” components are encoded using a JSON Array, containing as many elements as there are elements in the Array component.

- -

Requirement 75

Identifier/req/json-encoding-rules/array-values-valid
A

“DataArray” and “Matrix” values shall be encapsulated in a JSON Array.

-
B

Each array element shall be encoded using the rules corresponding to the data component used as the array element type.

-
- -

See the following examples:

- - -
- -

10.2.6.  Rules for Geometry

- -

The value of a “Geometry” component is encoded using a GeoJSON Geometry object.

- -

Requirement 76

Identifier/req/json-encodings-rules/geometry-valid
A

The value of a “Geometry” component shall be encoded as a GeoJSON Geometry Object, following rules defined by IETF RFC 7946.

-
B

The allowed GeoJSON geometry types shall be restricted to: Point, LineString, Polygon, MultiPoint, MultiLineString, and MultiPolygon

-
C

The number of dimensions of the GeoJSON geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component.

-
- -

See example: Datastream with geometry (feature detection)

-
- -

10.2.7.  JSON Schema

- -

In order to maximize compatibility with existing tools, A JSON Schema can be easily auto-generated from the Datastream description.

-
- -

10.2.8.  Media Types

- -

When array or datastream values are encoded with the JSON encoding method and provided standalone (i.e. outside of any wrapper format), one of the following media type identifiers shall be used:

- -
  1. One of application/json or application/swe+json shall be used as the content-type for files and HTTP reponses.

    -
  2. -
  3. application/swe+json shall be used for format negotiation between server and client (e.g. when the format is advertised by an API or web service). In particular, this media type shall be used in HTTP Accept and Link headers and in any server response used to advertise support or link to a resource encoded with this format.

    -
  4. -
- -

alternative would be application/vnd.ogc.swe+json

-
-

10.3.  Requirements Class: Text Encoding Rules

- -

Requirements class 18: Text Encoding Rules

Identifier/req/text-encoding-rules
Target typeEncoded Values Instance
Conformance classConformance class A.9: /conf/text-encoding-rules
PrerequisiteRequirements class 16: /req/general-encoding-rules
Indirect prerequisiteRequirements class 7: /req/uml-simple-encodings
- -

The “TextEncoding” method encodes field values (especially numbers) by their text representation. Special characters provide a way to separate successive values and successive blocks. The ABNF syntax defined in IETF RFC 5234 is used to formalize the encoding rules, and thus all ABNF snippets provided in this section are normative.

- -

Requirement 77

Identifier/req/text-encodings-rules/abnf-syntax-valid
Statement

The encoded values block shall be formatted as defined by the ABNF grammar defined in this clause.

- -

10.3.1.  Separators

- -

Token separators are used between single values and the block separator is used at the end of each block. The block corresponds to one element of the “DataArray” or “DataStream” carrying the “values” element in which the values are encoded. There are no special separators to delimitate nested records, arrays and choices.

- -

Separators shall be chosen so that nothing in the dataset contains the exact same character sequence as the one chosen for token or block separator.

- -

Requirement 78

Identifier/req/text-encodings-rules/separators-valid
Statement

Block and token separators used in the “TextEncoding” method shall be chosen as a sequence of characters that never occur in the data values themselves.

- -

When the attribute “collapseWhiteSpaces” is set to true (its default value), all white space characters surrounding the token and block separators shall be ignored. The BNF grammar for separators is given below:

- -
white-space = %d9 / %d10 / %d13 / %d32 ; TAB, LF, CR or SPACE

token-separator-chars = < Value of the tokenSeparator attribute >

block-separator-chars = < Value of the blockSeparator attribute >

token-separator = [white-space] token-separator-chars [white-space]

block-separator = [white-space] block-separator-chars [white-space]
- - -

White spaces around separators are in fact only allowed when the “collapseWhiteSpaces” attribute is set to ‘true’ (which is the default).

-
- -

10.3.2.  Rules for Scalar Components

- -

The value for a scalar component is encoded as its text representation, following XML schema datatypes conventions.

- -
scalar-value = xs:bool / xs:string / xs:double / xs:int / xs:date / xs:dateTime
- - -

Nil values are included in the stream just like normal scalar values. Since their data type has to match the field data type, there is no special treatment necessary for a decoder or encoder. It is the responsibility of the application to match the data value against the list of registered nil values for a given field in order to detect if it is associated to a nil reason or if it is an actual measurement value.

-
- -

10.3.3.  Rules for Range Components

- -

Range components are encoded as a sequence of two tokens (each one representing a scalar value) separated by a token separator:

- -
min-value = scalar-value

max-value = scalar-value

range-values = min-value token-separator max-value
- -
- -

10.3.4.  Rules for DataRecord and Vector

- -

Values of fields of a “DataRecord” are recursively encoded following rules associated to the type of component used for the field’s description (i.e. scalar, record, array, etc.) and separated by token separators as expressed by the following grammar:

- -
field-count = < Number of fields in the record minus one. Greater or equal to 0 >

any-field-value = scalar-value / range-values / record-values / choice-values / array-values

mandatory-field-value = any-field-value

optional-field-value = (“Y” token-separator any-field-value) / “N”

field-value = mandatory-field-value / optional-field-value

record-values = field-value <field-count>*(token-separator field-value)
- - -

When a field is marked as optional in the definition, the token ‘Y’ or ‘N’ shall be inserted in the data block. When the field value is omitted, the token ‘N’ is inserted alone. When it is included, the token ‘Y’ is inserted followed by the actual field value.

- -

Requirement 79

Identifier/req/text-encodings-rules/optional-field-marker-present
Statement

The ‘Y’ or ‘N’ token shall be inserted in a text encoded data block for all fields that have the “optional” attribute set to ‘true’.

- -

Coordinate values of “Vector” components are encoded with a similar syntax, but a coordinate value can only be scalar and cannot be omitted:

- -
coord-count = < Number of coordinates in the vector minus one. Greater or equal to 0 >

vector-values = scalar-value <coord-count>*(token-separator scalar-value)
- - -

See the following examples:

- - -
- -

10.3.5.  Rules for DataChoice

- -

A “DataChoice” is encoded with the text method by providing the name of the selected item before the item values themselves. The name used shall correspond to the “name” attribute of the “item” property element that describes the structure of the selected item.

- -
selected-item-name = < Value of the “name” attribute of the item selected >
selected-item-values = scalar-value / range-values / record-values / choice-values / array-values
choice-values = selected-item-name token-separator selected-item-values
- - -

Requirement 80

Identifier/req/text-encodings-rules/choice-selection-marker-valid
Statement

The selected-item-name token shall correspond to the value of the “name” attribute of the “item” property element that represents the selected item.

- -

See example: Datastream with choice (navigation data).

-
- -

10.3.6.  Rules for DataArray and Matrix

- -

Values of each “DataArray” or “Matrix” element are recursively encoded following rules associated to the type of component used for the element type (i.e. scalar, record, array, etc.). Groups of values (or single value in the case of a scalar element type) corresponding to each element are sequentially appended to the data block and separated by token or block separators, depending on the context: When the “DataArray” is the root of the component tree that is being encoded, its elements are separated by block separators, otherwise its elements are separated by token separators.

- -

A “DataArray” or “Matrix” can have a fixed or variable size, which leads to two slightly different syntaxes for encoding values: -array-separator = token-separator / block-separator ; block-separator is only used when the array is the root of the component tree whose values are being encoded.

- -
array-values = fixed-size-array-values / variable-size-array-values
- - -

Fixed size arrays have a size of at least one, and are encoded as defined below:

- -
fixed-element-count = < Number of elements in a fixed size array minus one. Greater or equal to 0 since fixed size is always at least one >

element-values = scalar-value / range-values / record-values / choice-values / array-values

fixed-size-array-values = element-values <fixed-element-count>*(array-separator element-values)
- - -

When a “DataArray” (“Matrix”) is defined as variable size, its size can be 0 and the array size is included as a token in the data block, before the actual array elements values are listed:

- -
variable-element-count = < Number of elements in a variable size array. Greater or equal to 0 since variable size can be 0 for an empty array >

variable-size-array-values = variable-element-count <variable-element-count>*(array-separator element-values)
- - -

See the following examples:

- - -
- -

10.3.7.  Rules for DataStream

- -

Values of “DataStream” elements are encoded as a sequence of tokens in a way similar to how “DataArray” values are encoded. Groups of encoded values corresponding to one element of a “DataStream” are always separated by block separators, while all values within these groups are separated by token separators:

- -
stream-element-count = < Number of elements in a data stream minus one. Greater or equal to 0 since the number of elements in a data stream is always at least one >

stream-values = element-values <stream-element-count>*(block-separator element-values);
- - -

Examples of “DataStream” with “TextEncoding” have already been given in previous sections.

-
- -

10.3.8.  Rules for Geometry

- -

The value of a “Geometry” component is encoded using the WKT format defined in the Simple Feature Access Standard (OGC 06-103r4).

- -

Requirement 81

Identifier/req/text-encodings-rules/geometry-valid
A

The value of a “Geometry” component shall be encoded using the WKT format defined in OGC 06-103r4, clause 7.

-
B

The WKT representation shall be either a “Two-Dimension Geometry WKT” (clause 7.2.2 of OGC 06-103r4) or a “Three-Dimension Geometry WKT” (clause 7.2.3 of OGC 06-103r4). The ‘M’ coordinate shall not be used.

-
C

The number of dimensions of the WKT geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component.

-
D

When a geometry value is included in a text-encoded datastream, the token separator shall not be the comma character (ASCII code 44) to avoid conflicting with commas used inside the WKT representation.

-
- -

See example: Datastream with geometry (feature detection)

-
- -

10.3.9.  Media Types

- -

When array or datastream values are encoded with the Text encoding method and provided standalone (i.e. outside of any wrapper format such as an XML document), one of the following media type identifiers shall be used:

- -
  1. One of text/plain, text/csv, or application/swe+text shall be used as the content-type for files and HTTP reponses.

    -
    • text/csv can be used only when the token separator is set to a single comma ‘,’ and the block separator is set to ‘CRLF’.

      -
    • -
    • text/plain and application/swe+text can be used for any combination of separators.

      -
    • -
    -
  2. -
  3. application/swe+text shall be used for format negotiation between server and client (e.g. when the format is advertised by an API or web service). In particular, this media type shall be used in HTTP Accept and Link headers and in any server response used to advertise support or link to a resource encoded with this format.

    -

    NOTE:    It is recommended that the character set code be correctly appended to these media types if it differs from US-ASCII or UTF-8.

  4. -
- - - -

alternative would be application/vnd.ogc.swe+text

-
-

10.4.  Requirements Class: Binary Encoding Rules

- -

Requirements class 19: Binary Encoding Rules

Identifier/req/binary-encoding-rules
Target typeEncoded Values Instance
Conformance classConformance class A.10: /conf/binary-encoding-rules
PrerequisiteRequirements class 16: /req/general-encoding-rules
Indirect prerequisiteRequirements class 8: /req/uml-advanced-encodings
- -

The “BinaryEncoding” method encodes field values by their binary representation. The ABNF syntax defined in IETF RFC 5234 is used to formalize the encoding rules, and thus all ABNF snippets provided in this section are normative.

- -

Requirement 82

Identifier/req/binary-encoding-rules/abnf-syntax-valid
Statement

The encoded values block shall be formatted as defined by the ABNF grammar defined in this clause.

- -

The encoding rules are similar to those of the “TextEncoding” method except that numerical values are encoded directly as their binary representation and that no separators are used. Separators are not needed because data types have either a fixed size or contain length information (See String encoding).

- -

10.4.1.  Rules for Scalar Components

- -

The value for a scalar component is encoded as its binary representation. This especially applies to numerical values that are encoded directly in binary form in accordance to the selected data type and the value of the “byteOrder” attribute.

- -
scalar-value = < binary value encoded according to data type, byte encoding and byte order specifications >
- - -

The last column of Table 1 in [xsd_binarycomponent_elt] indicates how each data type shall be binary encoded into a low level byte sequence. The actual order of bytes composing a multi-bytes data type depends on the value of the “byteOrder” attribute. The ‘bigEndian’ option indicates that muti-bytes data types are encoded with the most significant byte (MSB) first, while selecting ‘littleEndian’ signifies that encoding is done with the less significant byte (LSB) first. A UTF-8 string is not considered as a multi-byte data type and is always encoded in the same order, as specified by the Unicode Standard.

- -

Requirement 83

Identifier/req/binary-encoding-rules/type-encoding-valid
Statement

Binary data types in Table 1 shall be encoded according to their definition in the description column and the value of the “byteOrder” attribute.

- -

Nil values are included in the stream just like normal scalar values. Since their data type has to match the field data type, there is no special treatment necessary for a decoder or encoder. It is the responsibility of the application to match the data value against the list of registered nil values for a given field in order to detect if it is associated to a nil reason or if it is an actual measurement value.

- -

When the ‘raw’ byte encoding option is selected, bytes resulting from the data type encoding process defined above are inserted in the binary stream directly. This is refered to as ‘raw binary’ encoding. When the ‘base64’ option is selected, each byte resulting from the binary encoding process is also encoded in Base64 before being included in the stream. Scalar values can be Base 64 encoded one by one or by blocks as long as the resulting stream is compatible with requirements of IETF RFC 2045.

- -

Requirement 84

Identifier/req/binary-encoding-rules/base64-translation-applied
Statement

When the ‘base64’ encoding option is selected, binary data shall be encoded with the Base64 technique defined in IETF RFC 2045 Section 6.8: Base64 Content-Transfer-Encoding.

-
- -

10.4.2.  Rules for Range Components

- -

Range components are encoded as a sequence of two binary values (each one representing a scalar value):

- -
min-value = scalar-value

max-value = scalar-value

range-values = min-value max-value
- - -

Values are always included in the same order: The lower bound of the range first, followed by the upper bound.

-
- -

10.4.3.  Rules for DataRecord and Vector

- -

Values of fields of a “DataRecord” are recursively encoded following rules associated to the type of component used as the field’s description (i.e. scalar, record, array, etc.) and appended to the binary block:

- -
field-count = < Number of fields in the record. Greater or equal to 1 >

any-field-value = scalar-value / range-values / record-values / choice-values / array-values / block_values

mandatory-field-value = any-field-value

optional-field-value = (“Y” any-field-value) / “N”

field-value = mandatory-field-value / optional-field-value

record-values = <field-count>*field-values
- - -

When a field is marked as optional in the definition, the 1-byte value ‘Y’ (ASCII code 89) or ‘N’ (ASCII code 78) shall be inserted in the data block. When the field value is omitted, the token ‘N’ is inserted alone. When it is included, the token ‘Y’ is inserted followed by the actual field value.

- -

Requirement 85

Identifier/req/binary-encoding-rules/optional-field-marker-present
Statement

The one byte ASCII character ‘Y’ or ‘N’ shall be inserted in a binary encoded data block for all “DataRecord” fields that have the “optional” attribute set to ‘true’.

- -

Coordinate values of “Vector” components are encoded with a similar syntax, but a coordinate value can only be scalar and cannot be omitted:

- -
coord-count = < Number of coordinates in the vector. Greater or equal to 1 >

vector-values = <coord-count>*scalar-value
- - -

Vector coordinates cannot be optional.

-
- -

10.4.4.  Rules for DataChoice

- -

A “DataChoice” is encoded with the binary method by providing the zero-based index of the selected item before the item values themselves. The index value ranges from 0 for the first choice item to (number_of_items - 1) for the last item.

- -
selected-item-idx = < Index of the item selected >

selected-item-value = scalar-value / range-values / record-values / choice-values / array-values

choice-values = selected-item-idx selected-item-value
- - -

Requirement 86

Identifier/req/binary-encoding-rules/choice-selection-marker-valid
Statement

The value of the selected-item-idx flag shall be the zero-based index of the selected item (within the ordered list of items provided by the choice descriptor) and be encoded on a single unsigned byte.

-
- -

10.4.5.  Rules for DataArray and Matrix

- -

Values of each “DataArray” or “Matrix” element are recursively encoded following rules associated to the type of component used for the element type (i.e. scalar, record, array, etc.). Groups of values (or single value in the case of a scalar element type) corresponding to each element are sequentially appended to the data block. Since a “DataArray” or “Matrix” can have a fixed or variable size, two slightly different syntaxes for encoding values are possible:

- -
array-values = fixed-size-array-values / variable-size-array-values

element-value = scalar-value / range-values / record-values / choice-values / array-values / block_values
- - -

Fixed size arrays have a size of at least one, and are encoded as defined below:

- -
fixed-element-count = < Number of elements in a fixed size array >

fixed-size-array-values = <fixed-element-count>*element-value
- - -

When a “DataArray” (“Matrix”) is defined as variable size, its size can be 0 and the array size is included as a token in the data block, before the actual array elements values are listed:

- -
variable-element-count = < Number of elements in a variable size array >

variable-size-array-values = variable-element-count <variable-element-count>*element-value
- - -

When the array size is 0, only this number is encoded and no element values are included in the data block.

-
- -

10.4.6.  Rules for DataStream

- -

Values of “DataStream” elements are encoded exactly as elements of an array:

- -
stream-element-count = < Number of elements in a data stream >

stream-values = <stream-element-count>*element-value
- - -

A data stream usually contains at least one value but could be empty.

-
- -

10.4.7.  Rules for Geometry

- -

The value of “Geometry” is encoded using the WKB format defined in the Simple Feature Access Standard (OGC 06-103r4).

- -

Requirement 87

Identifier/req/binary-encodings-rules/geometry-valid
A

The value of a “Geometry” component shall be encoded using the WKB format defined in OGC 06-103r4, clause 8.

-
B

The WKB geometry type shall be one of the following types listed in OGC 06-103r4, clause 8.2.3, table 7: Point, LineString, Polygon, MultiPoint, MultiLineString, MultiPolygon, Point Z, LineString Z, Polygon Z, MultiPoint Z, MultiLineString Z, MultiPolygon Z. Other geometry type codes shall not be used.

-
C

The number of dimensions of the WKB geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component.

-
- -

No specific marker or length information needs to be pre-pended to the binary representation since the WKB format is self descriptive and parsable without knowing the total length ahead of time.

-
- -

10.4.8.  Block encoded components

- -

When block encoding characteristics are also specified in the encoding description, the encryption and/or compression algorithm shall be applied after the binary encoding process described above is completed for the block. Extensions of this standard can define compression and encryption methods that fit the needs of particular communities.

- -

In order to maximize compatibility with existing software, when compressing a binary encoded data stream results in a well known binary format, the corresponding mime type can be used instead of application/octet-stream. For instance video/h264 can be used when the entirety of the dataset (presumably a video stream) is compressed using the H264 video codec.

-
- -

10.4.9.  Media Types

- -

When array or stream values are encoded with the Binary encoding method and provided standalone (i.e. outside of any wrapper format), one of the following media type identifiers shall be used:

- -
  1. One of application/octet-stream or application/swe-binary shall be used as the content-type for files and HTTP responses.

    -
  2. -
  3. application/swe+binary shall be used for format negotiation between server and client (e.g. when the format is advertised by an API or web service). In particular, this media type shall be used in HTTP Accept and Link headers and in any server response used to advertise support or link to a resource encoded with this format.

    -
  4. -
- -

alternative would be application/vnd.ogc.swe-binary

-
-

Annex A
(normative)
Conformance Class Abstract Test Suite

A.1.  Core Conformance Classes

- -

A.1.1.  Conformance Class: Core Concepts

- -

Conformance class A.1

Identifier/conf/core
Requirements classRequirements class 1: /req/core
Target TypeDerived Models and Software Implementations
- -

Abstract test A.1: Core concepts are the base of all derived models

Identifier/conf/core/core-concepts-used
RequirementRequirement 1: /req/core/core-concepts-used
Test purpose

Verify that the target implementation correctly implements the core concepts.

-
Description

Example 1

Inspect the target implementation.

-
- -

Abstract test A.2: A boolean representation consists of a boolean value

Identifier/conf/core/boolean-rep-valid
RequirementRequirement 2: /req/core/boolean-rep-valid
Test purpose

Verify that the target implementation correctly implements the Boolean representation.

-
Description

Example 2

Inspect the target implementation.

-
- -

Abstract test A.3: A categorical representation consists of a token with a code space

Identifier/conf/core/categorical-rep-valid
RequirementRequirement 3: /req/core/categorical-rep-valid
Test purpose

Verify that the target implementation correctly implements the Categorical representation.

-
Description

Example 3

Inspect the target implementation.

-
- -

Abstract test A.4: A continuous numerical representation consists of a number with a scale

Identifier/conf/core/numerical-rep-valid
RequirementRequirement 4: /req/core/numerical-rep-valid
Test purpose

Verify that the target implementation correctly implements the Numerical representation.

-
Description

Example 4

Inspect the target implementation.

-
- -

Abstract test A.5: A countable representation consists of an integer number

Identifier/conf/core/countable-rep-valid
RequirementRequirement 5: /req/core/countable-rep-valid
Test purpose

Verify that the target implementation correctly implements the Countable representation.

-
Description

Example 5

Inspect the target implementation.

-
- -

Abstract test A.6: A textual representation is implemented as a character string

Identifier/conf/core/textual-rep-valid
RequirementRequirement 6: /req/core/textual-rep-valid
Test purpose

Verify that the target implementation correctly implements the Textual representation.

-
Description

Example 6

Inspect the target implementation.

-
- -

Abstract test A.7: A semantic definition of each property shall be provided

Identifier/conf/core/semantics-defined
RequirementRequirement 7: /req/core/semantics-defined
Test purpose

Verify that the target implementation allows attaching a semantic definition to all property representations.

-
Description

Example 7

Inspect the target implementation.

-
- -

Abstract test A.8: References to semantical information shall be resolvable

Identifier/conf/core/semantics-resolvable
RequirementRequirement 8: /req/core/semantics-resolvable
Test purpose

Verify that the target implementation encodes the semantic links in a way that they can be resolved to an actual concept definition.

-
Description

Example 8

Inspect the target implementation.

-
- -

Abstract test A.9: A temporal quantity is associated to a temporal reference frame

Identifier/conf/core/temporal-frame-defined
RequirementRequirement 9: /req/core/temporal-frame-defined
Test purpose

Verify that the target implementation allows providing a temporal reference frame along with any date/time quantity.

-
Description

Example 9

Inspect the target implementation.

-
- -

Abstract test A.10: A spatial quantity is associated to an axis of a spatial reference frame

Identifier/conf/core/spatial-frame-defined
RequirementRequirement 10: /req/core/spatial-frame-defined
Test purpose

Verify that the target implementation allows providing a spatial reference frame and axis along with any quantity that is projected along a spatial dimension.

-
Description

Example 10

Inspect the target implementation.

-
- -

Abstract test A.11: A NIL value maps a reserved value to a reason

Identifier/conf/core/nil-reasons-defined
RequirementRequirement 11: /req/core/nil-reasons-defined
Test purpose

Verify that the target implementation allows providing a reason along with each NIL (reserved) value.

-
Description

Example 11

Inspect the target implementation.

-
- -

Abstract test A.12: Aggregate data types are modeled according to ISO 11404

Identifier/conf/core/aggregates-model-valid
RequirementRequirement 12: /req/core/aggregates-model-valid
Test purpose

Verify that the target implementation models aggregate data types according to ISO 11404 definitions.

-
Description

Example 12

Inspect the target implementation.

-
- -

Abstract test A.13: Encoding methods shall be defined for all possible data structures

Identifier/conf/core/encoding-method-valid
RequirementRequirement 13: /req/core/encoding-method-valid
Test purpose

Verify that the target implementation provides encoding methods for all representations and all implemented data structures.

-
Description

Example 13

Inspect the target implementation.

-
-
-

A.2.  UML Conformance Classes

- -

A.2.1.  Conformance Class: Basic Types and Simple Components UML Packages

- -

Conformance class A.2: Basic Types and Simple Components UML Packages

Identifier/conf/uml-simple-components
Requirements classRequirements class 2: /req/uml-simple-components
PrerequisiteConformance class A.1: /conf/core
Target TypeDerived Models and Software Implementations
- -

Abstract test A.14: Compliance with UML models defined in this package

Identifier/conf/uml-simple-components/package-fully-implemented
RequirementRequirement 14: /req/uml-simple-components/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
Description

Example 1

Inspect the model or software implementation.

-
- -

Abstract test A.15: Compliance with UML models defined in ISO 19103

Identifier/conf/uml-simple-components/iso19103-implemented
RequirementRequirement 15: /req/uml-simple-components/iso19103-implemented
Test purpose

Verify that the target implements all classes imported from ISO 19103 UML packages.

-
Description

Example 2

Inspect the model or software implementation.

-
- -

Abstract test A.16: Compliance with UML models defined in ISO 19108

Identifier/conf/uml-simple-components/iso19108-implemented
RequirementRequirement 16: /req/uml-simple-components/iso19108-implemented
Test purpose

Verify that the target implements all classes imported from ISO 19108 UML packages.

-
Description

Example 3

Inspect the model or software implementation.

-
- -

Abstract test A.17: A definition URI is mandatory on all simple components

Identifier/conf/uml-simple-components/definition-present
RequirementRequirement 17: /req/uml-simple-components/definition-present
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 4

Inspect the model or software implementation.

-
- -

Abstract test A.18: The value of the axisID and axisAbbrev attributes match

Identifier/conf/uml-simple-components/axis-valid
RequirementRequirement 18: /req/uml-simple-components/axis-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 5

Inspect the model or software implementation.

-
- -

Abstract test A.19: The axis ID is always specified on scalar spatial properties

Identifier/conf/uml-simple-components/axis-defined
RequirementRequirement 19: /req/uml-simple-components/axis-defined
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 6

Inspect the model or software implementation.

-
- -

Abstract test A.20: The reference frame is specified on scalar spatial properties not part of a vector

Identifier/conf/uml-simple-components/ref-frame-defined
RequirementRequirement 20: /req/uml-simple-components/ref-frame-defined
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 7

Inspect the model or software implementation.

-
- -

Abstract test A.21: The value of a component satisfies the constraints

Identifier/conf/uml-simple-components/value-constraint-valid
RequirementRequirement 21: /req/uml-simple-components/value-constraint-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 8

Inspect the model or software implementation.

-
- -

Abstract test A.22: All derived simple components have an optional value attribute

Identifier/conf/uml-simple-components/value-attribute-present
RequirementRequirement 22: /req/uml-simple-components/value-attribute-present
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 9

Inspect the model or software implementation.

-
- -

Abstract test A.23: The list of values allowed in a Category component is a subset of the code space

Identifier/conf/uml-simple-components/category-constraint-valid
RequirementRequirement 23: /req/uml-simple-components/category-constraint-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 10

Inspect the model or software implementation.

-
- -

Abstract test A.24: A Category component always specifies a list of possible values

Identifier/conf/uml-simple-components/category-enum-defined
RequirementRequirement 24: /req/uml-simple-components/category-enum-defined
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 11

Inspect the model or software implementation.

-
- -

Abstract test A.25: The value of a Category component is one defined in the code space

Identifier/conf/uml-simple-components/category-value-valid
RequirementRequirement 25: /req/uml-simple-components/category-value-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 12

Inspect the model or software implementation.

-
- -

Abstract test A.26: The temporal reference frame is defined

Identifier/conf/uml-simple-components/time-ref-frame-defined
RequirementRequirement 26: /req/uml-simple-components/time-ref-frame-defined
Test purpose

Verify that the implementation correctly assumes the default value when the attribute is not set.

-
Description

Example 13

Inspect the model or software implementation.

-
- -

Abstract test A.27: The time of reference is expressed relative to the origin of the reference frame

Identifier/conf/uml-simple-components/time-ref-time-valid
RequirementRequirement 27: /req/uml-simple-components/time-ref-time-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 14

Inspect the model or software implementation.

-
- -

Abstract test A.28: The local and reference frames of a Time component are different

Identifier/conf/uml-simple-components/time-local-frame-valid
RequirementRequirement 28: /req/uml-simple-components/time-local-frame-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 15

Inspect the model or software implementation.

-
- -

Abstract test A.29: Values of range components satisfy the same requirements as scalar values

Identifier/conf/uml-simple-components/range-value-valid
RequirementRequirement 29: /req/uml-simple-components/range-value-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 16

Inspect the model or software implementation.

-
- -

Abstract test A.30: CategoryRange components satisfy all requirements of a Category component

Identifier/conf/uml-simple-components/category-range-valid
RequirementRequirement 30: /req/uml-simple-components/category-range-valid
Test purpose

Verify that the target implementation has constraints that enforce the requirement.

-
Description

Example 17

- -

Abstract test A.31: The code space of a CategoryRange component is well-ordered

Identifier/conf/uml-simple-components/category-range-codespace-order
RequirementRequirement 31: /req/uml-simple-components/category-range-codespace-order
Test purpose

Verify that the code space contains elements that have a specific order (either implied or defined).

-
Description

Example 18

Inspect instances generated by the implementation of the “CategoryRange” class, including a codepace, to verify the requirement.

-
- -

Abstract test A.32: TimeRange components satisfy all requirements of the Time class

Identifier/conf/uml-simple-components/time-range-valid
RequirementRequirement 32: /req/uml-simple-components/time-range-valid
Test purpose

Verify that the target implementation has constraints that enforce the requirement.

-
Description

Example 19

- -

Abstract test A.33: The reason attribute is a URI that is resolvable to a definition

Identifier/conf/uml-simple-components/nil-reason-resolvable
RequirementRequirement 33: /req/uml-simple-components/nil-reason-resolvable
Test purpose

Verify that the target implementation allows the value of a NIL reason identifier to be either:

-
  • a well known reason code defined by OGC

    -
  • -
  • a URI that can be resolved to the textual description of a custom reason.

    -
  • -
-
Description

Example 20

Inspect the model or software implementation.

-
- -

Abstract test A.34: Values reserved for NIL reasons are compatible with the component data type

Identifier/conf/uml-simple-components/nil-value-type-coherent
RequirementRequirement 34: /req/uml-simple-components/nil-value-type-coherent
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
Description

Example 21

Inspect the model or software implementation.

-
- -

Abstract test A.35: The scale of constraints is the same as the scale of the component value

Identifier/conf/uml-simple-components/allowed-values-unit-coherent
RequirementRequirement 35: /req/uml-simple-components/allowed-values-unit-coherent
Test purpose

Verify that numerical constraints are expressed with the correct scale.

-
Description

Example 22

Inspect instances generated by the implementation of the “Quantity”, “Count” and “Time” classes, including an “AllowedValues” constraint, to verify the requirement.

-
-
- -

A.2.2.  Conformance Class: Record Components UML Package

- -

Conformance class A.3: Record Components UML Package

Identifier/conf/uml-record-components
Requirements classRequirements class 3: /req/uml-record-components
PrerequisiteConformance class A.2: /conf/uml-simple-components
Target TypeDerived Models and Software Implementations
- -

Abstract test A.36: Compliance with UML models defined in this package

Identifier/conf/uml-record-components/package-fully-implemented
RequirementRequirement 36: /req/uml-record-components/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
Description

Example 1

Inspect the model or software implementation.

-
- -

Abstract test A.37: Each DataRecord field has a unique name

Identifier/conf/uml-record-components/record-field-name-unique
RequirementRequirement 37: /req/uml-record-components/record-field-name-unique
Test purpose

Verify that the implementation of the “DataRecord” class has a constraint that enforces the requirement.

-
Description

Example 2

Inspect the model or software implementation.

-
- -

Abstract test A.38: Each Vector coordinate has a unique name

Identifier/conf/uml-record-components/vector-coord-name-unique
RequirementRequirement 38: /req/uml-record-components/vector-coord-name-unique
Test purpose

Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.

-
Description

Example 3

Inspect the model or software implementation.

-
- -

Abstract test A.39: The reference frame is not specified on individual coordinates of a Vector

Identifier/conf/uml-record-components/vector-component-no-ref-frame
RequirementRequirement 39: /req/uml-record-components/vector-component-no-ref-frame
Test purpose

Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.

-
Description

Example 4

Inspect the model or software implementation. -The “referenceFrame” attribute shall be ommited from all data components used to define coordinates of a “Vector” instance.

-
- -

Abstract test A.40: The axis ID is specified on all coordinates of a Vector

Identifier/conf/uml-record-components/vector-component-axis-defined
RequirementRequirement 40: /req/uml-record-components/vector-component-axis-defined
Test purpose

Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.

-
Description

Example 5

Inspect the model or software implementation. -The “axisID” attribute shall be present on all data components used to define coordinates of a “Vector” instance.

-
- -

Abstract test A.41: The local and reference frames of a Vector component are different

Identifier/conf/uml-record-components/vector-local-frame-valid
RequirementRequirement 41: /req/uml-record-components/vector-local-frame-valid
Test purpose

Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.

-
Description

Example 6

Inspect the model or software implementation.

-
-
- -

A.2.3.  Conformance Class: Choice Components UML Package

- -

Conformance class A.4: Choice Components UML Package

Identifier/conf/uml-choice-components
Requirements classRequirements class 4: /req/uml-choice-components
PrerequisiteConformance class A.2: /conf/uml-simple-components
Target TypeDerived Models and Software Implementations
- -

Abstract test A.42: Compliance with UML models defined in this package

Identifier/conf/uml-choice-components/package-fully-implemented
RequirementRequirement 42: /req/uml-choice-components/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
Description

Example 1

Inspect the model or software implementation.

-
- -

Abstract test A.43: Each DataChoice item has a unique name

Identifier/conf/uml-choice-components/choice-item-name-unique
RequirementRequirement 43: /req/uml-choice-components/choice-item-name-unique
Test purpose

Verify that the implementation of the “DataChoice” class has a constraint that enforces the requirement.

-
Description

Example 2

Inspect the model or software implementation.

-
-
- -

A.2.4.  Conformance Class: Block Components UML Package

- -

Conformance class A.5: Block Components UML Package

Identifier/conf/uml-block-components
Requirements classRequirements class 5: /req/uml-block-components
PrerequisiteConformance class A.2: /conf/uml-simple-components
Target TypeDerived Models and Software Implementations
- -

Abstract test A.44: Compliance with UML models defined in this package

Identifier/conf/uml-block-components/package-fully-implemented
RequirementRequirement 44: /req/uml-block-components/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
Description

Example 1

Inspect the model or software implementation.

-
- -

Abstract test A.45: Components nested in a block component are data descriptors

Identifier/conf/uml-block-components/array-component-no-value
RequirementRequirement 45: /req/uml-block-components/array-component-no-value
Test purpose

Verify that implementations of the block component classes have a constraint that enforces the requirement.

-
Description

Example 2

Inspect the model or software implementation. -Check that the “DataArray”, “Matrix” and “DataStream” classes have the constraint.

-
- -

Abstract test A.46: An encoding method is specified whenever an encoded data block is included

Identifier/conf/uml-block-components/array-values-properly-encoded
RequirementsRequirement 46: /req/uml-block-components/array-values-properly-encoded
Requirement 48: /req/uml-block-components/datastream-array-valid
Test purpose

Verify that the implementation of block component classes have a constraint that enforces the requirement.

-
Description

Example 3

Inspect the model or software implementation. -Check that the “DataArray”, “Matrix” and “DataStream” classes have the constraint. -Inspect instances of these classes generated by the implementation to verify that an encoding method is specified whenever there are encoded values present.

-
- -

Abstract test A.47: Elements of a matrix are of scalar types or nested matrices

Identifier/conf/uml-block-components/matrix-element-type-valid
RequirementRequirement 47: /req/uml-block-components/matrix-element-type-valid
Test purpose

Verify that the implementation of the “Matrix” class has a constraint that enforces the requirement.

-
Description

Example 4

Inspect the model or software implementation.

-
-
- -

A.2.5.  Conformance Class: Simple Encodings UML Package

- -

Conformance class A.6: Simple Encodings UML Package

Identifier/conf/uml-simple-encodings
Requirements classRequirements class 7: /req/uml-simple-encodings
PrerequisiteConformance class A.1: /conf/core
Target TypeDerived Models and Software Implementations
- -

Abstract test A.48: Compliance with UML models defined in this package

Identifier/conf/uml-simple-encodings/package-fully-implemented
RequirementRequirement 52: /req/uml-simple-encodings/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
Description

Example

Inspect the model or software implementation.

-
-
- -

A.2.6.  Conformance Class: Advanced Encodings UML Package

- -

Conformance class A.7: Advanced Encodings UML Package

Identifier/conf/uml-advanced-encodings
Requirements classRequirements class 8: /req/uml-advanced-encodings
PrerequisiteConformance class A.6: /conf/uml-simple-encodings
Target TypeDerived Models and Software Implementations
- -

Abstract test A.49: Compliance with UML models defined in this package

Identifier/conf/uml-advanced-encodings/package-fully-implemented
RequirementRequirement 53: /req/uml-advanced-encodings/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
Description

Example

Inspect the model or software implementation.

-
-
-

A.3.  Datastream Encoding Conformance Classes

- -

A.3.1.  Conformance Class: General Encoding Rules

- -

Conformance class A.8: General Encoding Rules

Identifier/conf/general-encoding-rules
Requirements classRequirements class 16: /req/general-encoding-rules
Target TypeEncoded Values Instance
- -

Abstract test A.50: DataRecord fields and Vector coordinates are encoded recursively

Identifier/conf/general-encoding-rules/record-encoding-rule
RequirementRequirement 65: /req/general-encoding-rules/record-encoding-rule
Description

Example 1

Verify that the sequence of scalar values (obtained after decoding the section of the encoded data block corresponding to the “DataRecord” or “Vector”) includes values for the successive fields/coordinates in the right order.

-
- -

Abstract test A.51: DataChoice selected item is properly encoded

Identifier/conf/general-encoding-rules/choice-encoding-rule
RequirementRequirement 66: /req/general-encoding-rules/choice-encoding-rule
Description

Example 2

Verify that the sequence of scalar values (obtained after decoding the section of the encoded data block corresponding to the “DataChoice”) includes a value identifying the selected item as well as values for the item itself.

-
- -

Abstract test A.52: DataArray elements are encoded recursively

Identifier/conf/general-encoding-rules/array-encoding-rule
RequirementRequirement 67: /req/general-encoding-rules/array-encoding-rule
Description

Example 3

Verify that the sequence of scalar values obtained after decoding the section of the encoded data block corresponding to the “DataArray” includes values for the successive elements of the array.

-
- -

Abstract test A.53: The length of variable size arrays is encoded in the data block

Identifier/conf/general-encoding-rules/array-size-encoding-rule
RequirementRequirement 68: /req/general-encoding-rules/array-size-encoding-rule
Description

Example 4

Verify that the sequence of values obtained after decoding the section of the encoded data block corresponding to a variable size “DataArray” includes a value specifying the size of the array.

-
-
- -

A.3.2.  Conformance Class: Text Encoding Rules

- -

Conformance class A.9: Text Encoding Rules

Identifier/conf/text-encoding-rules
Requirements classRequirements class 18: /req/text-encoding-rules
PrerequisiteConformance class A.8: /conf/general-encoding-rules
Target TypeEncoded Values Instance
- -

Abstract test A.54: Compliance with ABNF grammar

Identifier/conf/text-encoding-rules/abnf-syntax-valid
Requirement/req/text-encoding-rules/abnf-syntax-valid
Description

Example 1

Verify that the text encoded data block is correct with respect to the ABNF grammar corresponding to the particular dataset (The complete ABNF grammar of the dataset should be dynamically constructed from the ABNF snippets provided in the specification).

-
- -

Abstract test A.55: Separator characters are well chosen

Identifier/conf/text-encoding-rules/separators-valid
Requirement/req/text-encoding-rules/separators-valid
Description

Example 2

Verify that the values encoded in the data block never include the reserved separator characters. This can be detected by looking for invalid or superfluous values.

-
- -

Abstract test A.56: Special flags are inserted before optional component values

Identifier/conf/text-encoding-rules/optional-field-marker-present
Requirement/req/text-encoding-rules/optional-field-marker-present
Description

Example 3

Verify that the sequence of values corresponding to the optional field starts with the ‘Y’ or ‘N’ flag.

-
- -

Abstract test A.57: The name of a selected choice item is inserted in the stream

Identifier/conf/text-encoding-rules/choice-selection-marker-valid
Requirement/req/text-encoding-rules/choice-selection-marker-valid
Description

Example 4

Verify that the sequence of values corresponding to the “DataChoice” starts with a character string matching the name of one item of the choice descriptor.

-
-
- -

A.3.3.  Conformance Class: Binary Encoding Rules

- -

Conformance class A.10: Binary Encoding Rules

Identifier/conf/binary-encoding-rules
Requirements classRequirements class 19: /req/binary-encoding-rules
PrerequisiteConformance class A.8: /conf/general-encoding-rules
Target TypeEncoded Values Instance
- -

Abstract test A.58: Compliance with ABNF grammar

Identifier/conf/binary-encoding-rules/abnf-syntax-valid
RequirementRequirement 82: /req/binary-encoding-rules/abnf-syntax-valid
Description

Example 1

Verify that the binary encoded data block is correct with respect to the ABNF grammar of the particular dataset (The complete ABNF grammar of the dataset should be dynamically constructed from the ABNF snippets provided in the specification).

-
- -

Abstract test A.59: Data types are encoded as specified in this standard

Identifier/conf/binary-encoding-rules/type-encoding-valid
RequirementRequirement 83: /req/binary-encoding-rules/type-encoding-valid
Description

Example 2

Verify that valid and realistic scalar values are obtained when the binary data block is parsed by extracting the number of bits specified in the table and decoding the resulting bytes in the order specified by the “byteOrder” attribute. When the encoded data and the encoding parameters are not consistent, abberant values (such as -65502 for a temperature field, etc…) are usually obtained, which can be easily detected.

-
- -

Abstract test A.60: Base64 encoding is implemented as defined by IETF

Identifier/conf/binary-encoding-rules/base64-translation-applied
RequirementRequirement 84: /req/binary-encoding-rules/base64-translation-applied
Description

Example 3

  • Verify that only characters allowed by base64 encoding are used in the encoded data content.

    -
  • -
  • Verify that the data block can be properly parsed after the base64 data is decoded into a raw binary data stream.

    -
  • -
-
- -

Abstract test A.61: Special flags are inserted before optional component values

Identifier/conf/binary-encoding-rules/optional-field-marker-present
RequirementRequirement 85: /req/binary-encoding-rules/optional-field-marker-present
Description

Example 4

  • Verify that any optional field is preceded by the a 1-byte ASCII character with value ‘Y’ or ‘N’.

    -
  • -
  • Verify that the actual field value is only present if the flag has the ‘Y’ value.

    -
  • -
-
- -

Abstract test A.62: The name of a selected choice item is inserted in the stream

Identifier/conf/binary-encoding-rules/choice-selection-marker-valid
RequirementRequirement 86: /req/binary-encoding-rules/choice-selection-marker-valid
Description

Example 5

  • Verify that the sequence of bytes corresponding to the “DataChoice” starts with a byte value that is greater or equal to 0 and less than the total number of items defined in the choice descriptor.

    -
  • -
  • Verify that the parsed index value corresponds to the proper item in the choice descriptor.

    -
  • -
-
-
-

Annex B
(informative)
Examples

B.1.  Text Encoding Rules Examples

- -

B.1.1.  DataArray with inline values (curve)

- -

The following example shows how elements of an array defined as a “DataRecord” can be encoded inline with the text method:

- -
<swe:DataArray definition="http://sweet.jpl.nasa.gov/2.0/mathFunction.owl#Function">
  <swe:description>Measurement error vs. temperature</swe:description>
  <swe:elementCount>
    <swe:Count>
      <swe:value>5</swe:value>
    </swe:Count>
  </swe:elementCount>
  <swe:elementType name="point">
    <swe:DataRecord>
      <swe:label>Error vs. Temperature</swe:label>
      <swe:field name="temp">
        <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/physThermo.owl#Temperature">
          <swe:label>Temperature</swe:label>
          <swe:uom code="Cel"/>
        </swe:Quantity>
      </swe:field>
      <swe:field name="error">
        <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/sciUncertainty.owl#Error">
          <swe:label>Relative Error</swe:label>
          <swe:uom code="%"/>
        </swe:Quantity>
      </swe:field>
    </swe:DataRecord>
  </swe:elementType>
  <swe:encoding>
    <swe:TextEncoding blockSeparator=" " tokenSeparator=","/>
  </swe:encoding>
  <swe:values>0,5 10,2 50,2 80,5 100,15</swe:values>
</swe:DataArray>
- - -

In this example, each element consists of a record of two values. The array element structure also corresponds to one block so that tuples are separated by block separators (here the ‘,’ character). Since the array is of size 5, there are 5 tuples listed sequentially in the data block, each one composed of the two values of the data record separated by the token separator. The pattern is “temp,error temp,error …” since values have to be listed in the same order as the fields.

-
- -

B.1.2.  Datastream with records (weather data)

- -

The following snippet defines a datastream with an element of type record:

- -
<swe:DataStream>
  <swe:label>Weather Data</swe:label>
  <swe:elementType name="weatherData">
    <swe:DataRecord>
      <swe:field name="time">
        <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime"
                  referenceFrame="http://www.opengis.net/def/trs/BIPM/0/UTC">
          <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/>
        </swe:Time>
      </swe:field>
      <swe:field name="temp">
        <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/air_temperature">
          <swe:label>Air Temperature</swe:label>
          <swe:uom code="Cel"/>
        </swe:Quantity >
      </swe:field>
      <swe:field name="press">
        <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/air_pressure_at_mean_sea_level">
          <swe:label>Atmospheric Pressure</swe:label>
          <swe:uom code="HPa"/>
        </swe:Quantity >
      </swe:field>
       <swe:field name="windSpeed">
        <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_speed">
          <swe:label>Wind Speed</swe:label>
          <swe:uom code="km/h"/>
        </swe:Quantity>
      </swe:field>
      <swe:field name="windDir">
        <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_to_direction">
          <swe:label>Wind Direction</swe:label>
          <swe:uom code="deg"/>
        </swe:Quantity>
      </swe:field>
    </swe:DataRecord>
  </swe:elementType>
  <swe:encoding>
    <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=","/>
  </swe:encoding>
</swe:DataStream>
- - -

The datastream records are encoded using the Text encoding method as shown below:

- -
2023-03-20T15:40:00Z,15.3,1014,3.5,56.0
2023-03-20T15:45:00Z,15.4,1015,5.6,123.0
2023-03-20T15:50:00Z,15.8,1014,13.2,34.0
...
- -
- -

B.1.3.  Datastream with records and optional fields (navigation data)

- -

The following snippet defines a datastream with an element of type record that contains optional fields:

- -
<swe:DataStream>
  <swe:label>Aircraft Navigation</swe:label>
  <swe:elementType name="navData">
    <swe:DataRecord>
      <swe:field name="time">
        <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime"
                  referenceFrame="http://www.opengis.net/def/trs/OGC/0/GPS">
          <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/>
        </swe:Time>
      </swe:field>
      <swe:field name="speed">
        <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/humanTransportAir.owl#GroundSpeed">
          <swe:uom code="m/s"/>
        </swe:Quantity >
      </swe:field>
      <swe:field name="location">
        <swe:Vector optional="true" referenceFrame="http://www.opengis.net/def/crs/EPSG/0/4979">
          <swe:coordinate name="lat">
            <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/spaceCoordinates.owl#Latitude" axisID="Lat">
              <swe:uom code="deg"/>
            </swe:Quantity>
          </swe:coordinate>
          <swe:coordinate name="lon">
            <swe:Quantity definition=" http://sweet.jpl.nasa.gov/2.0/spaceCoordinates.owl#Longitude" axisID="Long">
              <swe:uom code="deg"/>
            </swe:Quantity>
          </swe:coordinate>
          <swe:coordinate name="alt">
            <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/spaceExtent.owl#Altitude" axisID="h">
              <swe:uom code="m"/>
            </swe:Quantity>
          </swe:coordinate>
        </swe:Vector>
      </swe:field>
    </swe:DataRecord>
  </swe:elementType>
  <swe:encoding>
    <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=","/>
  </swe:encoding>
</swe:DataStream>
- - -

The datastream records are encoded using the Text encoding method as shown below:

- -
2007-10-23T15:46:12Z,15.3,Y,45.3,-90.5,311
2007-10-23T15:46:22Z,25.3,N
2007-10-23T15:46:32Z,20.6,Y,45.3,-90.6,312
2007-10-23T15:46:52Z,18.9,Y,45.4,-90.6,315
2007-10-23T15:47:02Z,22.3,N
...
- - -

In this example, the whole location “Vector” is marked as optional and thus the coordinate values are only included when the optional flag is set to ‘Y’ in the stream. Field values in each block have to be listed in the same order as the field properties in the record definition thus following the “time,speed,Y,lat,lon,alt” or “time,speed,N” pattern depending on whether or not the location is omitted.

-
- -

B.1.4.  Datastream with choice (navigation data)

- -

This is illustrated by the following example:

- -
<swe:DataStream>
  <swe:elementType name="message">
    <swe:DataChoice>
      <swe:item name="TEMP">
        <swe:DataRecord>
          <swe:label>Temperature Measurement</swe:label>
          <swe:field name="time">
            <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime">
              <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/>
            </swe:Time>
          </swe:field>
          <swe:field name="temp">
            <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/air_temperature">
              <swe:uom code="Cel"/>
            </swe:Quantity>
          </swe:field>
        </swe:DataRecord>
      </swe:item>
      <swe:item name="WIND">
        <swe:DataRecord>
          <swe:label>Wind Measurement</swe:label>
          <swe:field name="time">
            <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime">
              <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/>
            </swe:Time>
          </swe:field>
          <swe:field name="wind_speed">
            <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_speed">
              <swe:uom code="km/h"/>
            </swe:Quantity>
          </swe:field>
          <swe:field name="wind_dir">
            <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_to_direction">
              <swe:uom code="deg"/>
            </swe:Quantity>
          </swe:field>
        </swe:DataRecord>
      </swe:item>
    </swe:DataChoice>
  </swe:elementType>
  <swe:encoding>
    <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=","/>
  </swe:encoding>
</swe:DataStream>
- - -

The datastream records are encoded using the Text encoding method as shown below:

- -
TEMP,2009-05-23T19:36:15Z,25.5
TEMP,2009-05-23T19:37:15Z,25.6
WIND,2009-05-23T19:37:17Z,56.3,226.3
TEMP,2009-05-23T19:38:15Z,25.5
...
- - -

This datastream interleaves different types of messages separated by the block separator character. The element type is a “DataChoice” which means that each encoded block is composed of the item name ‘TEMP’ or ‘WIND’, followed by values of the item. This example also demonstrates that items of a choice can be of different types and length.

-
- -

B.1.5.  Fixed size 2D array (stress matrix)

- -

The following example illustrates how values of a fixed size 3×3 stress matrix can be text encoded inline:

- -
<swe:Matrix definition="http://sweet.jpl.nasa.gov/2.0/physPressure.owl#Stress">
  <swe:elementCount>
    <swe:Count>
      <swe:value>3</swe:value>
    </swe:Count>
  </swe:elementCount>
  <swe:elementType name="row">
    <swe:Matrix definition="http://sweet.jpl.nasa.gov/2.0/info.owl#Row">
      <swe:elementCount>
        <swe:Count>
          <swe:value>3</swe:value>
        </swe:Count>
      </swe:elementCount>
      <swe:elementType name="coef">
        <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/mathVector.owl#Coordinate">
          <swe:uom code="MPa"/>
        </swe:Quantity>
      </swe:elementType>
    </swe:Matrix>
  </swe:elementType>
  <swe:encoding>
    <swe:TextEncoding blockSeparator=" " tokenSeparator=","/>
  </swe:encoding>
  <swe:values>0.36,0.48,-0.8 -0.8,0.6,0.0 0.48,0.64,0.6</swe:values>
</swe:Matrix>
- - -

Note that elements of the outer array (i.e. a matrix is a special kind of array) are separated by block separators (i.e. each block surrounded by spaces corresponds to one row of the matrix) while the inner array elements are separated by token separators.

-
- -

B.1.6.  Datastream of variable size 1D arrays (profile series)

- -

The following example shows how SWE Common can be used to encode a series of irregular length profiles by using a variable size array:

- -
<swe:DataStream>
  <swe:elementType name="profileData">
    <swe:DataRecord>
      <swe:field name="time">
        <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime">
          <swe:label>Sampling Time</swe:label>
          <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/>
        </swe:Time>
      </swe:field>
      <swe:field name="profilePoints">
        <swe:DataArray definition="http://sweet.jpl.nasa.gov/2.0/info.owl#Profile">
          <swe:elementCount>
            <swe:Count/>
          </swe:elementCount>
          <swe:elementType name="point">
            <swe:DataRecord>
              <swe:field name="depth">
                <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/depth">
                  <swe:label>Sampling Point Vertical Location</swe:label>
                  <swe:uom code="m"/>
                </swe:Quantity>
              </swe:field>
              <swe:field name="salinity">
                <swe:Quantity definition="http://mmisw.org/ont/cf/parameter#sea_water_salinity">
                  <swe:label>Salinity</swe:label>
                  <swe:uom code="[ppth]"/>
                </swe:Quantity>
              </swe:field>
            </swe:DataRecord>
          </swe:elementType>
        </swe:DataArray>
      </swe:field>
    </swe:DataRecord>
  </swe:elementType>
  <swe:encoding>
    <swe:TextEncoding blockSeparator="@@&#10;" tokenSeparator=","/>
  </swe:encoding>
</swe:DataStream>
- - -

The datastream records are encoded using the Text encoding method as shown below:

- -
2005-05-16T21:47:12Z,5,0,45,10,20,20,30,30,35,40,40@@
2005-05-16T22:43:05Z,4,0,45,10,20,20,30,30,35@@
2005-05-16T23:40:52Z,5,0,45,10,20,20,30,30,35,40,40
...
- - -

The example shows data for 3 profiles with a variable number of measurements along the vertical dimension. The number of measurements is indicated in the encoded data block by a number inserted after the timestamp, and before the measurements themselves. Since the array is itself the element of a “DataStream”, elements of the array are separated by token separators.

-
- -

B.1.7.  Datastream with geometry (feature detection)

- -

The following snippet is an example of datastream that contains a geometry. Here, each datastream record represents a feature detected in a video stream, and is composed of a timestamp, a scalar field and the geometry of the geolocated feature.

- -
<swe:DataStream>
  <swe:label>Feature Detections</swe:label>
  <swe:elementType name="detection">
    <swe:DataRecord>
      <swe:field name="time">
        <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime"
                  referenceFrame="http://www.opengis.net/def/trs/OGC/0/GPS">
          <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/>
        </swe:Time>
      </swe:field>
      <swe:field name="type">
        <swe:Category definition="http://www.opengis.net/def/featureType">
          <swe:codeSpace xlink:href="http://x-myorg.net/def/VehicleTypes"/>
        </swe:Category>
      </swe:field>
      <swe:field name="geom">
        <swe:Geometry definition="http://www.opengis.net/def/property/OGC/0/SamplingTime" srs="http://www.opengis.net/def/crs/EPSG/0/4326">
          <swe:constraint>
            <swe:AllowedGeometries>
              <swe:geomType>Point</swe:geomType>
              <swe:geomType>Polygon</swe:geomType>
            </swe:AllowedGeometries>
          </swe:constraint>
        </swe:Geometry>
      </swe:field>
    </swe:DataRecord>
  </swe:elementType>
  <swe:encoding>
    <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=";"/>
  </swe:encoding>
</swe:DataStream>
- - -

The datastream records are encoded using the Text encoding method as shown below:

- -
2007-10-23T15:46:12Z;Car;POINT(-86.3254 35.4812)
2007-10-23T15:49:03Z;Truck;POLYGON((-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812))
2007-10-23T15:56:45Z;Bus;POLYGON((-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812))
...
- -
-

B.2.  XML Encoding Rules Examples

- -

The following examples build on the ones provided in the Text Encoding Rules Examples section. The datastream descriptions are kept the same, except that the encoding method would have to be changed to:

- -
<swe:encoding>
  <swe:XMLEncoding/>
</swe:encoding>
- - -

In the following sections, encoded values were kept identical to the ones used in the text encoding section, in order to facilitate comparison.

- -

B.2.1.  Datastream with records (weather data)

- -

This example is based on the same datastream description as the one provided in Annex B.1.2.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -
<swe:values xmlns:ns="http://www.myorg.com/datasets/id">
  <ns:weatherData>
    <ns:time>2023-03-20T15:40:00Z</ns:time>
    <ns:temp>15.3</ns:temp>
    <ns:press>1014</ns:press>
    <ns:windSpeed>3.5</ns:windSpeed>
    <ns:windDir>56.0</ns:windDir>
  </ns:weatherData>
  <ns:weatherData>
    <ns:time>2023-03-20T15:45:00Z</ns:time>
    <ns:temp>15.4</ns:temp>
    <ns:press>1015</ns:press>
    <ns:windSpeed>5.6</ns:windSpeed>
    <ns:windDir>123.0</ns:windDir>
  </ns:weatherData>
  <ns:weatherData>
    <ns:time>2023-03-20T15:50:00Z</ns:time>
    <ns:temp>15.8</ns:temp>
    <ns:press>1014</ns:press>
    <ns:windSpeed>13.2</ns:windSpeed>
    <ns:windDir>34.0</ns:windDir>
  </ns:weatherData>
  ...
</swe:values>
- -
- -

B.2.2.  Datastream with records and optional fields (navigation data)

- -

This example is based on the same datastream description as the one provided in Annex B.1.3.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -
<swe:values xmlns:ns="urn:myorg:dataset:X156822">
  <ns:navData>
    <ns:time>2007-10-23T15:46:12Z</ns:time>
    <ns:speed>15.3</ns:speed>
    <ns:location>
      <ns:lat>45.3</ns:lat>
      <ns:lon>-90.5</ns:lon>
      <ns:alt>311</ns:alt>
    </ns:location>
  </ns:navData>
  <ns:navData>
    <ns:time>2007-10-23T15:46:22Z</ns:time>
    <ns:speed>25.3</ns:speed>
  </ns:navData>
  <ns:navData>
    <ns:time>2007-10-23T15:46:32Z</ns:time>
    <ns:speed>20.6</ns:speed>
    <ns:location>
      <ns:lat>45.3</ns:lat>
      <ns:lon>-90.6</ns:lon>
      <ns:alt>312</ns:alt>
    </ns:location>
  </ns:navData>
  ...
</swe:values>
- - -

Notice that the optional ‘location’ field in the second stream element has been completely omitted.

-
- -

B.2.3.  Datastream with choice (navigation data)

- -

This example is based on the same datastream description as the one provided in Annex B.1.4.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -
<swe:values xmlns:ns="urn:myorg:dataset:DC4578">
  <ns:message>
    <ns:TEMP>
      <ns:time>2009-05-23T19:36:15Z</ns:time>
      <ns:temp>25.5</ns:temp>
    </ns:TEMP>
  </ns:message>
  <ns:message>
    <ns:TEMP>
      <ns:time>2009-05-23T19:37:15Z</ns:time>
      <ns:temp>25.6</ns:temp>
    </ns:TEMP>
  </ns:message>
  <ns:message>
    <ns:WIND>
      <ns:time>2009-05-23T19:37:17Z</ns:time>
      <ns:wind_speed>56.3</ns:wind_speed>
      <ns:wind_dir>226.3</ns:wind_dir>
    </ns:WIND>
  </ns:message>
  <ns:message>
    <ns:TEMP>
      <ns:time>2009-05-23T19:38:15Z</ns:time>
      <ns:temp>25.5</ns:temp>
    </ns:TEMP>
  </ns:message>
  ...
</swe:values>
- -
- -

B.2.4.  Datastream of variable size 1D arrays (profile series)

- -

This example is based on the same datastream description as the one provided in Annex B.1.6.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -
<swe:values xmlns:ns="urn:myorg:dataset:PS3658">
  <ns:profileData>
    <ns:time>2005-05-16T21:47:12Z</ns:time>
    <ns:profilePoints elementCount="5">
      <ns:point>
        <ns:depth>0</ns:depth>
        <ns:salinity>45</ns:salinity>
      </ns:point>
      <ns:point>
        <ns:depth>10</ns:depth>
        <ns:salinity>20</ns:salinity>
      </ns:point>
      <ns:point>
        <ns:depth>20</ns:depth>
        <ns:salinity>30</ns:salinity>
      </ns:point>
      <ns:point>
        <ns:depth>30</ns:depth>
        <ns:salinity>35</ns:salinity>
      </ns:point>
      <ns:point>
        <ns:depth>40</ns:depth>
        <ns:salinity>40</ns:salinity>
      </ns:point>
    </ns:profilePoints>
  </ns:profileData>
  <ns:profileData>
    <ns:time>2005-05-16T22:43:05Z</ns:time>
    <ns:profilePoints elementCount="4">
      <ns:point>
        <ns:depth>0</ns:depth>
        <ns:salinity>45</ns:salinity>
      </ns:point>
      <ns:point>
        <ns:depth>10</ns:depth>
        <ns:salinity>20</ns:salinity>
      </ns:point>
      <ns:point>
        <ns:depth>20</ns:depth>
        <ns:salinity>30</ns:salinity>
      </ns:point>
      <ns:point>
        <ns:depth>30</ns:depth>
        <ns:salinity>35</ns:salinity>
      </ns:point>
    </ns:profilePoints>
  </ns:profileData>
  ...
</swe:values>
- - -

This example shows how the array size is specified on the ‘profilePoints’ element corresponding to each nested array, and how element local names correspond to the “name” attributes of each component’s parent property.

-
- -

B.2.5.  Datastream with geometry (feature detection)

- -

This example is based on the same datastream description as the one provided in Annex B.1.7.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -
<swe:values xmlns:ns="urn:myorg:dataset:X151451" xmlns:gml="http://www.opengis.net/gml/3.2">
  <ns:detection>
    <ns:time>2007-10-23T15:46:12Z</ns:time>
    <ns:type>Car</ns:type>
    <ns:geom>
      <gml:Polygon srsName="http://www.opengis.net/def/crs/EPSG/0/4326">
        <gml:exterior>
          <gml:LinearRing>
            <gml:posList srsDimension="2">-86.3254 35.4812 -86.3253 35.4812 -86.3253 35.4811 -86.3254 35.4811 -86.3254 35.4812</gml:posList>
          </gml:LinearRing>
        </gml:exterior>
      </gml:Polygon>
    </ns:geom>
  </ns:detection>
  <ns:detection>
    <ns:time>2007-10-23T15:49:03Z</ns:time>
    <ns:type>Truck</ns:type>
    <ns:geom>
      <gml:Polygon srsName="http://www.opengis.net/def/crs/EPSG/0/4326" >
        <gml:exterior>
          <gml:LinearRing>
            <gml:posList srsDimension="2">-86.3254 35.4812 -86.3253 35.4812 -86.3253 35.4811 -86.3254 35.4811 -86.3254 35.4812</gml:posList>
          </gml:LinearRing>
        </gml:exterior>
      </gml:Polygon>
    </ns:geom>
  </ns:detection>
  <ns:detection>
    <ns:time>2007-10-23T15:56:45Z</ns:time>
    <ns:type>Bus</ns:type>
    <ns:geom>
      <gml:Polygon srsName="http://www.opengis.net/def/crs/EPSG/0/4326">
        <gml:exterior>
          <gml:LinearRing>
            <gml:posList srsDimension="2">-86.3254 35.4812 -86.3253 35.4812 -86.3253 35.4811 -86.3254 35.4811 -86.3254 35.4812</gml:posList>
          </gml:LinearRing>
        </gml:exterior>
      </gml:Polygon>
    </ns:geom>
  </ns:detection>
  ...
</swe:values>
- -
-

B.3.  JSON Encoding Rules Examples

- -

The following examples build on the ones provided in the Text Encoding Rules Examples section. The datastream descriptions are kept the same, except that the encoding method would have to be changed to:

- -
<swe:encoding>
  <swe:JSONEncoding/>
</swe:encoding>
- - -

In the following sections, encoded values were kept identical to the ones used in the text encoding section, in order to facilitate comparison.

- -

B.3.1.  DataArray with inline values (curve)

- -

This example is based on the same “DataArray” description as the one provided in Annex B.1.1.

- -

The equivalent JSON description for this “DataArray” is provided below:

- -
{
 
"type": "DataArray",
 
"definition": "http://sweet.jpl.nasa.gov/2.0/mathFunction.owl#Function"
 
"description": "Measurement error vs. temperature",
 
"elementCount": {
   
"type": "Count",
   
"value": 5
 
},
 
"elementType": {
   
"name": "point",
   
"type": "DataRecord",
   
"label": "Error vs. Temperature",
   
"fields": [
     
{
       
"name": "temp",
       
"type": "Quantity",
       
"definition": "http://sweet.jpl.nasa.gov/2.0/physThermo.owl#Temperature",
       
"label": "Temperature",
       
"uom": { "code": "Cel" }
     
},
     
{
       
"name": "error",
       
"type": "Quantity",
       
"definition": "http://sweet.jpl.nasa.gov/2.0/sciUncertainty.owl#Error",
       
"label": "Relative Error",
       
"uom": { "code": "%" }
     
}
   
]
 
},
 
"values": [[0,5], [10,2], [50,2], [80,5], [100,15]]
}
- -
- -

B.3.2.  Datastream with records (weather data)

- -

This example is based on the same datastream description as the one provided in Annex B.1.2.

- -

The following snippet shows how this datastream records are encoded using the JSON encoding method:

- -
[
 
{
   
"time": "2023-03-20T15:40:00Z",
   
"temp": 15.3,
   
"press": 1014,
   
"windSpeed": 3.5,
   
"windDir": 56.0
 
},
 
{
   
"time": "2023-03-20T15:45:00Z",
   
"temp": 15.4,
   
"press": 1015,
   
"windSpeed": 5.6,
   
"windDir": 123.0
 
},
 
{
   
"time": "2023-03-20T15:50:00Z",
   
"temp": 15.8,
   
"press": 1014,
   
"windSpeed": 13.2,
   
"windDir": 34.0
 
},
 
...
]
- -
- -

B.3.3.  Datastream with records and optional fields (navigation data)

- -

This example is based on the same datastream description as the one provided in Annex B.1.3.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -
[
 
{
   
"time": "2007-10-23T15:46:12Z",
   
"speed": 15.3,
   
"location": {
     
"lat": 45.3,
     
"lon": -90.5,
     
"alt": 311
   
}
 
},
 
{
   
"time": "2007-10-23T15:46:22Z",
   
"speed": 25.3,
   
"location": null
 
},
 
{
   
"time": "2007-10-23T15:46:32Z",
   
"speed": 20.6,
   
"location": {
     
"lat": 45.3,
     
"lon": -90.6,
     
"alt": 312
   
}
 
},
 
...
]
- -
- -

B.3.4.  Datastream with choice (navigation data)

- -

This example is based on the same datastream description as the one provided in Annex B.1.4.

- -

The following snippet shows how this datastream records are encoded using the JSON encoding method:

- -
[
 
{
   
"TEMP": {
     
"time": "2009-05-23T19:36:15Z",
     
"temp": 25.5
   
}
 
},
 
{
   
"TEMP": {
     
"time": "2009-05-23T19:37:15Z",
     
"temp": 25.6
   
}
 
},
 
{
   
"WIND": {
     
"time": "2009-05-23T19:37:17Z",
     
"wind_speed": 56.3,
     
"wind_dir": 226.3
   
}
 
},
 
{
   
"TEMP": {
     
"time": "2009-05-23T19:38:15Z",
     
"temp": 25.5
   
}
 
},
 
...
]
- -
- -

B.3.5.  Fixed size 2D array (stress matrix)

- -

This example is based on the same “Matrix” description as the one provided in Annex B.1.5.

- -

The equivalent JSON description for this “Matrix” is provided below:

- -
{
 
"type": "Matrix",
 
"definition": "http://sweet.jpl.nasa.gov/2.0/physPressure.owl#Stress"
 
"elementCount": {
   
"type": "Count",
   
"value": 3
 
},
 
"elementType": {
   
"name": "row",
   
"type": "Matrix",
   
"elementCount": {
     
"type": "Count",
     
"value": 3
   
},
   
"elementType": {
     
"name": "coef",
     
"type": "Quantity",
     
"definition": "http://sweet.jpl.nasa.gov/2.0/mathVector.owl#Coordinate",
     
"uom": { "code": "MPa" }
   
}
 
},
 
"values": [[0.36,0.48,-0.8], [-0.8,0.6,0.0], [0.48,0.64,0.6]]
}
- -
- -

B.3.6.  Datastream of variable size 1D arrays (profile series)

- -

This example is based on the same datastream description as the one provided in Annex B.1.6.

- -

The following snippet shows how this datastream records are encoded using the JSON encoding method:

- -
[
 
{
   
"time": "2005-05-16T21:47:12Z",
   
"profilePoints": [
     
{ "depth": 0, "salinity": 45 },
     
{ "depth": 10, "salinity": 20 },
     
{ "depth": 20, "salinity": 30 },
     
{ "depth": 30, "salinity": 35 },
     
{ "depth": 40, "salinity": 40 }
   
]
 
},
 
{
   
"time": "2005-05-16T22:43:05Z",
   
"profilePoints": [
     
{ "depth": 0, "salinity": 45 },
     
{ "depth": 10, "salinity": 20 },
     
{ "depth": 20, "salinity": 30 },
     
{ "depth": 30, "salinity": 35 }
   
]
 
},
 
{
   
"time": "2005-05-16T23:40:52Z",
   
"profilePoints": [
     
{ "depth": 0, "salinity": 45 },
     
{ "depth": 10, "salinity": 20 },
     
{ "depth": 20, "salinity": 30 },
     
{ "depth": 30, "salinity": 35 },
     
{ "depth": 40, "salinity": 40 }
   
]
 
},
 
...
]
- -
- -

B.3.7.  Datastream with geometry (feature detection)

- -

This example is based on the same datastream description as the one provided in Annex B.1.7.

- -

The following snippet shows how this datastream records are encoded using the JSON encoding method:

- -
[
 
{
   
"time": "2007-10-23T15:46:12Z",
   
"type": "Car",
   
"geom": {
     
"type": "Point",
     
"coordinates": [-86.3254, 35.4812]
   
}
 
},
 
{
   
"time": "2007-10-23T15:49:03Z",
   
"type": "Truck",
   
"geom": {
     
"type": "Polygon",
     
"coordinates": [
       
[-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812]
     
]
   
}
 
},
 
{
   
"time": "2007-10-23T15:56:45Z",
   
"type": "Bus",
   
"geom": {
     
"type": "Polygon",
     
"coordinates": [
       
[-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812]
     
]
   
}
 
},
 
...
]
- -
-

Annex C
(informative)
Relationship with other ISO models

C.1.  Feature model

- -

SWE “Records” can sometimes be seen as feature data from which GML feature representations could be derived. Even if it is true that a SWE “Record” contains values of feature properties, it does not always represent an object like a “Feature” does. The “Record” is simply a logical collection of fields that may be grouped together for a different reason than the fact that they all represent properties of the same object.

- -

The “Feature” model is a higher level model that is used to regroup property values inside the objects that they correspond to, as well as associate a meaning to the object itself.

- -

A good example is a set of weather observations obtained from different sensors that may be grouped into a single “Record” in SWE Common, but which does not constitute a feature in the GIS sense.

-

C.2.  Coverage model

- -

SWE “Arrays” can sometimes be interpreted as coverage range data or grid data. However, SWE data arrays are lower level data types and don’t constitute a “Coverage” in themselves. The “Coverage” model described in OGC Abstract Topic 6 (OGC 07-011) can be used on top of the SWE “Array” model (which only provides means for describing and encoding the data), in order to provide a stronger link between range data and domain definition.

- -

Additionally, sensor descriptions given in SensorML (and thus using the SWE Common model) can be used to define a geo-referencing transformation that can be associated with a coverage via the same model.

-

Annex D
(informative)
Revision History

DateReleaseEditorPrimary clauses modifiedDescription
2008-08-202.0 draftAlexandre RobinAllInitial draft version
2008-10-302.0 draftIngo SimonisAllGeneral revision
2009-10-302.0 draftAlexandre RobinAllDraft candidate standard
2009-11-042.0 draftPeter TaylorClauses 6 and 7Additional examples, minor edits
2009-11-102.0 draftAlexandre RobinAllGeneral revision, added section 8
2010-01-152.0 draftAlexandre RobinAllClarifications in requirements
2010-03-102.0 finalAlexandre RobinAllCorrections following RFC comments
2023-03-072.1 draftAlexandre RobinAllConversion to AsciiDoc / Metanorma
2023-03-082.1 draftAlexandre RobinClauses 7,8,9Removed requirements that were redundant with dependencies
2023-03-162.1 draftAlexandre RobinClause 7,8,9Added Geometry class
2023-03-212.1 draftAlexandre RobinClause 9Added JSON datastream encoding rules
2023-03-212.1 draftAlexandre RobinClause 9Clarified use of media types
2024-04-293.0 draftAlexandre RobinAllRefactored to v3.0, removed XML encoding sections

Bibliography

- -

TODO

NOTE:    The TC has approved Springer LNCS as the official document citation type.

Springer LNCS is widely used in technical and computer science journals and other publications

– Actual References:

[n] Journal: Author Surname, A.: Title. Publication Title. Volume number, Issue number, Pages Used (Year Published)

[1]  OGC: OGC Testbed 12 Annex B: Architecture (2015).

- - - - -
- - - - - - - - - - - - - - - - - - - diff --git a/swecommon/standard/24-014.presentation.xml b/swecommon/standard/24-014.presentation.xml deleted file mode 100644 index 05bda3bf..00000000 --- a/swecommon/standard/24-014.presentation.xml +++ /dev/null @@ -1,10984 +0,0 @@ - - - -OGC SWE Common Data Model Encoding Standard -http://www.opengis.net/doc/DIS/SWE/3.024-01424-014yyyy-mm-ddyyyy-mm-ddyyyy-mm-dd -GeoRobotix, Inc. - -Botts Innovative Research, Inc. - -Cesium GS, Inc. - -52° North Initiative for Geospatial Open Source Software GmbH - -Pelagis Data Solutions - -National Geospatial-Intelligence Agency (NGA) - -Alexandre Robin - -Open Geospatial Consortium -3.0.0en

The primary focus of the SWE Common Data Model is to define and package data in a self-describing and semantically enabled way. The main objective is to achieve interoperability, first at the syntactic level, and later at the semantic level (by using ontologies and probably semantic mediation) so that (sensor) data can be better understood by machines, processed automatically in complex workflows and easily shared between intelligent nodes.

- -

This standard is one of several implementation standards produced under OGC’s Connected Systems activity, and is a revision of content that was previously developed in the context of the Sensor Web Enablement initiative. These common data models are intended to be used in various OGC standards, and in particular, SensorML and OGC API - Connected Systems.

-
draftDraft2024 -Open Geospatial Consortium -ogcdocOGC documenthtmlSWEsensorsensorwebconnected systemsjsonencodingobservationcommandtaskingpropertystandardimplementationtechnical
ScopeSymbols and abbreviated termsAbbreviated termsSymbolsContentsIntroductionPrefaceAbstractAcknowledgementsTerms and definitionsTerms, definitions, symbols and abbreviated termsTerms, definitions and symbolsTerms, definitions and abbreviated termsNormative referencesBibliographyPrefaceClauseAnnexAppendixcontinued

No terms and definitions are listed in this document.

-

This document uses the terms defined in OGC Policy Directive 49, which is based on the ISO/IEC Directives, Part 2, Rules for the structure and drafting of International Standards. In particular, the word “shall” (not “must”) is the verb form used to indicate a requirement to be strictly followed to conform to this document and OGC documents do not use the equivalent phrases in the ISO/IEC Directives, Part 2.

-

This document also uses terms defined in the OGC Standard for Modular specifications (OGC 08-131r3), also known as the 'ModSpec'. The definitions of terms such as standard, specification, requirement, and conformance test are provided in the ModSpec.

-

For the purposes of this document, the following additional terms and definitions apply.

-
The following documents are referred to in the text in such a way that some or all of their content constitutes requirements of this document. For dated references, only the edition cited applies. For undated references, the latest edition of the referenced document (including any amendments) applies.There are no normative references in this document.

This document uses the terms defined in OGC Policy Directive 49, which is based on the ISO/IEC Directives, Part 2, Rules for the structure and drafting of International Standards. In particular, the word “shall” (not “must”) is the verb form used to indicate a requirement to be strictly followed to conform to this document and OGC documents do not use the equivalent phrases in the ISO/IEC Directives, Part 2.

-

This document also uses terms defined in the OGC Standard for Modular specifications (OGC 08-131r3), also known as the 'ModSpec'. The definitions of terms such as standard, specification, requirement, and conformance test are provided in the ModSpec.

-

For the purposes of this document, the terms and definitions given in % additionally apply.

-

This document uses the terms defined in OGC Policy Directive 49, which is based on the ISO/IEC Directives, Part 2, Rules for the structure and drafting of International Standards. In particular, the word “shall” (not “must”) is the verb form used to indicate a requirement to be strictly followed to conform to this document and OGC documents do not use the equivalent phrases in the ISO/IEC Directives, Part 2.

-

This document also uses terms defined in the OGC Standard for Modular specifications (OGC 08-131r3), also known as the 'ModSpec'. The definitions of terms such as standard, specification, requirement, and conformance test are provided in the ModSpec.

-

For the purposes of this document, the terms and definitions given in % and the following additionally apply.

-
(%)%1 and %2%1, and %2%1 or %2%1, or %2%1 and %2%1 or %2%1 from %2%1 to %2%1, %2%1 %2spellout-ordinalNOTENoteNote % to entryListDefinition ListFigureDiagramFormulaFormulaTableRequirementRecommendationPermissionBoxRecommendation testRequirement testPermission testRecommendations classRequirements classPermissions classAbstract testConformance classKeyExampleExamplewherewhereWhole of textdraftinformativenormativemodifiedadaptedDEPRECATEDSOURCEandAll Parts%Spellout editioneditionversionList of FiguresList of TablesList of RecommendationsJanuaryFebruaryMarchAprilMayJuneJulyAugustSeptemberOctoberNovemberDecemberObligationDangerWarningCautionImportantSafety PrecautionsEditorial NoteSectionClausePartParagraphChapterPageTableAnnexFigureExampleNoteFormulamfncommonsgdualplpreppartadjadvnounverbdeprecatessupersedesnarrowerbroaderequivalentcomparecontrastseesee alsoClauseClausesAnnexAnnexesAppendixAppendixesNoteNotesNote % to entryNotes % to entryListListsFigureFiguresFormulaFormulasTableTablesRequirementRequirementsRecommendationRecommendationsPermissionPermissionsExampleExamplesPartPartsSectionSectionsParagraphParagraphsChapterChaptersPagePagesADMITTEDSubmittersContributorsTable of FiguresNo security considerations have been made for this document.Submission DateApproval DatePublication DateAuthorEditorContributorDraftWork Item DraftCandidate SWG DraftCandidate OAB Review DraftCandidate Public RFC DraftCandidate TC Vote DraftApprovedPublishedDeprecatedRescindedRetiredenLatn
Table
_c783dac9-3b6e-4a0f-8f06-94547924f0fe/req/core
_88c2dfd0-84fc-4ecc-85ac-237ab6d734ff/req/core/core-concepts-used
_f8620212-5b3c-4e04-9d42-d8bd09d59a82/req/core/boolean-rep-valid
_4240aa38-8d6a-4103-86ea-cc6648ff1f18/req/core/categorical-rep-valid
_eab9d5ff-ab46-456a-a4b8-ef6d53c30cd1/req/core/numerical-rep-valid
_7631e6f0-4823-448d-8ab0-54ab9802de11/req/core/countable-rep-valid
_0882f36b-35ef-46cf-93c3-9323b065a80f/req/core/textual-rep-valid
_b2e0c151-fdf0-4ee3-b01f-d8590839c349/req/core/semantics-defined
_69b6e18d-40b6-43c7-98f2-edf5c2565198/req/core/semantics-resolvable
_3743b2a0-3fee-4e97-98b9-6d35478ac23a/req/core/temporal-frame-defined
_94dcb6c4-8d28-4484-a2cf-d6a42b16e3d5/req/core/spatial-frame-defined
_a2d4276d-f14d-4529-8817-2917aa3d37fc/req/core/nil-reasons-defined
_1d82d6d3-0ae8-4594-8a38-6de9e0394035/req/core/aggregates-model-valid
_ae68587d-81a7-46f6-823f-3b28e20f0f55/req/core/encoding-method-valid
_93d9c0ea-a29c-4fab-815a-4e42b3251ee6/req/uml-simple-components
_1a5c5ad9-f674-42e4-951f-fd5c40093863/req/uml-simple-components/package-fully-implemented
_9cdb685a-704f-491c-a922-9631f674f977/req/uml-simple-components/iso19103-implemented
_8ae269f7-e9af-45d9-b9f0-b5c6b196f265/req/uml-simple-components/iso19108-implemented
_fef89ebe-4efa-4e94-b65f-123160405fe6/req/uml-simple-components/definition-present
_13ff592e-79f7-47b3-a537-95f13c348eb1/req/uml-simple-components/axis-valid
_98ea2092-8182-4ba0-967a-34d1b0394880/req/uml-simple-components/axis-defined
_26f529b1-f31d-48dc-8adc-975c3c610107/req/uml-simple-components/ref-frame-defined
_b2c59889-26de-49f0-9feb-04bf692d1664/req/uml-simple-components/value-constraint-valid
_6254611d-a8e4-4e31-8484-2277c169bd0b/req/uml-simple-components/value-attribute-present
_f426ada1-24ba-4db5-9053-0fc61be0252b/req/uml-simple-components/category-constraint-valid
_63f8b65c-d1ad-4db7-8801-45cd3733b03f/req/uml-simple-components/category-enum-defined
_9fe57107-34bb-4ce0-a717-a3a32392627b/req/uml-simple-components/category-value-valid
_4dcc1c14-2e3f-4f17-9c4f-4cd5b77dc068/req/uml-simple-components/time-ref-frame-defined
_64f496e7-0b53-4db8-b8b5-5aec8a087efd/req/uml-simple-components/time-ref-time-valid
_0cc1bdb2-0bd5-4d35-9bd9-db3426f3bd7b/req/uml-simple-components/time-local-frame-valid
_6c8a5454-a826-4c71-9c99-7eed8879e98c/req/uml-simple-components/range-value-valid
_ddd05e78-0c48-423b-92a8-8f1d48bb8691/req/uml-simple-components/category-range-valid
_d7550e09-a2e0-4202-8c7f-c2f15de40bd7/req/uml-simple-components/category-range-codespace-order
_4d79c5e6-fd95-49c0-9f65-bec40869a9dd/req/uml-simple-components/time-range-valid
_4334e486-cf19-4afe-8c78-0c08fc195f8e/req/uml-simple-components/nil-reason-resolvable
_f964331c-8aa5-4c19-8c34-82c17cd99144/req/uml-simple-components/nil-value-type-coherent
_ca13f829-dc08-4258-8fcf-23091663547c/req/uml-simple-components/allowed-values-unit-coherent
_aeb99422-f2a8-4fcc-b573-b6faa5792d40/req/uml-record-components
_c0d2fb82-bb35-490e-ad51-d8b7c5ffd788/req/uml-record-components/package-fully-implemented
_e3f0a203-b9bd-4438-9d0c-1cff58e841b2/req/uml-record-components/record-field-name-unique
_6128cc09-457c-43a6-a569-119186a88c8e/req/uml-record-components/vector-coord-name-unique
_dadf02b9-d9b9-4b52-b81b-f64179f51bdc/req/uml-record-components/vector-component-no-ref-frame
_cea0b66e-64e4-4ffd-ab88-27578ffb8b97/req/uml-record-components/vector-component-axis-defined
_ab5d81c9-474b-4c17-8523-850bb60a5e54/req/uml-record-components/vector-local-frame-valid
_bdea6f24-1405-4c04-844a-3493d71297b4/req/uml-choice-components
_9a5afaf6-931b-43d3-9f4c-9ecb01fa4ac3/req/uml-choice-components/package-fully-implemented
_60142650-932c-4494-add8-9dbc3184060c/req/uml-choice-components/choice-item-name-unique
_5b87431f-e587-43e2-bf19-7ba1ff71d7d1/req/uml-block-components
_a7009d09-dd93-46c9-a65f-25a307c3dce4/req/uml-block-components/package-fully-implemented
_fc63c921-694b-4080-9d89-d2c59b98691e/req/uml-block-components/array-component-no-value
_8299a5db-fa0b-4328-8f69-6346e76b65a4/req/uml-block-components/array-values-properly-encoded
_54a0e65c-4347-4ebc-b7cc-04055b2b1928/req/uml-block-components/matrix-element-type-valid
_24a3ba69-97e1-42de-a54f-d30718c8520c/req/uml-block-components/datastream-array-valid
_485d508b-cb4b-4ab0-a41b-ff6d87bf8569/req/uml-geom-components
_b8f8c1e9-094f-4cff-85fb-9c9ff34f1f05/req/uml-geom-components/package-fully-implemented
_0e74b495-88e9-49b4-a024-6a4a88627fd7/req/uml-geom-components/srs-valid
_47d85457-1e3e-4cb5-9871-18032d49b970/req/uml-geom-components/geom-value-valid
_b137f877-f72d-4c70-9c12-a60fec7a5ed7/req/uml-simple-encodings
_e8e82cf0-0045-43ac-8876-db1bdd684b88/req/uml-simple-encodings/package-fully-implemented
_bc0a786e-33c7-4d6b-9b3f-04dd03442129/req/uml-advanced-encodings
_fffd554b-1cda-4108-b38e-82fc48979360/req/uml-advanced-encodings/package-fully-implemented
_a8bc3622-f2c8-488f-9612-dce609a8e930/req/json-simple-components
_1ffa4ccc-b6a6-4a86-b2e7-4ca6cca9468b/req/json-simple-components/schema-valid
_7a79fa83-2ffe-4df9-8569-2fa2642a13f0/req/json-simple-components/special-numerical-values
_7d299258-3353-427f-8e07-d632371689b8/req/json-simple-components/definition-resolvable
_1e58f94d-af1e-44aa-89f2-d7bf17924ba0/req/json-simple-components/inline-value-constraint-valid
_44472ff4-cc49-4025-b374-f4700a518476/req/json-simple-components/ucum-code-used
_dc742332-e6f6-43be-aa50-99e0062aae09/req/json-simple-components/iso8601-uom-used
_c7aa1491-b30d-49de-9c25-0a725374ab4f/req/json-record-components
_39e495de-1a08-4d91-9cb6-3c5f500cb2dd/req/json-choice-components
_b3aba94f-0f74-4685-8471-bb7c515b58e9/req/json-block-components
_8fc2ad9d-ce4c-40d8-b5ab-297b22bcce8c/req/json-geom-components
_689f3fd1-2048-4f2b-8f7f-d111aa19d2a6/req/json-simple-encodings
_61ecb26d-a1cb-487a-bf61-a317e09d59ea/req/json-advanced-encodings
_0315ad14-c240-4c89-9928-4ec581b16fb8/req/xsd-advanced-encodings/ref-syntax-valid
_4b65d294-16d9-4c4e-9f76-b5510b62f162/req/xsd-advanced-encodings/scalar-ref-component-valid
_6a5ebfb9-2ec1-4ab2-9791-7e01eb73ae49/req/xsd-advanced-encodings/datatype-valid
_b2ad778c-c633-41ee-869b-64a6e44f973c/req/xsd-advanced-encodings/datatype-compatible
_7655ef6a-f6d5-4d43-baa3-7a12ad0ea707/req/xsd-advanced-encodings/no-datatype-length
_355d1fef-8a6b-4878-9b5e-54dfae36f499/req/general-encoding-rules
_89fc3a84-6279-4132-9630-fb59f3a1ff2e/req/general-encoding-rules/record-encoding-rule
_e60d1a52-437b-4f4b-b48d-ce5fb5400a24/req/general-encoding-rules/choice-encoding-rule
_cc90cb43-b123-4376-9386-ab59b2f34d4b/req/general-encoding-rules/array-encoding-rule
_867a66a0-1550-4e6d-baaa-232197bd9ac7/req/general-encoding-rules/array-size-encoding-rule
_9d547d80-5023-4749-b546-48c2be01e830/req/json-encoding-rules
_f7931ef7-61f3-4f8e-86c3-b3e37b36a35d/req/json-encodings-rules/json-valid
_b791f15f-e2d8-419e-abcc-c40d03ad999f/req/json-encoding-rules/scalar-value-valid
_01fae0ae-fb26-4424-8d57-0695599de979/req/json-encoding-rules/range-value-valid
_0ea0a97a-06dc-4d61-8f41-455473681b75/req/json-encoding-rules/record-object-valid
_cb1420b9-20ac-42f8-b02b-933064665c0e/req/json-encoding-rules/vector-object-valid
_45d3463d-3906-4eac-8925-8c895a3f457b/req/json-encoding-rules/choice-object-valid
_e22e35dd-587d-433d-8c30-bf9238a07c86/req/json-encoding-rules/array-values-valid
_9504cc66-103d-44ce-bd91-7094bc649dad/req/json-encodings-rules/geometry-valid
_642738e4-c199-4b13-b412-ce2c6179a4f2/req/text-encoding-rules
_1d3ef339-3c2b-48af-b362-04e79a37c63b/req/text-encodings-rules/abnf-syntax-valid
_7ba0fee3-3cd9-4fc4-9cf7-8076ba9850ae/req/text-encodings-rules/separators-valid
_3621ff12-3408-4556-975f-2fd6bd59862e/req/text-encodings-rules/optional-field-marker-present
_f90d70e7-166e-4876-81ad-1fb269ec79e6/req/text-encodings-rules/choice-selection-marker-valid
_d1932a67-cdd1-40e4-a4d2-7fe4aa54341b/req/text-encodings-rules/geometry-valid
_3a14423c-bd56-4664-bcd3-d9a197f8f644/req/binary-encoding-rules
_bef43c29-cb7d-4a45-861b-fcc28897581d/req/binary-encoding-rules/abnf-syntax-valid
_df6eaa05-0f3e-4ff2-96bc-e9a01c48449c/req/binary-encoding-rules/type-encoding-valid
_d0a6761e-e35a-442c-95e8-48239a2d28f7/req/binary-encoding-rules/base64-translation-applied
_38c66334-c281-47b2-8eaf-99df349d5fd7/req/binary-encoding-rules/optional-field-marker-present
_0a436829-ca39-468e-b6bd-ddf5175fa59d/req/binary-encoding-rules/choice-selection-marker-valid
_daf6760b-767e-43de-8970-a811cd101bc3/req/binary-encodings-rules/geometry-valid
_e293b62e-2f96-41a8-bb7c-649f8996d416/conf/core
_eb4c4842-54aa-4a11-a560-4f524abc11cb/conf/core/core-concepts-used
_e2ff1447-eaac-4132-ab90-0f5e3294828b/conf/core/boolean-rep-valid
_6cd04c8c-0ace-4275-b5b1-635dd81ae9cd/conf/core/categorical-rep-valid
_88e8af44-fadb-4820-a6f5-68494e86ef2a/conf/core/numerical-rep-valid
_1eef2b04-fb13-4bf2-a34d-ace361f6409c/conf/core/countable-rep-valid
_b294a13b-fc57-4c8d-8a21-eee14e10f9b0/conf/core/textual-rep-valid
_ad75403e-dc41-488e-ab57-17eba9b2718d/conf/core/semantics-defined
_b42d0d27-71a7-40af-a5b1-c53450d15462/conf/core/semantics-resolvable
_be7488de-d4ef-4671-a905-a7dd439105d5/conf/core/temporal-frame-defined
_4db3dc0b-3fc3-4425-9a9b-91175bd90635/conf/core/spatial-frame-defined
_9fcdfedb-3af2-4883-9d1f-649e14fd1bc0/conf/core/nil-reasons-defined
_5cb4b894-d405-4881-905a-322cb5b69315/conf/core/aggregates-model-valid
_c6fb05a1-a9de-4dc6-a2f6-138f4a17bece/conf/core/encoding-method-valid
_c8bdfb37-b249-40f1-96ca-62396b0a28da/conf/uml-simple-components
_9f99c3b0-4926-44fe-9b3d-2d9f0ead6855/conf/uml-simple-components/package-fully-implemented
_76d2eb8e-f7fa-42c0-b9c9-5b1ff0ed1077/conf/uml-simple-components/iso19103-implemented
_4c850ad4-c9f2-412f-a097-4551cd1696dd/conf/uml-simple-components/iso19108-implemented
_2ed4af97-68bd-458a-8e11-5e44a329a44b/conf/uml-simple-components/definition-present
_e80fc58b-da84-4ea0-9f7e-95cab0cf293c/conf/uml-simple-components/axis-valid
_f1a7ede2-8107-4253-884c-7c48fc01d169/conf/uml-simple-components/axis-defined
_5a5f66e8-aa69-4e04-bdaa-166110ba9316/conf/uml-simple-components/ref-frame-defined
_d633efe9-d718-4df7-93c6-897d54b644b7/conf/uml-simple-components/value-constraint-valid
_fb3af4c8-81d5-4897-8e88-bd2a2456714c/conf/uml-simple-components/value-attribute-present
_82f39c2c-b858-4e7e-ad40-d77333aa28b0/conf/uml-simple-components/category-constraint-valid
_a6119fb5-be85-4604-a22e-18f09a36001e/conf/uml-simple-components/category-enum-defined
_58d2dd0d-bb77-4e90-941f-4d5e7dc9c519/conf/uml-simple-components/category-value-valid
_aff2c624-40f5-4c26-8987-f272d16febd8/conf/uml-simple-components/time-ref-frame-defined
_f0a50b34-acb0-46fd-aa7d-bc75314ff29d/conf/uml-simple-components/time-ref-time-valid
_3474e1a9-fd5d-4263-a896-ed28f2d02f26/conf/uml-simple-components/time-local-frame-valid
_30017d56-699a-4218-a95e-fe7efa9bd9ca/conf/uml-simple-components/range-value-valid
_8cd09a4f-5a87-4d6d-82ff-e7fa827ac0d5/conf/uml-simple-components/category-range-valid
_da68f495-2de4-4ca2-bb15-cd215f8db9f7/conf/uml-simple-components/category-range-codespace-order
_7b8c8ad0-2c99-44d9-9001-6b33437e3ac4/conf/uml-simple-components/time-range-valid
_189ea1fe-cbf0-4430-9636-046fe0c5ee9e/conf/uml-simple-components/nil-reason-resolvable
_d87ed7ab-689d-448b-ae3c-cd71f0f69ef5/conf/uml-simple-components/nil-value-type-coherent
_1f657bd1-2e2f-4c13-8120-cc421b8b859c/conf/uml-simple-components/allowed-values-unit-coherent
_0a98c237-f17f-4409-8eed-1057b8fd1ffd/conf/uml-record-components
_390a8a16-c216-4ec5-9ea6-85536d52b939/conf/uml-record-components/package-fully-implemented
_94380548-04b7-40ff-9e21-251abbb7927c/conf/uml-record-components/record-field-name-unique
_a823b131-da50-45f5-a899-863aa67e571d/conf/uml-record-components/vector-coord-name-unique
_1f77657f-ff17-42b6-bd7c-1ccfc8c66eea/conf/uml-record-components/vector-component-no-ref-frame
_9219bee8-129c-42e3-a2c6-4f980e80e993/conf/uml-record-components/vector-component-axis-defined
_d39028da-521c-4ae2-942c-4d4b68f6e108/conf/uml-record-components/vector-local-frame-valid
_8596ac1f-e4f7-4783-a50f-978ce812741c/conf/uml-choice-components
_c1644a67-536d-4443-938c-6bc770d6e7ea/conf/uml-choice-components/package-fully-implemented
_bdb0dc0d-08e5-49b1-abb2-e2ec31d7db04/conf/uml-choice-components/choice-item-name-unique
_3b772f72-e7f4-4729-872f-0099b4d42cfe/conf/uml-block-components
_48c143b6-00b3-474c-bf39-da34dcfdddf9/conf/uml-block-components/package-fully-implemented
_df3e2226-ba68-47cc-8657-4ed58c088061/conf/uml-block-components/array-component-no-value
_b8eaa866-e1d4-45c8-a358-9b3f20fccf21/conf/uml-block-components/array-values-properly-encoded
_47c41a1d-0343-4b6a-8f5f-557fd3bd3abc/conf/uml-block-components/matrix-element-type-valid
_7e6ec960-6b4b-4f28-8d11-7c3ab0097a18/conf/uml-simple-encodings
_9ca1e6b1-3968-4a9b-aaae-0a06c7bed739/conf/uml-simple-encodings/package-fully-implemented
_cd4f0a4a-1a3b-4189-8ec0-366e54c88d75/conf/uml-advanced-encodings
_1b1770cf-24eb-4266-bb6d-07791893ca64/conf/uml-advanced-encodings/package-fully-implemented
_cb106cc9-f555-4be3-a529-afec7a0974f0/conf/general-encoding-rules
_c076053c-228e-40c0-8b15-f3f4827af898/conf/general-encoding-rules/record-encoding-rule
_a412618e-3411-4b17-a5a7-0ff999c71d55/conf/general-encoding-rules/choice-encoding-rule
_e2d85f61-db1a-43d7-be63-cb468c3b2e64/conf/general-encoding-rules/array-encoding-rule
_4f35f829-cd68-4f8b-b40d-62715ccb831a/conf/general-encoding-rules/array-size-encoding-rule
_18767d78-4f8a-474e-80f5-8ee1f9b6d768/conf/text-encoding-rules
_f07e06af-668c-4e14-a3b6-d7545b81d3ca/conf/text-encoding-rules/abnf-syntax-valid
_aa68d1a7-f5ef-41bb-a66d-198786798afe/conf/text-encoding-rules/separators-valid
_3bc64378-83f2-4d9c-a738-e9bd52cc37cc/conf/text-encoding-rules/optional-field-marker-present
_3ecaf503-5dc7-49ac-8c4a-9c4b3bab2aa1/conf/text-encoding-rules/choice-selection-marker-valid
_e83a02ca-9b14-4552-a6ac-9b74127c1d02/conf/binary-encoding-rules
_fdaa758c-ed4b-4453-9c56-fda1b10b45e4/conf/binary-encoding-rules/abnf-syntax-valid
_563b222b-2d5c-4050-a1cb-15d7fd36c689/conf/binary-encoding-rules/type-encoding-valid
_c3ca1b98-9e1f-49bb-bf58-1afd7a7a9afa/conf/binary-encoding-rules/base64-translation-applied
_4bf64024-f7f6-4aa3-80a7-9b8128f0b2ac/conf/binary-encoding-rules/optional-field-marker-present
_dc03e74b-3d73-43dd-a43a-0f1b0f5f7c7c/conf/binary-encoding-rules/choice-selection-marker-valid
TOC Heading Levels2HTML TOC Heading Levels2DOC TOC Heading Levels2 - -OGC SWE Common Data Model Encoding Standard -http://www.opengis.net/doc/DIS/SWE/3.024-01424-014yyyy-mm-ddyyyy-mm-ddyyyy-mm-dd -GeoRobotix, Inc. - -Botts Innovative Research, Inc. - -Cesium GS, Inc. - -52° North Initiative for Geospatial Open Source Software GmbH - -Pelagis Data Solutions - -National Geospatial-Intelligence Agency (NGA) - -Alexandre Robin - -Open Geospatial Consortium -3.0.0enLatnThe primary focus of the SWE Common Data Model is to define and package data in a self-describing and semantically enabled way. The main objective is to achieve interoperability, first at the syntactic level, and later at the semantic level (by using ontologies and probably semantic mediation) so that (sensor) data can be better understood by machines, processed automatically in complex workflows and easily shared between intelligent nodes. - -This standard is one of several implementation standards produced under OGC’s Connected Systems activity, and is a revision of content that was previously developed in the context of the Sensor Web Enablement initiative. These common data models are intended to be used in various OGC standards, and in particular, SensorML and OGC API - Connected Systems. -draft2024 -Open Geospatial Consortium -ogcdocOGC documenthtmlSWEsensorsensorwebconnected systemsjsonencodingobservationcommandtaskingpropertystandardimplementationtechnical_c783dac9-3b6e-4a0f-8f06-94547924f0fe/req/core_88c2dfd0-84fc-4ecc-85ac-237ab6d734ff/req/core/core-concepts-used_f8620212-5b3c-4e04-9d42-d8bd09d59a82/req/core/boolean-rep-valid_4240aa38-8d6a-4103-86ea-cc6648ff1f18/req/core/categorical-rep-valid_eab9d5ff-ab46-456a-a4b8-ef6d53c30cd1/req/core/numerical-rep-valid_7631e6f0-4823-448d-8ab0-54ab9802de11/req/core/countable-rep-valid_0882f36b-35ef-46cf-93c3-9323b065a80f/req/core/textual-rep-valid_b2e0c151-fdf0-4ee3-b01f-d8590839c349/req/core/semantics-defined_69b6e18d-40b6-43c7-98f2-edf5c2565198/req/core/semantics-resolvable_3743b2a0-3fee-4e97-98b9-6d35478ac23a/req/core/temporal-frame-defined_94dcb6c4-8d28-4484-a2cf-d6a42b16e3d5/req/core/spatial-frame-defined_a2d4276d-f14d-4529-8817-2917aa3d37fc/req/core/nil-reasons-defined_1d82d6d3-0ae8-4594-8a38-6de9e0394035/req/core/aggregates-model-valid_ae68587d-81a7-46f6-823f-3b28e20f0f55/req/core/encoding-method-valid_93d9c0ea-a29c-4fab-815a-4e42b3251ee6/req/uml-simple-components_1a5c5ad9-f674-42e4-951f-fd5c40093863/req/uml-simple-components/package-fully-implemented_9cdb685a-704f-491c-a922-9631f674f977/req/uml-simple-components/iso19103-implemented_8ae269f7-e9af-45d9-b9f0-b5c6b196f265/req/uml-simple-components/iso19108-implemented_fef89ebe-4efa-4e94-b65f-123160405fe6/req/uml-simple-components/definition-present_13ff592e-79f7-47b3-a537-95f13c348eb1/req/uml-simple-components/axis-valid_98ea2092-8182-4ba0-967a-34d1b0394880/req/uml-simple-components/axis-defined_26f529b1-f31d-48dc-8adc-975c3c610107/req/uml-simple-components/ref-frame-defined_b2c59889-26de-49f0-9feb-04bf692d1664/req/uml-simple-components/value-constraint-valid_6254611d-a8e4-4e31-8484-2277c169bd0b/req/uml-simple-components/value-attribute-present_f426ada1-24ba-4db5-9053-0fc61be0252b/req/uml-simple-components/category-constraint-valid_63f8b65c-d1ad-4db7-8801-45cd3733b03f/req/uml-simple-components/category-enum-defined_9fe57107-34bb-4ce0-a717-a3a32392627b/req/uml-simple-components/category-value-valid_4dcc1c14-2e3f-4f17-9c4f-4cd5b77dc068/req/uml-simple-components/time-ref-frame-defined_64f496e7-0b53-4db8-b8b5-5aec8a087efd/req/uml-simple-components/time-ref-time-valid_0cc1bdb2-0bd5-4d35-9bd9-db3426f3bd7b/req/uml-simple-components/time-local-frame-valid_6c8a5454-a826-4c71-9c99-7eed8879e98c/req/uml-simple-components/range-value-valid_ddd05e78-0c48-423b-92a8-8f1d48bb8691/req/uml-simple-components/category-range-valid_d7550e09-a2e0-4202-8c7f-c2f15de40bd7/req/uml-simple-components/category-range-codespace-order_4d79c5e6-fd95-49c0-9f65-bec40869a9dd/req/uml-simple-components/time-range-valid_4334e486-cf19-4afe-8c78-0c08fc195f8e/req/uml-simple-components/nil-reason-resolvable_f964331c-8aa5-4c19-8c34-82c17cd99144/req/uml-simple-components/nil-value-type-coherent_ca13f829-dc08-4258-8fcf-23091663547c/req/uml-simple-components/allowed-values-unit-coherent_aeb99422-f2a8-4fcc-b573-b6faa5792d40/req/uml-record-components_c0d2fb82-bb35-490e-ad51-d8b7c5ffd788/req/uml-record-components/package-fully-implemented_e3f0a203-b9bd-4438-9d0c-1cff58e841b2/req/uml-record-components/record-field-name-unique_6128cc09-457c-43a6-a569-119186a88c8e/req/uml-record-components/vector-coord-name-unique_dadf02b9-d9b9-4b52-b81b-f64179f51bdc/req/uml-record-components/vector-component-no-ref-frame_cea0b66e-64e4-4ffd-ab88-27578ffb8b97/req/uml-record-components/vector-component-axis-defined_ab5d81c9-474b-4c17-8523-850bb60a5e54/req/uml-record-components/vector-local-frame-valid_bdea6f24-1405-4c04-844a-3493d71297b4/req/uml-choice-components_9a5afaf6-931b-43d3-9f4c-9ecb01fa4ac3/req/uml-choice-components/package-fully-implemented_60142650-932c-4494-add8-9dbc3184060c/req/uml-choice-components/choice-item-name-unique_5b87431f-e587-43e2-bf19-7ba1ff71d7d1/req/uml-block-components_a7009d09-dd93-46c9-a65f-25a307c3dce4/req/uml-block-components/package-fully-implemented_fc63c921-694b-4080-9d89-d2c59b98691e/req/uml-block-components/array-component-no-value_8299a5db-fa0b-4328-8f69-6346e76b65a4/req/uml-block-components/array-values-properly-encoded_54a0e65c-4347-4ebc-b7cc-04055b2b1928/req/uml-block-components/matrix-element-type-valid_24a3ba69-97e1-42de-a54f-d30718c8520c/req/uml-block-components/datastream-array-valid_485d508b-cb4b-4ab0-a41b-ff6d87bf8569/req/uml-geom-components_b8f8c1e9-094f-4cff-85fb-9c9ff34f1f05/req/uml-geom-components/package-fully-implemented_0e74b495-88e9-49b4-a024-6a4a88627fd7/req/uml-geom-components/srs-valid_47d85457-1e3e-4cb5-9871-18032d49b970/req/uml-geom-components/geom-value-valid_b137f877-f72d-4c70-9c12-a60fec7a5ed7/req/uml-simple-encodings_e8e82cf0-0045-43ac-8876-db1bdd684b88/req/uml-simple-encodings/package-fully-implemented_bc0a786e-33c7-4d6b-9b3f-04dd03442129/req/uml-advanced-encodings_fffd554b-1cda-4108-b38e-82fc48979360/req/uml-advanced-encodings/package-fully-implemented_a8bc3622-f2c8-488f-9612-dce609a8e930/req/json-simple-components_1ffa4ccc-b6a6-4a86-b2e7-4ca6cca9468b/req/json-simple-components/schema-valid_7a79fa83-2ffe-4df9-8569-2fa2642a13f0/req/json-simple-components/special-numerical-values_7d299258-3353-427f-8e07-d632371689b8/req/json-simple-components/definition-resolvable_1e58f94d-af1e-44aa-89f2-d7bf17924ba0/req/json-simple-components/inline-value-constraint-valid_44472ff4-cc49-4025-b374-f4700a518476/req/json-simple-components/ucum-code-used_dc742332-e6f6-43be-aa50-99e0062aae09/req/json-simple-components/iso8601-uom-used_c7aa1491-b30d-49de-9c25-0a725374ab4f/req/json-record-components_39e495de-1a08-4d91-9cb6-3c5f500cb2dd/req/json-choice-components_b3aba94f-0f74-4685-8471-bb7c515b58e9/req/json-block-components_8fc2ad9d-ce4c-40d8-b5ab-297b22bcce8c/req/json-geom-components_689f3fd1-2048-4f2b-8f7f-d111aa19d2a6/req/json-simple-encodings_61ecb26d-a1cb-487a-bf61-a317e09d59ea/req/json-advanced-encodings_0315ad14-c240-4c89-9928-4ec581b16fb8/req/xsd-advanced-encodings/ref-syntax-valid_4b65d294-16d9-4c4e-9f76-b5510b62f162/req/xsd-advanced-encodings/scalar-ref-component-valid_6a5ebfb9-2ec1-4ab2-9791-7e01eb73ae49/req/xsd-advanced-encodings/datatype-valid_b2ad778c-c633-41ee-869b-64a6e44f973c/req/xsd-advanced-encodings/datatype-compatible_7655ef6a-f6d5-4d43-baa3-7a12ad0ea707/req/xsd-advanced-encodings/no-datatype-length_355d1fef-8a6b-4878-9b5e-54dfae36f499/req/general-encoding-rules_89fc3a84-6279-4132-9630-fb59f3a1ff2e/req/general-encoding-rules/record-encoding-rule_e60d1a52-437b-4f4b-b48d-ce5fb5400a24/req/general-encoding-rules/choice-encoding-rule_cc90cb43-b123-4376-9386-ab59b2f34d4b/req/general-encoding-rules/array-encoding-rule_867a66a0-1550-4e6d-baaa-232197bd9ac7/req/general-encoding-rules/array-size-encoding-rule_9d547d80-5023-4749-b546-48c2be01e830/req/json-encoding-rules_f7931ef7-61f3-4f8e-86c3-b3e37b36a35d/req/json-encodings-rules/json-valid_b791f15f-e2d8-419e-abcc-c40d03ad999f/req/json-encoding-rules/scalar-value-valid_01fae0ae-fb26-4424-8d57-0695599de979/req/json-encoding-rules/range-value-valid_0ea0a97a-06dc-4d61-8f41-455473681b75/req/json-encoding-rules/record-object-valid_cb1420b9-20ac-42f8-b02b-933064665c0e/req/json-encoding-rules/vector-object-valid_45d3463d-3906-4eac-8925-8c895a3f457b/req/json-encoding-rules/choice-object-valid_e22e35dd-587d-433d-8c30-bf9238a07c86/req/json-encoding-rules/array-values-valid_9504cc66-103d-44ce-bd91-7094bc649dad/req/json-encodings-rules/geometry-valid_642738e4-c199-4b13-b412-ce2c6179a4f2/req/text-encoding-rules_1d3ef339-3c2b-48af-b362-04e79a37c63b/req/text-encodings-rules/abnf-syntax-valid_7ba0fee3-3cd9-4fc4-9cf7-8076ba9850ae/req/text-encodings-rules/separators-valid_3621ff12-3408-4556-975f-2fd6bd59862e/req/text-encodings-rules/optional-field-marker-present_f90d70e7-166e-4876-81ad-1fb269ec79e6/req/text-encodings-rules/choice-selection-marker-valid_d1932a67-cdd1-40e4-a4d2-7fe4aa54341b/req/text-encodings-rules/geometry-valid_3a14423c-bd56-4664-bcd3-d9a197f8f644/req/binary-encoding-rules_bef43c29-cb7d-4a45-861b-fcc28897581d/req/binary-encoding-rules/abnf-syntax-valid_df6eaa05-0f3e-4ff2-96bc-e9a01c48449c/req/binary-encoding-rules/type-encoding-valid_d0a6761e-e35a-442c-95e8-48239a2d28f7/req/binary-encoding-rules/base64-translation-applied_38c66334-c281-47b2-8eaf-99df349d5fd7/req/binary-encoding-rules/optional-field-marker-present_0a436829-ca39-468e-b6bd-ddf5175fa59d/req/binary-encoding-rules/choice-selection-marker-valid_daf6760b-767e-43de-8970-a811cd101bc3/req/binary-encodings-rules/geometry-valid_e293b62e-2f96-41a8-bb7c-649f8996d416/conf/core_eb4c4842-54aa-4a11-a560-4f524abc11cb/conf/core/core-concepts-used_e2ff1447-eaac-4132-ab90-0f5e3294828b/conf/core/boolean-rep-valid_6cd04c8c-0ace-4275-b5b1-635dd81ae9cd/conf/core/categorical-rep-valid_88e8af44-fadb-4820-a6f5-68494e86ef2a/conf/core/numerical-rep-valid_1eef2b04-fb13-4bf2-a34d-ace361f6409c/conf/core/countable-rep-valid_b294a13b-fc57-4c8d-8a21-eee14e10f9b0/conf/core/textual-rep-valid_ad75403e-dc41-488e-ab57-17eba9b2718d/conf/core/semantics-defined_b42d0d27-71a7-40af-a5b1-c53450d15462/conf/core/semantics-resolvable_be7488de-d4ef-4671-a905-a7dd439105d5/conf/core/temporal-frame-defined_4db3dc0b-3fc3-4425-9a9b-91175bd90635/conf/core/spatial-frame-defined_9fcdfedb-3af2-4883-9d1f-649e14fd1bc0/conf/core/nil-reasons-defined_5cb4b894-d405-4881-905a-322cb5b69315/conf/core/aggregates-model-valid_c6fb05a1-a9de-4dc6-a2f6-138f4a17bece/conf/core/encoding-method-valid_c8bdfb37-b249-40f1-96ca-62396b0a28da/conf/uml-simple-components_9f99c3b0-4926-44fe-9b3d-2d9f0ead6855/conf/uml-simple-components/package-fully-implemented_76d2eb8e-f7fa-42c0-b9c9-5b1ff0ed1077/conf/uml-simple-components/iso19103-implemented_4c850ad4-c9f2-412f-a097-4551cd1696dd/conf/uml-simple-components/iso19108-implemented_2ed4af97-68bd-458a-8e11-5e44a329a44b/conf/uml-simple-components/definition-present_e80fc58b-da84-4ea0-9f7e-95cab0cf293c/conf/uml-simple-components/axis-valid_f1a7ede2-8107-4253-884c-7c48fc01d169/conf/uml-simple-components/axis-defined_5a5f66e8-aa69-4e04-bdaa-166110ba9316/conf/uml-simple-components/ref-frame-defined_d633efe9-d718-4df7-93c6-897d54b644b7/conf/uml-simple-components/value-constraint-valid_fb3af4c8-81d5-4897-8e88-bd2a2456714c/conf/uml-simple-components/value-attribute-present_82f39c2c-b858-4e7e-ad40-d77333aa28b0/conf/uml-simple-components/category-constraint-valid_a6119fb5-be85-4604-a22e-18f09a36001e/conf/uml-simple-components/category-enum-defined_58d2dd0d-bb77-4e90-941f-4d5e7dc9c519/conf/uml-simple-components/category-value-valid_aff2c624-40f5-4c26-8987-f272d16febd8/conf/uml-simple-components/time-ref-frame-defined_f0a50b34-acb0-46fd-aa7d-bc75314ff29d/conf/uml-simple-components/time-ref-time-valid_3474e1a9-fd5d-4263-a896-ed28f2d02f26/conf/uml-simple-components/time-local-frame-valid_30017d56-699a-4218-a95e-fe7efa9bd9ca/conf/uml-simple-components/range-value-valid_8cd09a4f-5a87-4d6d-82ff-e7fa827ac0d5/conf/uml-simple-components/category-range-valid_da68f495-2de4-4ca2-bb15-cd215f8db9f7/conf/uml-simple-components/category-range-codespace-order_7b8c8ad0-2c99-44d9-9001-6b33437e3ac4/conf/uml-simple-components/time-range-valid_189ea1fe-cbf0-4430-9636-046fe0c5ee9e/conf/uml-simple-components/nil-reason-resolvable_d87ed7ab-689d-448b-ae3c-cd71f0f69ef5/conf/uml-simple-components/nil-value-type-coherent_1f657bd1-2e2f-4c13-8120-cc421b8b859c/conf/uml-simple-components/allowed-values-unit-coherent_0a98c237-f17f-4409-8eed-1057b8fd1ffd/conf/uml-record-components_390a8a16-c216-4ec5-9ea6-85536d52b939/conf/uml-record-components/package-fully-implemented_94380548-04b7-40ff-9e21-251abbb7927c/conf/uml-record-components/record-field-name-unique_a823b131-da50-45f5-a899-863aa67e571d/conf/uml-record-components/vector-coord-name-unique_1f77657f-ff17-42b6-bd7c-1ccfc8c66eea/conf/uml-record-components/vector-component-no-ref-frame_9219bee8-129c-42e3-a2c6-4f980e80e993/conf/uml-record-components/vector-component-axis-defined_d39028da-521c-4ae2-942c-4d4b68f6e108/conf/uml-record-components/vector-local-frame-valid_8596ac1f-e4f7-4783-a50f-978ce812741c/conf/uml-choice-components_c1644a67-536d-4443-938c-6bc770d6e7ea/conf/uml-choice-components/package-fully-implemented_bdb0dc0d-08e5-49b1-abb2-e2ec31d7db04/conf/uml-choice-components/choice-item-name-unique_3b772f72-e7f4-4729-872f-0099b4d42cfe/conf/uml-block-components_48c143b6-00b3-474c-bf39-da34dcfdddf9/conf/uml-block-components/package-fully-implemented_df3e2226-ba68-47cc-8657-4ed58c088061/conf/uml-block-components/array-component-no-value_b8eaa866-e1d4-45c8-a358-9b3f20fccf21/conf/uml-block-components/array-values-properly-encoded_47c41a1d-0343-4b6a-8f5f-557fd3bd3abc/conf/uml-block-components/matrix-element-type-valid_7e6ec960-6b4b-4f28-8d11-7c3ab0097a18/conf/uml-simple-encodings_9ca1e6b1-3968-4a9b-aaae-0a06c7bed739/conf/uml-simple-encodings/package-fully-implemented_cd4f0a4a-1a3b-4189-8ec0-366e54c88d75/conf/uml-advanced-encodings_1b1770cf-24eb-4266-bb6d-07791893ca64/conf/uml-advanced-encodings/package-fully-implemented_cb106cc9-f555-4be3-a529-afec7a0974f0/conf/general-encoding-rules_c076053c-228e-40c0-8b15-f3f4827af898/conf/general-encoding-rules/record-encoding-rule_a412618e-3411-4b17-a5a7-0ff999c71d55/conf/general-encoding-rules/choice-encoding-rule_e2d85f61-db1a-43d7-be63-cb468c3b2e64/conf/general-encoding-rules/array-encoding-rule_4f35f829-cd68-4f8b-b40d-62715ccb831a/conf/general-encoding-rules/array-size-encoding-rule_18767d78-4f8a-474e-80f5-8ee1f9b6d768/conf/text-encoding-rules_f07e06af-668c-4e14-a3b6-d7545b81d3ca/conf/text-encoding-rules/abnf-syntax-valid_aa68d1a7-f5ef-41bb-a66d-198786798afe/conf/text-encoding-rules/separators-valid_3bc64378-83f2-4d9c-a738-e9bd52cc37cc/conf/text-encoding-rules/optional-field-marker-present_3ecaf503-5dc7-49ac-8c4a-9c4b3bab2aa1/conf/text-encoding-rules/choice-selection-marker-valid_e83a02ca-9b14-4552-a6ac-9b74127c1d02/conf/binary-encoding-rules_fdaa758c-ed4b-4453-9c56-fda1b10b45e4/conf/binary-encoding-rules/abnf-syntax-valid_563b222b-2d5c-4050-a1cb-15d7fd36c689/conf/binary-encoding-rules/type-encoding-valid_c3ca1b98-9e1f-49bb-bf58-1afd7a7a9afa/conf/binary-encoding-rules/base64-translation-applied_4bf64024-f7f6-4aa3-80a7-9b8128f0b2ac/conf/binary-encoding-rules/optional-field-marker-present_dc03e74b-3d73-43dd-a43a-0f1b0f5f7c7c/conf/binary-encoding-rules/choice-selection-marker-validTOC Heading Levels2HTML TOC Heading Levels2DOC TOC Heading Levels2 - - - -Copyright notice -Copyright © 2024 Open Geospatial Consortium -To obtain additional rights of use, visit - - - - -Note -Attention is drawn to the possibility that some of the elements of this document may be the subject of patent rights. The Open Geospatial Consortium shall not be held responsible for identifying any or all such patent rights. - -Recipients of this document are requested to submit, with their comments, notification of any relevant patent claims or other intellectual property rights of which they may be aware that might be infringed by any implementation of the standard set forth in this document, and to provide supporting documentation. - - - - - - -License Agreement -Use of this document is subject to the license agreement at - - - - - - -Notice for Drafts -This document is not an OGC Standard. This document is distributed for review and comment. This document is subject to change without notice and may not be referred to as an OGC Standard. - -Recipients of this document are invited to submit, with their comments, notification of any relevant patent rights of which they are aware and to provide supporting documentation. - - - - - - -Suggested additions, changes and comments on this document are welcome and encouraged. Such suggestions may be submitted using the online change request form on OGC web site: - - -AbstractThe primary focus of the SWE Common Data Model is to define and package data in a self-describing and semantically enabled way. The main objective is to achieve interoperability, first at the syntactic level, and later at the semantic level (by using ontologies and probably semantic mediation) so that (sensor) data can be better understood by machines, processed automatically in complex workflows and easily shared between intelligent nodes. - -This standard is one of several implementation standards produced under OGC’s Connected Systems activity, and is a revision of content that was previously developed in the context of the Sensor Web Enablement initiative. These common data models are intended to be used in various OGC standards, and in particular, SensorML and OGC API — Connected Systems. - -Preface -The OGC SWE Common Data Model Encoding Standard is the result of worked done by the Connected Systems Working Group of the OGC, with the aim of modernizing the Sensor Wen Enablement (SWE) suite of Standards. - -To increase the brevity and readability of this Standard, many OGC document titles are shortened and/or abbreviated. Therefore, in the context of this document, the following phrases are defined: - -“this Standard” shall be interpreted as equivalent to “OGC SWE Common Data Model Encoding Standard”. -“SensorML” or “SensorML Standard” shall be interpreted as equivalent to “OGC Sensor Modeling Language Encoding Standard” - -Foreword -This document deprecates version 2.0 of the OGC® SWE Common Data Model Encoding Standard (OGC 08-094r2). - -The following changes have been made: - -Addition of the JSON encodings and schemas - -Addition of the Geometry data component (modeled on OGC simple feature geometries) - -Deprecation of the XML encodings - -Technical revision and improved explanations in various clauses - - - -This release is not fully backward compatible with version 2.0 even though changes were kept to a minimum. - -Security considerations -No security considerations have been made for this Standard. - -Submitters -All questions regarding this submission should be directed to the editor or the submitters: - -Name -Affiliation - -Alex Robin (Editor) -GeoRobotix, Inc. -Christian Autermann -52° North Initiative -Chuck Heazel -Heazeltech -Mike Botts -Botts Innovative Research, Inc. - - - -Additional contributors to this Standard include the following: - -Name -Affiliation -Arne Broering -52° North Initiative -Barry Reff -US DHS -Ingo Simonis -iGSI -Johannes Echterhoff -iGSI -John Herring -Oracle USA -Luis Bermudez -SURA -Nick Garay -Botts Innovative Research, Inc. -Peter Taylor -CSIRO - - - - - - - - - - -Scope -This standard defines low level data models for exchanging sensor related data between nodes of the OGC® Connected Systems framework (previously Sensor Web Enablement (SWE) framework). These models allow applications and/or servers to structure, encode and transmit sensor datasets in a self describing and semantically enabled way. - -More precisely, the SWE Common Data Model is used to define the representation, nature, structure and encoding of sensor related data. These four pieces of information, essential for fully describing a data stream, are further defined in section 6. - -The SWE Common Data Model is intended to be used for describing static data (files) as well as dynamically generated datasets (on the fly processing), data subsets, process and web service inputs and outputs, and real time streaming data and commands. All categories of sensor observations are in scope ranging from simple in-situ temperature data to satellite imagery and full motion video. - -This standard defines JSON encodings for the dataset/datastream description, while the data itself can be encoded in JSON, text or binary form. This standard is used by other existing OGC standards such as the Sensor Model Language (SensorML) and OGC API — Connected Systems. One goal of the SWE Common Data Model is to maintain the functionality and consistency between these related standards. - - - -Conformance -This standard has been written to be compliant with the OGC Specification Model – A Standard for Modular Specification (OGC 08-131r3). Extensions of this standard shall themselves be conformant to the OGC Specification Model. - -Conformance with this specification shall be checked using all the relevant tests specified in Annex A. The framework, concepts, and methodology for testing, and the criteria to be achieved to claim conformance are specified in ISO 19105: Geographic information — Conformance and Testing. In order to conform to this OGC™ encoding standard, a standardization target shall implement the core conformance class, and choose to implement any one of the other conformance classes. - -Additionally, it is highly recommended that JSON based implementations of the conceptual models do implement requirement classes from clause 8 and clause 9 of this standard, respectively, and pass the corresponding conformance classes instead of defining new encodings. - -TODO - -This standard defines XXXX. - -Requirements for N standardization target types are considered: - -AAAA - -BBBB - - - -Conformance with this standard shall be checked using all the relevant tests specified in Annex A (normative) of this document. The framework, concepts, and methodology for testing, and the criteria to be achieved to claim conformance are specified in the OGC Compliance Testing Policies and Procedures and the OGC Compliance Testing web site. - -In order to conform to this OGC® interface standard, a software implementation shall choose to implement: - -Any one of the conformance levels specified in Annex A (normative). - -Any one of the Distributed Computing Platform profiles specified in Annexes TBD through TBD (normative). - - - -All requirements-classes and conformance-classes described in this document are owned by the standard(s) identified. - - - - - -Terms and definitionsThis document uses the terms defined in OGC Policy Directive 49, which is based on the ISO/IEC Directives, Part 2, Rules for the structure and drafting of International Standards. In particular, the word “shall” (not “must”) is the verb form used to indicate a requirement to be strictly followed to conform to this document and OGC documents do not use the equivalent phrases in the ISO/IEC Directives, Part 2. -This document also uses terms defined in the OGC Standard for Modular specifications (OGC 08-131r3), also known as the ‘ModSpec’. The definitions of terms such as standard, specification, requirement, and conformance test are provided in the ModSpec. -For the purposes of this document, the following additional terms and definitions apply. - -This document uses the terms defined in Sub-clause 5.3 of , which is based on the ISO/IEC Directives, Part 2, Rules for the structure and drafting of International Standards. In particular, the word “shall” (not “must”) is the verb form used to indicate a requirement to be strictly followed to conform to this standard. - -For the purposes of this document, the following additional terms and definitions apply. - -TODO - - -Feature - - -Abstraction of real-world phenomena - - - ISO-19101, definition 4.11 - - - -Observation - - -Act of observing a property - - - ISO-19156, definition 4.10 - - - -Observation Procedure - - -Method, algorithm or instrument, or system of these which may be used in making an observationNote: In the context of the sensor web, an observation procedure is often composed of one or more sensors that transform a real world phenomenon into digital information, plus additional processing steps. - - - - - ISO-19156, definition 4.11 - - - -Property - - -Facet or attribute of an object referenced by a name -Example : Abby’s car has the colour red, where “colour red” is a property of the car instance - - - ISO-19143 - - - -Sensor - - -Type of observation procedure that provides the estimated value of an observed property at its output -Note: A sensor uses a combination of physical, chemical or biological means in order to estimate the underlying observed property. At the end of the measuring chain electronic devices often produce signals to be processed - - - -Sensor Network - - -A collection of sensors and processing nodes, in which information on properties observed by the sensors may be transferred and processed -Note: A particular type of a sensor network is an ad hoc sensor network. - - - -Sensor Data - - -List of digital values produced by a sensor that represents estimated values of one or more observed properties of one or more features -Note: Sensor data is usually available in the form of data streams or computer files. - - - -Sensor Related Data - - -List of digital values produced by a sensor that contains auxiliary information that is not directly related to the value of observed properties -Example: sensor status, quality of measure, quality of service, etc… When such data is measured, it is sometimes considered sensor data as well. - - - -Data Component - - -Element of sensor data definition corresponding to an atomic or aggregate data type -Note: A data component is a part of the overall dataset definition. The dataset structure can then be seen as a hierarchical tree of data components. - - - - -Conventions - -Identifiers -The normative provisions in this standard are denoted by the URI - - - -All requirements and conformance tests that appear in this document are denoted by partial URIs which are relative to this base. - - - -Abbreviated terms -In this document the following abbreviations and acronyms are used or introduced: - -CRS: Coordinate Reference System - -CSML: Climate Science Modeling Language - -GPS: Global Positioning System - -ISO International Organization for Standardization - -MISB Motion Imagery Standards Board - -OGC Open Geospatial Consortium - -SAS Sensor Alert Service - -SensorML Sensor Model Language - -SI Système International (International System of Units) - -SOS Sensor Observation Service - -SPS Sensor Planning Service - -SWE Sensor Web Enablement - -TAI Temps Atomique International (International Atomic Time) - -UML Unified Modeling Language - -UTC Coordinated Universal Time - -XML eXtended Markup Language - -1D One Dimensional - -2D Two Dimensional - -3D Three Dimensional - - - - -UML Notation -The diagrams that appear in this standard are presented using the Unified Modeling Language (UML) static structure diagram. The UML notations used in this standard are described in the diagram below. - - - - - - -Requirements Class: Core Concepts (normative core) - -Core Concepts /req/coreDerived Models and Software Implementations - - - - -Introduction -The generic SWE Common data model defined by this standard aims at providing verbose information to robustly describe sensor related datasets. We define Sensor Data as data resulting from the observation of properties of virtual or real world objects (or features) by any type of Observation Procedure (See the Observation and Measurements specification OGC 07-022r1 for a more complete description of the observation model used in SWE). - -Sensor related datasets however are not limited to sensor observation values, but can also include auxiliary information such as status or ancillary data. In the following sections, we will use the term ‘property’ in a broader sense, which does not necessarily imply “property measured by a sensor”. - -A dataset is composed of Data Components whose values need to be put into context in order to be fully understood and interpreted, by either humans or machines. The SWE Common Data Model provides several pieces of information that are necessary to achieve this goal. More precisely, the SWE Common Data Model covers the following aspects of datasets description: - -Representation - -Nature of data and semantics (by using identifiers pointing to external semantics) - -Quality - -Structure - -Encoding - - - -This requirement class constitutes the core of this standard. The standardization target types of this core are all models or software implementations seeking compliance with this standard. - - /req/core/core-concepts-used - -A derived model or software implementation shall correctly implement the concepts defined in the core of this standard. - - - - -Data Representation -Data representation deals with how property values are represented and stored digitally. Each component (or field) in a dataset carries a value that represents the state of a property. This representation will vary depending on the nature of the method used to capture the data and/or the target usage. For instance, a fluid temperature can be represented as a decimal number expressed in degrees Celsius (i.e. 25.4 °C), or as a categorical value taken from a list of possible choices (such as “freezing, cold, normal, warm, hot”). - -The following types of representations have been identified: Boolean, Categorical, Continuous Numerical, Discrete Countable and Textual. The paragraphs below explain basic features of each of these representation types. - - -Boolean -A Boolean representation of a property can take only two values that should be “true/false” or “yes/no”. In a sense, this type of representation is a particular case of the categorical representation with only two predefined options. - -Examples - -Motion detectors output can be represented by a boolean value -– TRUE if there is motion in the room, FALSE otherwise. - -On/Off status of a measurement system can be represented by a boolean value -– TRUE if the system in on, FALSE if the system is off. - - - /req/core/boolean-rep-valid - -A boolean representation shall at least consist of a boolean value. - - -The “Boolean” class described in is used to define a data component with a Boolean representation. - - - -Categorical -A categorical representation is a type of discrete representation of a property that only allows picking a value from a well defined list of possibilities (i.e. categories). This list is called a code space in this standard, following ISO 19103 terminology. - -The different possible values constituting a code space are usually listed explicitly in an out-of-band dictionary or ontology. This is necessary because each value should be defined formally and unambiguously, so that it can be interpreted correctly. - -Examples - -Biological or chemical species data is usually represented by a categorical data component that can leverage on existing controlled vocabulary. - -A camera mode can be represented by a categorical value: AUTO_FOCUS, MANUAL_FOCUS, etc…​ - - - /req/core/categorical-rep-valid - -A categorical representation shall at least consist of a category identifier and information describing the value space of this identifier. - - -The “Category” class described in is used to define a data component with a categorical representation. - - - -Numerical (continuous) -Perhaps the most used representation of a property value, especially in the science and technical communities, is the numerical one, as the majority of properties measured by sensors can be represented by numbers. - -Numerical representation is often used for continuous values and, in this case, the representation consists of a decimal (often floating point) number associated to a scale or unit of measure. The unit specification is mandatory even for quantities such as ratios that have no physical unit (in this case a scale factor is provided such as 1, 1/100 for percents, 1/1000 for per thousands, etc.). - -Examples - -Temperature measurements can be represented by a number associated to a unit such as degrees Celsius or Fahrenheit: 23.51°C, 94°F - -A velocity vector is composed of several values (usually 2 or 3) associated to a unit of speed: [1.0 2.0 3.0] m/s. - - - /req/core/numerical-rep-valid - -A continuous numerical representation shall at least consist of a decimal number and the scale (or unit) used to express this number. - - -The “Quantity” class described in is used to define a data component with a decimal representation and a unit of measure. - - - -Countable (discrete) -Discrete countable properties are also of interest and are most accurately captured with a numerical integer representation. They do not require a unit since the unit is always the unit of count (i.e. the person if we are counting persons, the pixel if we are counting pixels, etc). Note that continuous properties can also be represented as integers with certain combinations of scale and precision. This case should not be confused with the countable properties described here. - -Examples - -Array indices and sizes are countable properties with no unit. - -There are numerous other countable properties such as number of persons, number of bytes, number of frames, etc. for which the unit is obvious from the definition of the property itself. - - -A discrete countable representation should not be confused with a continuous numerical representation whose scale and precision allow encoding the property value as an integer. - - /req/core/countable-rep-valid - -A countable representation shall at least consist of an integer number. - - -The “Count” class described in is used to define a data component with an integer representation and no unit of measure. - - - -Textual -A textual representation is useful for providing human readable data, expressed in natural language, as well as various alpha numeric tokens that cannot be assigned to well-defined categories. - -Examples - -Comments or notes written by humans (ex: data annotations, quality assessments). - -Machine generated messages for which there is no taxonomy (ex: automatic alert messages). - -Alphanumeric identifier schemes leading to a large number of possibilities that cannot be explicitly enumerated (ex: UUID, ISBN code, URN). - - - /req/core/textual-rep-valid - -A textual representation shall at least consist of a character string. - - -The “Text” class described in is used to define a data component with a textual representation. - - - -Constraints -Constraints can be added to some representation types to further restrict the set of possible values allowed for a given property: - -A boolean representation cannot be restricted further since it is already limited to only two possibilities. - -A numerical representation can be constrained by a list of allowed values and/or bounded or unbounded intervals. A decimal representation can also be constrained by the number of significant digits after the decimal point. - -A categorical representation can be constrained by a list of possible choices, which should be a subset of the list of possibilities defined by the code space. - -A textual representation can be constrained by a pattern expressed in a well known language such as regular expression syntax. - - - -These constraints apply only to the value of the data component to which they are associated. They shall not be used to express constraints on other data components or on any other information than the value. - -Examples - -A decimal representation of an angular property such as latitude can be constrained to the [-90° 90°] interval. - -A temperature reading produced by a sensor can be constrained to the [-50°C +250°C] range. - - - - - -Nature of Data -We define “Nature of data” as the information needed to understand what property the value represents. It is thus connected to semantics and the semantic details are often provided by external sources such as dictionaries, taxonomies or ontologies. Note that it is independent of the type of representation used and it does not include information about how the data was actually measured or acquired. This lineage information should be described by other means as explained in . - - -Human readable information -The first means by which nature of data can be communicated is through human readable text. The data component’s description, which is present in all data types defined in this specification, can hold any length of text for this purpose. The data component’s label is used to carry short human readable information (i.e. a short name); this is useful to allow data consumers to quickly identify the represented property. - -It is not recommended to use the concepts of “description” and “label” in a way that they contain robust semantic information (i.e. that machines can rely upon). The content of such fields is intended to be interpretable solely by humans. - - - -Robust semantics -All SWE Common data types allow for associating each data component in a dataset with the definition of the Property that it represents. - - /req/core/semantics-defined - -All data values shall be associated with a clear definition of the property that the value represents. - - -It is recommended that a model uses references to out-of-band dictionaries rather than inline information because semantics are supposed to be shared by multiple datasets. Using references also helps by providing a framework that is independent from the actual semantic technology used. - -The SWE Common UML models and XML schemas desribed in this standard can be used in combination with any semantic web technology. It is thus possible to connect a SWE dataset description to an existing taxonomy provided the external register exposes a unique identifier for each entry. - -These semantic references point to out-of-band semantic information that can be encoded in various languages, such as the Ontology Web Language (OWL) or GML dictionary. - - /req/core/semantics-resolvable - -If semantic information is provided by referencing out-of-band data, the locators or identifiers used to point to this information shall be resolvable by some well-defined method. - - - - -Time, space and projected quantities -Temporal, spatial and other projected quantities need to be further defined by specifying the reference frame and axis with respect to which the quantity is expressed. In SWE Common, any simple component type can be associated to a particular axis of a given reference frame. - -Examples - -Satellite position data can be defined as a vector of 3 components, expressed in the J2000 ECI Cartesian frame, the 1st component being associated to the X axis, the 2nd to the Y axis and the 3rd to the Z axis. - -Angular velocity data from an Inertial Measurement Unit can be defined as a vector of 3 components, expressed in the plane reference frame (for instance ENU defined by local East, North, Up directions), the Euler components being mapped to X, Y, Z respectively. - -Relative time data can be given with respect to an arbitrary epoch itself positioned in a well defined reference frame such as TAI (from the French “Temps Atomique International” = International Atomic Time). - - - /req/core/temporal-frame-defined - -A temporal quantity shall be expressed with respect to a well defined temporal reference frame and this frame shall be specified. - - - /req/core/spatial-frame-defined - -A spatial quantity shall be expressed with respect to the axes of a well defined spatial reference frame and this frame shall be specified. - - -The “Time” class described in is designed for carrying a temporal reference frame or a time of reference in the case of relative time data. - -The “Vector” class detailed in is a special type of record used to assign a reference frame to all its child-components. - -The “Matrix” class defined in allows the definition of higher order tensor quantities. - -This standard does not impose requirements on the type of reference frames that a standardization target shall support. Standards that are dependent on this specification can (and often should) however define a minimum set of reference frames that shall be supported by all implementations. - - - - -Data Quality -Quality information can be essential to the data consumer and the SWE Common Data Model provides simple and flexible ways to associate qualitative information with each component of a dataset. - - -Simple quality information -Simple quality information can be associated with any scalar data component, in the form of another scalar or range value. The quality information defined here applies solely to the value of the associated data component (i.e. the measurement value) and, depending on its data type, quality can be represented by a numerical, categorical or textual value, or by a range of values. - -This quality information can be static, i.e. constant over the whole dataset, or dynamic and provided with the data itself. In this case, the quality value is in fact carried by another component of the dataset (and described in SWE Common as such). - -The exact type of quality information provided should be specified via semantic tagging just like with any other property in SWE Common. - -Examples - -Examples of quality measures are “absolute accuracy”, “relative accuracy”, “absolute precision”, “tolerance”, and “confidence level”. - -Quality related comments can also describe operating conditions, such as “sensor contained blockage and was removed” or “engineer on site, values may be affected”. This information can inform the user of potential inaccuracy in the data across certain periods. - - - - -Nil Values -The concept of NIL value is used to indicate that the actual value of a property cannot be given in the data stream, and that a special code (i.e. reserved value) is used instead. It is thus a kind of quality information. The reason for which the value is not included is essential for a good interpretation of the data, so each reserved value is associated to a well-defined reason. In that sense, a NIL value definition is essentially a mapping between a reserved value and a reason. - -Each component of a dataset can define one or several NIL values corresponding to one or more reasons. - -Example - -In low level satellite imagery with, for instance, 8-bits per channel, the imagery metadata often defines: -- A reserved value to indicate that a pixel value was “Below Detection Limit” usually set to ‘0’ -- A reserved value to indicate that a pixel value was “Above Detection Limit” usually set to ‘255’ - - - /req/core/nil-reasons-defined - -A model of a NIL value shall always include a mapping between the selected reserved value and a well-defined reason. - - - - -Full lineage and traceability -Full lineage and traceability is not in the scope of this specification. It is fully addressed by the OGC® Sensor Model Language Standard, which allows robust definition of measurement chains, with detailed information about the processing that takes place at each stage of the chain. This means that complex lineage guarantying full traceability can be recorded in a SensorML process chain, separately from the data itself. - -Datasets can be associated to lineage information described using the Sensor Model Language by using a metadata wrapper such as the “Observation” object defined in the OGC® Observations and Measurements Standard (O&M). In this standard, the “procedure” property of the “Observation” class allows attaching detailed information about the measurement procedure, that is to say a description of how the data was obtained (i.e. lineage), to the data itself. - - - - -Data Structure -Data structure defines how individual pieces of data are grouped, ordered, repeated and interleaved to form a complete data stream. The SWE Common models are based on data structures commonly accepted in computer science and formalized in ISO 11404. -Classical aggregate datatypes are defined below: - -Record: consists of a list of fields, each of them being keyed by a field identifier and defining its own type that can be any scalar or aggregate structure. - -Array: consists of many elements of the same type, usually indexed by an integer. The element type can be any data structure including scalars and aggregates. The array size constitutes the upper bound of the index. - -Choice: consists of a list of alternatives, each of them being keyed by a tag value and having its own type. Only values for one alternative at a time are actually present in the data stream described by such a structure. - - - - /req/core/aggregates-model-valid - -Aggregate data structures shall be implemented in a way that is consistent with definitions of ISO 11404. - - -This standard also defines the concept of “data component” as any part of the structure of a dataset, aggregate or not. It is thus the superset of all the aggregate structures described above and of all scalar elements implementing the representations described in . - -Example - -A dataset representing a time series of observations acquired by a mobile sensor can be encoded with various methods depending on the requirements: - -XML encoding can be used when data needs to be easily styled to other markup formats (such as HTML) or when precise error localization (in the case of an error in the stream) is needed. - -ASCII encoding can be used to achieve a good compromise between readability and size efficiency. - -Binary encoding can be used (eventually with embedded compression) when pure performance (i.e. size but also reading and writing throughput) is the main concern. - - - - -A data component can be both a data descriptor and a data container: - -A data component used as a data descriptor defines the structure, representation, semantics, quality, and other metadata of a data set but does not include the actual data values. - -A data component used as a data container equally defines the dataset but also includes the actual property values. - - - - - -Data Encoding -A key concept of the SWE Common Data Model is the ability to separate data values themselves from the description of the data structure, semantics and representation. This allows verbose metadata to be used in order to robustly define the content and meaning of a dataset while still being able to package the data values in very efficient manners. - -Data encoding methods define how the data is packed as blocks that can efficiently be transferred or stored using various protocols and formats. Different methods allow encoding the data as JSON, text (CSV like), binary and even compressed or encrypted formats in a way that is agnostic to a particular structure. This allows any of the encodings methods to be selected and used based on a particular requirement, such as performance, re-use of tools, alignment with existing standards and so on. - - /req/core/encoding-method-valid - -All encoding methods shall be applicable to any arbitrarily complex data structures as long as they are made of the data components described in . - - - - - -UML Conceptual Models (normative) -This standard defines normative UML models with which derived encoding models as well as all future separate extensions should be compliant. The standardization target type for the UML requirements classes defined in this clause is thus a software implementation or an encoding model that directly implements the conceptual models defined in this standard. - - -Package Dependencies -The following packages are defined by the SWE Common Data Model: - - -Internal Package Dependencies - - -This standard also has dependencies on external packages defined by other standards, namely ISO 19103, ISO 19108 and ISO 19111, as show below: - - -External Package Dependencies - - - - -Requirements Class: Basic Types and Simple Components Packages - -Simple Components UML Package /req/uml-simple-componentsSoftware Implementation or Encoding of the Conceptual Models/req/core - - - -Data components are the most essential part of the SWE Common Data Model. They are used to describe all types of data structures, whether they represent data stream contents, tasking messages, alert messages or process inputs/outputs. - -The “Simple Components” UML package contains classes modeling simple data components, that is to say scalar components and range components (i.e. value extents). These classes implement concepts defined in the core section of this standard, and are designed to collect information about nature, representation and quality of data. These include six scalar types – Boolean, Text, Category, Count, Quantity, and Time – as well as four range types – CategoryRange, CountRange, QuantityRange and TimeRange. - -The “Basic Types” UML package from which the “Simple Components” package is dependent is also included in this requirements class. - -As an overview, conceptual models of the six scalar component types are shown on the following UML class diagram: - - -Scalar Data Components - - -Classes representing the four range data components are shown on the diagram below: - - -Range Data Components - - -Details and requirements about each of these classes are given in the following sections. - - /req/uml-simple-components/package-fully-implemented - -The encoding or software shall correctly implement all classes defined in the “Simple Components” and “Basic Types” UML packages. - - -Several dependencies to ISO standards exist and are detailed below. - -Data types from several packages of the ISO 19103 standard are used directly which makes this requirement class dependent on it. These data types are “CharacterString”, “Boolean”, “Real”, “Integer”, “Date”, “Time”, “DateTime”, “ScopedName”, “UnitOfMeasure” and “UomTime”. - - /req/uml-simple-components/iso19103-implemented - -The encoding or software shall correctly implement all UML classes defined in ISO 19103 that are referenced directly or indirectly by this standard. - - -The “TM_Position” data type from the “Temporal Reference System” package of the ISO 19108 standard is also used. - - /req/uml-simple-components/iso19108-implemented - -The encoding or software shall correctly implement all UML classes defined in ISO 19108 that are referenced directly or indirectly by this standard. - - -The “SC_CRS” and “TM_Temporal_CRS” classifiers are referenced conceptually from ISO 19111 but their implementation is not required by this standard. Implementations are allowed to simply use a CRS identifier as a mean of recognizing predefined coordinate reference systems. The use of identifiers from the EPSG database is recommended in this case. However, when new CRS definitions need to be created (e.g. engineering CRS attached to sensors or platforms), the models defined in ISO 19111 shall be used. - - -Basic Data Types -This requirement class also includes requirements for the “Basic Types” UML package. This package defines low level data types that are used as property types by classes defined in the other packages. - -Data types defined in this package relate to defining pairs of data types defined in ISO 19103 for use within classes describing value extents: - - -Basic types for pairs of scalar types - - - - -Attributes shared by all data components -All SWE Common data component classes carry standard attributes inherited (transitively) from the “AbstractDataComponent” and “AbstractSWEValue” classes (The “AbstractSWEValue” class is actually defined in the “Basic Types” package but is shown here for clarity). The class hierarchy is shown on the following UML diagram: - - -AbstractDataComponent Class - - -Extension Slot - -The “extension” attribute is used as a container for future extensions. It allows adding new extended properties to an existing class at the instance level. - -Name and Description - -The optional “name” and “description” attributes can be used to provide human readable information describing what property the component represents. The “name” is meant to hold a short descriptive name whereas “description” can carry any length of plain text. These two fields should not be used to specify robust semantic information (see ). Instead, the “definition” attribute described below should be used for that purpose. - -Identifier - -The optional “identifier” attribute allows assigning a unique identifier to the component, so that it can be referenced later on. It can be used, for example, when defining the unique identifier of a universal constant. - -Definition - -The “definition” attribute identifies the property (often an observed property in our context) that the data component represents by using a scoped name. It should map to a controlled term defined in an (web accessible) dictionary, registry or ontology. Such terms provide the formal textual definition agreed upon by one or more communities, eventually illustrated by pictures and diagrams as well as additional semantic information such as relationships to units and other concepts, ontological mappings, etc. - -Examples - -The definition may indicate that the value represents an atmospheric temperature using a URN such as “urn:ogc:def:property:OGC::SamplingTime” referencing the complete definition in a register. - -The definition may also be a URL linking to a concept defined in an ontology such as [http//www.opengis.net/def/OGC/0/SamplingTime]. -The label could be “Sampling Time”, which allows quick identification by human data consumers. - -The description could be “Time at which the observation was made as measured by the on-board clock” which adds contextual details. - - -Flags - -The “optional” attribute is an optional flag indicating if the component value can be omitted in the data stream. It is only meaningful if the component is used as a schema descriptor (i.e. not for a component containing an inline value). It is ‘false’ by default. - -The “updatable” attribute is an optional flag indicating if the component value is fixed or can be updated. It is only applicable if the data component is used to define the input of a process (i.e. when used to define the input or parameter of a service, process or sensor, but not when used to define the content of a dataset). - -Examples - -The “updatable” flag can be used to identify what parameters of a system are changeable. The exact semantics depends on the context. For example: - -In SensorML process chains, the “updatable” flag is used to identify process parameters that can accept an incoming connection (and thus can get changed while the process is in execution). - -In a SensorML System it is used to indicate whether or not a system parameter is changeable, either by an operator (i.e. by turning a screw or inserting a jumper) or remotely by sending a command. - -In the Sensor Planning Service it is used to indicate if tasking parameters are changeable by the client (i.e. by using the Update operation) after a task has been submitted. - - - - - - -Attributes shared by all simple data components -As shown on , classes modeling simple data components inherit attributes from the “AbstractSimpleComponent” class from which they are directly derived. This abstract class is shown again below: - - -AbstractSimpleComponent Class - - -The definition attribute inherited from the “AbstractDataComponent” class is mandatory on this class and thus on all its descendants. - - /req/uml-simple-components/definition-present - -The “definition” attribute shall be specified by all instances of concrete classes derived from “AbstractSimpleComponent”. - - -Reference Frames and Axes - -It provides two attributes allowing the association of a data component to a reference frame and an axis and thus implements core concepts introduced in . These attributes are used for a component which value is the projection of a property along a temporal or spatial axis. - -The “referenceFrame” attribute identifies the reference frame (as defined by the “SC_CRS” object) relative to which the coordinate value is given. The “axisID” attribute takes a string that uniquely identifies one of the reference frame’s axes along which the coordinate value is given. - - /req/uml-simple-components/axis-valid - -The value of the “axisID” attribute shall correspond to the “axisAbbrev” attribute of one of the coordinate system axes listed in the specified reference frame definition. - - -The union of these two attributes thus uniquely identifies one axis of one given reference frame along which the value of the component is expressed. Note that even though the ISO 19111 model assigns units to CRS axes in addition to a direction, only the direction is used in this standard and the unit is defined by the data component itself. This allows expressing other quantities than the one predefined along the CRS’s axes such as velocity, acceleration or rotation. - -A component representing a projected quantity can be defined in isolation or can be contained within a “Vector” or ”Matrix” aggregate when it contributes to the specification of a multi-dimensional quantity (see ). In this last case the reference frame definition is usually inherited from the parent “Vector” or ”Matrix” instance and is thus omitted from the scalar component itself. However, the “axisID” attribute still needs to be specified on “Vector” components. - - /req/uml-simple-components/axis-defined - -The “axisID” attribute shall be specified by all instances of concrete classes derived from “AbstractSimpleComponent” and representing a property projected along a spatial axis. - - - /req/uml-simple-components/ref-frame-defined - -The “referenceFrame” attribute shall be specified by all instances of concrete classes derived from “AbstractSimpleComponent” and representing a property projected along a spatial or temporal axis, except if it is inherited from a parent aggregate (Vector or Matrix). - - -Quality - -The optional “quality” attribute is used to provide simple quality information as discussed in . It is of type “Quality” which is a union of several classes as defined in . Its multiplicity is more than one which means that several quality measures can be given on for a single data component. - -Example - -Both precision and accuracy of the value associated to a data component can be specified concurrently (see for a good explanation of the difference between the two). - - -Nil Values - -The optional “nilValues” attribute is used to provide a list (i.e. one or more) of NIL values as defined in . The model of the “NilValues” class is detailed in . - -Concrete sub-classes of “AbstractSimpleComponent” can also define a “constraint” attribute that allows further restriction of the possible values allowed by the corresponding representation. This implements concepts defined in . These constraints always apply to the value of the property as represented by the corresponding data component whether this value is given inline (data container case) or out-of-band (data descriptor case). - -Constraints - - /req/uml-simple-components/value-constraint-valid - -The property value (formally the representation of the property value) attached to an instance of a class derived from “AbstractSimpleComponent” shall satisfy the constraints specified by this instance. - - -All concrete sub-classes of “AbstractSimpleComponent” also define a “value” attribute. This attribute is not defined in this abstract class because it has a different primitive type in each concrete data component class (See following clauses). - - /req/uml-simple-components/value-attribute-present - -All concrete classes derived from the “AbstractSimpleComponent” class (directly or indirectly) shall define an optional “value” attribute and use it as defined by this standard. - - -The “value” attribute is always optional on any simple data component in order to allow for both data descriptor and data container cases: - -When the data component is used as a data container, this attribute always carries the value of the associated property (formally the representation of the estimated or asserted value of the property). Quality information, nil values definitions and constraints thus apply to the value taken by this attribute. - -When the data component is used as a data descriptor, its actual value is provided somewhere else, often encoded as part of a larger data block. In this case, quality information, nil values definitions and constraints apply to the out-of-band value and not to the “value” attribute. Instead, the “value” attribute can then be used to specify a default value. - - - -Whether the data component is used as a descriptor or a container depends on the context and should be explicitly stated by any standard that makes use of the SWE Common Data Model. - -All UML classes in this package that derive from “AbstractSimpleComponent” define a “value” attribute with the adequate primitive type and whose meaning is the one explained above. - - - -Boolean Class -The “Boolean” class is used to specify a scalar data component with a Boolean representation as defined in . It derives from “AbstractSimpleComponent” and is shown below: - - -Boolean Class - - -The “value” attribute of this class is of the boolean primitive type.The boolean primitive type is defined in ISO19103 and is not to be confused with the “Boolean” class defined in this standard. This clause is the only place in this standard where the ISO 19103 boolean data type is referenced. All other occurrences of the “Boolean” class in this standard refer to the class defined in this clause. - - - - - - -Text Class -The “Text” class is used to specify a component with a textual representation as defined in . It derives from “AbstractSimpleComponent” and is shown below: - - -Text Class - - -Constraints - -The “constraint” attribute allows further restricting the range of possible values by using the “AllowedTokens” class defined in . This class allows the definition of the constraint by either enumerating the allowed tokens and/or by specifying a pattern that the value must match. - -Value - -The “value” attribute (or the corresponding value in out-of-band data) is a string that must match the constraint.The “Text” component can be used to wrap a string representing complex content such as an expression in a programming language, xml or html content. This practice should however be used only for systems that don’t require high level of interoperability since the client must know how to interpret the content. Also care must be taken to properly escape such content before it is inserted in an XML document or in a SWE Common data stream. - - - - - - -Category Class -The “Category” class is used to specify a scalar data component with a categorical representation as defined in . It derives from “AbstractSimpleComponent” and is shown below: - - -Category Class - - -Code Space - -The “codeSpace” attribute is of type “Dictionary” and allows listing and defining the meaning of all possible values for this component. It is expected that instances of the “Dictionary” class will usually be referenced (rather than included inline) by implementations of this class since the code space definition is usually obtained from a controlled vocabulary maintained at a remote location. This type of implementation is the one chosen in the XML encodings defined by this standard. - -Constraints - -The “constraint” attribute allows further restricting the list of possible values by using the “AllowedTokens” class defined in . This is usually done by specifying a limited list of possible values, which have to be extracted from the code space. - - /req/uml-simple-components/category-constraint-valid - -When an instance of the “Category” class specifies a code space, the list of allowed tokens provided by the “constraint” property of this instance shall be a subset of the values listed in this code space. - - -It is also possible to use this class without a code space, even though it is not recommended as values allowed in the component would then not be formally defined. However, as the intent of this class is to always represent a value extracted from a set of possible options, a constraint shall be defined if no code space is specified. - - /req/uml-simple-components/category-enum-defined - -An instance of the “Category” class shall either specify a code space or an enumerated list of allowed tokens, or both. - - -Value - -The “value” attribute (or the corresponding value in out-of-band data) is a string that must be one of the items of the code space and also match the constraint. - - /req/uml-simple-components/category-value-valid - -When an instance of the “Category” class specifies a code space, the value of the property represented by this instance shall be equal to one of the entries of the code space. - - - - -Count Class -The “Count” class is used to specify a scalar data component with a discrete countable representation as defined in . It derives from “AbstractSimpleComponent” and is shown below: - - -Count Class - - -Constraints - -The “constraint” attribute can be used to restrict the range of possible values to a list of inclusive intervals and/or single values using the “AllowedValues” class defined in . Numbers used to define these constraints should be integers and expressed in the same scale as the count value itself. The “significantFigures” constraint allowed by the “AllowedValues” class is not applicable to the “Count” class. - -Value - -The “value” attribute (or the corresponding value in out-of-band data) is an integer that must be within one of the constraint intervals or exactly one of the enumerated values. - - - -Quantity Class -The “Quantity” class is used to specify a component with a continuous numerical representation as defined in . It derives from “AbstractSimpleComponent” and is shown below: - - -Quantity Class - - -Unit of Measure (UoM) - -In addition to attributes inherited from the “AbstractSimpleComponent” class, this class provides a unit of measure declaration through the “uom” attribute. This unit is essential for the correct interpretation of data represented as decimal numbers and is thus mandatory. Quantities with no physical unit still have a scale (such as unity, percent, per thousands, etc.) that must be specified with this property. - -Constraints - -The “constraint” attribute is used to restrict the range of possible values to a list of inclusive intervals and/or single values using the “AllowedValues” class defined in . Numbers used to define these constraints must be expressed in the same unit as the quantity value itself. Additionally, it is possible to constrain the number of significant digits that can be added after the decimal point. - -Value - -The “value” attribute (or the corresponding value in out-of-band data) is a real value that is within one of the constraint intervals or exactly one of the enumerated values, and most importantly is expressed in the unit specified. - - - -Time Class -The “Time” class is used to specify a component with a date-time representation and whose value is projected along the axis of a temporal reference frame. This class is also necessary to specify that a time value is expressed in a calendar system. This class derives from “AbstractSimpleComponent” and is shown below: - - -Time Class - - -Time is treated as a special type of continuous numerical quantity that can be either expressed as a scalar number with a temporal unit or a calendar date with or without a time of day. Consequently, this class has all properties of the “Quantity” class, plus some others that are specific to the treatment of time. - -Reference Frame - -As time is always expressed relative to a particular reference frame, the “referenceFrame” attribute inherited from the parent class “AbstractSimpleComponent” shall always be set on instances on this class unless the default ‘UTC’ is meant. - - /req/uml-simple-components/time-ref-frame-defined - -The “referenceFrame” attribute inherited from “AbstractSimple Component” shall always be set on instance of the “Time” class unless the UTC temporal reference system is used. - - -Note that specifying the frame of reference is required even when using ISO notation because there can be ambiguities between several universal time references such as UTC, TAI, GPS, UT1, etc… Differences between these different time reference systems are indeed in the order of a few seconds (and increasing), that is to say not negligible in various situations. - -Example - -J2000 is a well known epoch in astronomy and is equal to: - -January 1, 2000, 11:59:27.816 in the TAI time reference system - -January 1, 2000, 11:58:55.816 in the UTC time reference system - -January 1, 2000, 11:59:08.816 in the GPS time reference system - - - -These offsets are not always constant and depend on the irregular insertion of leap seconds in UTC. - - -The “axisID” attribute inherited from the parent class does not need to be set since a time reference system always has a single dimension. However it can be set to ‘T’ for consistency with spatial axes. - -Reference Time - -The “referenceTime” attribute is used to specify a different time origin than the one sometimes implied by the “referenceFrame”. This is used to express a time relative to an arbitrary epoch (i.e. different from the origin of a well known reference frame). The new time origin specified by “referenceTime” shall be expressed with respect to the reference frame specified and is of type “DateTime”. This forces the definition of this origin as a calendar date/time combination. - - /req/uml-simple-components/time-ref-time-valid - -The value of the “referenceTime” attribute shall be expressed with respect to the system of reference indicated by the “referenceFrame” attribute. - - -Example - -This class can be used to define a value expressed as a UNIX time (i.e. number of seconds elapsed since January 1, 1970, 00:00:00 GMT) by: - -Specifying that the reference frame is the UTC reference system - -Setting the reference time to January 1, 1970, 00:00:00 GMT. - -Setting the unit of measure to seconds - - - -See definitions of some commonly accepted time standards at or . - - -Local Frame - -The optional “localFrame” attribute allows for the definition of a local temporal frame of reference through the value of the component (i.e. we are specifying a time origin), as opposed to the referenceFrame which specifies that the value of the component is in reference to this frame. - - /req/uml-simple-components/time-local-frame-valid - -The “localFrame” attribute of an instance of the “Time” class shall have a different value than the “referenceFrame” attribute. - - -This feature allows chaining several relative time positions. This is similar to what is done with spatial position in a geopositioning algorithm (and which is also supported by this standard using the “Vector” class). - -Example 1 - -In the case of a whiskbroom scanner instrument, the “sampling time” is often expressed relative to the “scan start time” which is itself given relative to the “mission start time”. It is important to properly identify the chain of time reference systems at play so that the adequate process can compute the absolute time of every measurement made (Note that it is often not practical to record the absolute time of each single measurement when high sampling rates are used). - -Example 2 - -A model forecast may represent its result times relative to the “run time” of the model for efficient encoding. The values of the output will be in reference to this base epoch. In this example the “referenceFrame” attribute of the model time is set to UTC and the “localFrame” set as “ModelTime”. The model result would then define its “referenceFrame” as “ModelTime”, allowing the time values to be encoded relative to the specified time origin. - - -Unit of Measure (UoM) - -The “uom” attribute is mandatory since time is a continuous property that shall always be expressed in a well defined scale. The only units allowed are obviously time units. - -Constraints - -Similarly to the “Quantity” class, the “constraint” attribute allows further restricting the range of possible time values by using the “AllowedTimes” class defined in . - -Value - -The “value” attribute (or the corresponding value in out-of-band data) is of type “TimePosition” (see ) and must match the constraint. - - - -Requirements applicable to all range classes -This UML package defines four classes “CategoryRange”, “CountRange”, “QuantityRange” and “TimeRange” that are used for representing extents of property values. These classes have common requirements that are expressed in this clause. - -The “value” attribute of all these classes takes a pair of values (with a datatype corresponding to the representation) that represent the inclusive minimum and maximum bounds of the extent. These values must both satisfy the constraints specified by an instance of the class, and be expressed in the unit specified when applicable. - - /req/uml-simple-components/range-value-valid - -Both values specified in the “value” property of an instance of a class representing a property range (i.e. “CategoryRange”, “CountRange”, “QuantityRange” and “TimeRange”) shall satisfy the same requirements as the scalar value used in the corresponding scalar classes. - - -These classes are intentionally not derived from their scalar counterparts because they are aggregates of two values and should be treated as such by implementations (especially by encoding methods defined in this standard). - - - - -CategoryRange Class -The “CategoryRange” class is used to express a value extent using the categorical representation of a property. It defines the same attributes as the “Category” class and those should be used in the same way (see ): - - -CategoryRange Class - - - /req/uml-simple-components/category-range-valid - -All requirements associated to the “Category” class defined in apply to the “CategoryRange” class. - - -Code Space - -The “CategoryRange” class also requires that the underlying code space is well-ordered (i.e. the ordering of the different categories in the code space is clearly defined) so that the range is meaningful. - - /req/uml-simple-components/category-range-codespace-order - -The code space specified by the “codeSpace” attribute of an instance of the “CategoryRange” class shall define a well-ordered set of categories. - - -Example - -A “CategoryRange” can be used to specify the approximate time of a geological event by using names of geological eons, eras or periods such as [Archean — Proterozoic] or [Jurassic — Cretaceous]. - - -Value - -The “value” attribute of the “CategoryRange” class takes a pair of tokens representing the inclusive minimum and maximum bounds of the extent. - - - -CountRange Class -The “CountRange” class is used to express a value extent using the discrete countable representation of a property. It defines the same attributes as the “Count” class and those should be used in the same way (see ): - - -CountRange Class - - -Value - -The “value” attribute of the “CountRange” class takes a pair of integer numbers representing the inclusive minimum and maximum bounds of the extent. - - - -QuantityRange Class -The “QuantityRange” class is used to express a value extent using the discrete countable representation of a property. It defines the same attributes as the “Quantity” class and those should be used in the same way (see ): - - -QuantityRange Class - - -Value - -The “value” attribute of the “QuantityRange” class takes a pair of real numbers representing the inclusive minimum and maximum bounds of the extent. - - - -TimeRange Class -The “TimeRange” class is used to express a value extent of a time property. It defines the same attributes as the “Time” class and those should be used in the same way (see ): - - -TimeRange Class - - - /req/uml-simple-components/time-range-valid - -All requirements associated to the “Time” class defined in apply to the “TimeRange” class. - - -The “value” attribute of the “TimeRange” class takes a pair of values of type “TimePosition” representing the inclusive minimum and maximum bounds of the extent. - - - -Quality Union -The “Quality” class is a union allowing the use of different representations of quality. - -Quality can be indeed be specified as a decimal value, an interval, a categorical value or a textual statement. In our model, quality objects are in fact data components used in a recursive way, as shown on the following diagram: - - -Quality Union - - -These different representations of quality are useful to cover most use cases where simple quality information is provided with the data. - -Examples - -“Quantity” is used to specify quality as a decimal number such as accuracy, variance and mean, or probability. - -“QuantityRange” is used to specify a bounded interval of variation such as a bi-directional tolerance. - -“Category” is used for a quality statement based on a well defined taxonomy such as certification levels. - -“Text” is used to include a textual quality statement such as a comment written by a field operator. - - -The “definition” attribute of the chosen quality component helps to further define the type of quality information given just like any other data component, and the “uom” should be specified in the case of a decimal quality value or interval.Reusing data components to specify quality also allows the inclusion of quality values in the data stream itself. This is useful if the quality is varying and re-estimated for each measurement. This is for example the case in a GPS receiver where both horizontal and vertical errors are given along with the geographic position. See the XML implementation clause for more information on this use case. - - - - - - -NilValues Class -The “NilValues” class is used by all classes deriving from “AbstractSimpleComponent”. It allows the specification of one or more reserved values that may be included in a data stream when the normal measurement value is not available (see ). The UML model of this class is given below: - - -NilValues Class - - -An instance of the “NilValues” class is composed of one to many “NilValue” objects, each of which specifies a mapping between a reserved value and a reason. - -The mandatory “reason” attribute indicates the reason why a measurement value is not available. It is a resolvable reference to a controlled term that provides the formal textual definition of this reason (usually agreed upon by one or more communities). - - /req/uml-simple-components/nil-reason-resolvable - -The “reason” attribute of an instance of the “NilValue” class shall map to the complete human readable definition of the reason associated with the NIL value. - - -The mandatory “value” attribute specifies the data value that would be found in the stream to indicate that a measurement value is missing for the corresponding reason. The range of values allowed here is the range of values allowed by the datatype of the parent data component. - - /req/uml-simple-components/nil-value-type-coherent - -The value used in the “value” property of an instance of the “NilValue” class shall be compatible with the datatype of the parent data component object. - - -This means that when specifying NIL values for a “Quantity” component, only real values are allowed (in most implementations, this includes NaN, -INF and INF) and for a “Count” component only integer values are allowed. - -Consequently, it is also impossible to specify NIL values for a “Boolean” data component since it allows only two possible values. In this case a “Category” component should be used. - -There are no restrictions on the choice of NIL values for “Category” and “Text” components since their datatype is String. - - - -AllowedTokens Class -The “AllowedTokens” class is used to express constraints on the value of a data component represented by a “Text” or a “Category” class. The UML class is shown below: - - -AllowedTokens Class - - -This class allows defining the constraint either by enumerating a list of allowed values by using one or more “value” attributes and/or by specifying a pattern that the value must match. The value must then either be one of the enumerated tokens or match the pattern. - - - -AllowedValues Class -The “AllowedValues” class is used to express constraints on the value of a data component represented by a “Count” or a “Quantity” class. The UML class is shown below: - - -AllowedValues Class - - -This class allows constraints to be defined either by enumerating a list of allowed values and/or a list of inclusive intervals. To be valid, the value must either be one of the enumerated values or included in one of the intervals. The numbers used in the “value” and “interval” properties shall be expressed in the same unit as the parent data component. - - /req/uml-simple-components/allowed-values-unit-coherent - -The scale of the numbers used in the “enumeration” and “interval” properties of an instance of the “AllowedValues” class shall be expressed in the same scale as the value(s) that the constraint applies to. - - -If the parent data component instance is used to define a projected quantity (i.e. when the “axisID” is set), then the constraints given by this class are expressed along the same spatial reference frame axis. - -The number of significant digits can also be specified with the “significantFigures” property though it is only applicable when used with a decimal representation (i.e. within the “Quantity” class). This limits the total number of digits that can be included in the number represented whether a scientific notation is used or not. - -Examples - -All non-zero digits are considered significant. 123.45 has five significant figures: 1, 2, 3, 4 and 5. - -Zeros between two non-zero digits are significant. 101.12 has five significant figures: 1, 0, 1, 1 and 2. - -Leading zeros are not significant. 0.00052 has two significant figures: 5 and 2 and is equivalent to 5.2×10-4 and would be valid even if the number of significant figures is restricted to 2. - -Trailing zeros are significant. 12.2300 has six significant figures: 1, 2, 2, 3, 0 and 0 and would thus be invalid if the number of significant figures is restricted to 4. - - -The number of significant figures and/or an interval constraint (i.e. min/max values) can help a software implementation choosing the best data type to use (i.e. ‘float’ or ‘double’, ‘short’, ‘int’ or ‘long’) to store values associated to a given data component. - - - - -AllowedTimes Class -The “AllowedTimes” class is used to express constraints on the value of a data component represented by a “Time” class. The UML class is shown below: - - -AllowedTimes Class - - -This class is almost identical to the “AllowedValues” class and in fact all properties are used in the same way. The only difference with this class is that the “value” and “interval” properties allow the use of time data types as defined in . - -The constraints given by this class are expressed along the same time reference frame axis as the value attached to the parent data component. - - - -Unions of simple component classes -Several useful groups of classes are also defined in this package. These unions can be used as attribute types and they are shown on the following diagram: - - -Simple Component Unions - - -The “AnyScalar” union groups all classes representing scalar components, numerical or not. The “AnyNumerical” union includes all classes corresponding to numerical scalar representations. The “AnyRange” union regroups all range components. - - - - -Requirements Class: Record Components Package - -Record Components UML Package /req/uml-record-componentsSoftware Implementation or Encoding of the Conceptual Models/req/uml-simple-components - - - -As detailed in the following clauses, this package defines classes modeling record style component types that can be nested to build complex structures from the simple component types introduced in . - -The classes defined in this package are “DataRecord” and “Vector” (other aggregates are defined in the “Choice Components” and “Block Components” packages defined in respectively). The UML model is exposed below: - - -Record Data Components - - - /req/uml-record-components/package-fully-implemented - -The encoding or software shall correctly implement all classes defined in the “Record Components” UML package. - - -As with simple component types, all data aggregates inherit attributes from the “AbstractDataComponent” class. In this case, however, these attributes provide information about the group as a whole rather than its individual components. - -Examples - -A particular “DataRecord” might represent a standard collection of error codes coming from a GPS device. - -A particular “Vector” might represent the linear or angular velocity vector of an aircraft. - -In these two cases, the “definition” attribute should reference a semantic description in a registry, so that the data consumer knows what kind of data the aggregate represents. This semantic description can then be interpreted appropriately by consuming clients: for example to automatically decide how to style the data in visualization software. - - - -DataRecord Class -The “DataRecord” class is modeled on the definition of ‘Record’ from ISO 11404. In this definition, a record is a composite data type composed of one to many fields, each of which having its own name and type definition. Thus it defines some logical collection of components of any type that are grouped for a given purpose. - -As shown on the following figure, the “DataRecord” class in SWE Common is based on a full composite design pattern, such that each one of its “field” can be of a different type, including simple component types as well as any aggregate component type. - - -DataRecord Class - - -The “DataRecord” class derives from the “AbstractDataComponent” class, which is necessary to enable the full composite pattern in which a “DataRecord” can be used to group scalar components, but also other records, arrays and choices recursively. - -Fields - -Each “field” attribute can take an instance of any concrete sub-class of “AbstractDataComponent”, which is the superset of all data component types defined in this standard. The name of each field must be unique within a given “DataRecord” instance so that it can be used as a key to uniquely identify and/or index each one of the record components. - - /req/uml-record-components/record-field-name-unique - -Each “field” attribute in a given instance of the “DataRecord” class shall be identified by a name that is unique to this instance. - - -Example - -A “DataRecord” can group related values such as “temperature”, “pressure” and “wind speed” into a structure called “weather measurements”. This feature is often used to organize the data and present it in a clear way to the user. - -Similarly a “DataRecord” can be used to group values of several spectral bands in multi-spectral sensor data. However, using a “DataArray” may be easier to describe hyper spectral datasets with several hundreds of bands. - - -The slightly different definition of record found in ISO 19103 provides for its schema to be specified in an associated “RecordType”. When used as a descriptor, the “DataRecord” implements the ISO 19103 “RecordType”. When used as a data container, it is self-describing: the descriptive information is then interleaved with the record values. - - - - -Vector Class -The “Vector” class is used to express multi-dimensional quantities with respect to a well defined referenced frame (usually a spatial or spatio-temporal reference frame). This is done by projecting the quantity on one or several axes that define the reference frame and assigning a value to each of the axis projections. - -The “Vector” class is a special case of a record that takes a collection of coordinates that are restricted to a numerical representation. Coordinates of a “Vector” can thus only be of type “Quantity”, “Count” or “Time”. Its UML diagram is shown below: - - -Vector Class - - -Coordinates - -Just like record fields, vector coordinates must have a unique name: - - /req/uml-record-components/vector-coord-name-unique - -Each “coordinate” attribute in a given instance of the “Vector” class shall be identified by a name that is unique to this instance. - - -Reference Frame - -This class contains a mandatory “referenceFrame” attribute that identifies the frame of reference with respect to which the vector quantity is expressed. The coordinates of the vector correspond to values projected on the axes of this frame. - -The “referenceFrame” attribute is inherited by all components of the “Vector”, so that it shall not be redefined for each coordinate. However the “axisID” attribute shall be specified for each coordinate, in order to unambiguously indicate what axis of the reference frame it corresponds to. - - /req/uml-record-components/vector-component-no-ref-frame - -The “referenceFrame” attribute shall be ommited from all data components used to define coordinates of a “Vector” instance. - - - /req/uml-record-components/vector-component-axis-defined - -The “axisID” attribute shall be specified on all data components used as children of a “Vector” instance. - - -Local Frame - -The optional “localFrame” attribute allows identifying the frame of interest, that is to say the frame we are positioning with the coordinate values associated to this component (by opposition to the “referenceFrame” that specifies the frame with respect to which the values of the coordinates are expressed). - - /req/uml-record-components/vector-local-frame-valid - -The “localFrame” attribute of an instance of the “Vector” class shall have a different value than the “referenceFrame” attribute. - - -Correctly identifying the local and reference frame is an important feature that allows chaining several relative positions, something that is essential to correctly compute accurate position of sensor data (especially remote sensing data). - -Example 1 - -A position vector (or location vector) is used to locate the origin of a frame of interest (the local frame) relative to the origin of a frame of reference (the reference frame) through a linear translation. It is composed of three coordinates of type “Quantity”, each with a definition indicating that the coordinate represents a length expressed in the desired unit. The definition of the “Vector” itself should also indicate that it is a “location vector”. - - - -Example 2 - -An orientation vector is used to indicate the rotation of the axes of a frame of interest (the local frame) relative to a frame of reference (the reference frame). It is composed of three coordinates of type “Quantity” with a definition indicating an angular property. The “Vector” definition should indicate the type of orientation vector such as “Euler Angles” or “Quaternion”. Depending on the exact definition, the order in which the coordinates are listed in the vector may matter. - - -“Vector” aggregates are most commonly used to describe position, orientation, velocity, and acceleration within temporal and spatial domains, but can also be used to express relationships between any two coordinate frames. - - - - - -Requirements Class: Choice Components Package - -Choice Components UML Package /req/uml-choice-componentsSoftware Implementation or Encoding of the Conceptual Models/req/uml-simple-components - - - -As detailed in the following clauses, this package defines a class modeling a disjoint union component type. This aggregate type can be nested with other aggregate components to build complex structures. - - /req/uml-choice-components/package-fully-implemented - -The encoding or software shall correctly implement all classes defined in the “Choice Components” UML package. - - - -DataChoice Class -The “DataChoice” class (also called Disjoint Union) is modeled on the definition of ‘Choice’ from ISO 11404. It is a composite component that allows for a choice of child components. By opposition to records that carry all their fields simultaneously, only one item at a time can be present in the data when wrapped in a “DataChoice”. The following diagram shows the “DataChoice” class as implemented in the SWE Common Data Model: - - -DataChoice Class - - -This class implements a full composite pattern, so that each “item” can be any data component, including simple and aggregate types. - -The “choiceValue” attribute is used to represent the token value that would be present in the data stream and that indicates the actual choice selection before the corresponding data can be given (i.e. knowing what choice item was selected ahead of time is necessary for proper decoding of encoded data streams). - -Items - -Each “item” attribute can take an instance of any concrete sub-class of “AbstractDataComponent”, which is the superset of all data component types defined in this standard. The name of each item shall be unique within a given “DataChoice” instance so that it can be used as a key to uniquely identify and/or index each one of the choice components. - - /req/uml-choice-components/choice-item-name-unique - -Each “item” attribute in a given instance of the “DataChoice” class shall be identified by a name that is unique to this instance. - - -The “DataChoice” component is used to describe a data structure (or a part of the structure) that can alternatively contain different types of objects. It can also be used to define the input of a service or process that allows a choice of structures as its input. - -Examples - -NMEA 0183 compatible devices can output several types of sentences in the same data stream. Some sentences include GPS location, while some others contain heading or status data. This can be described by a “DataChoice” which items represent all the possible types of sentences output by the device. - -A Sensor Planning Service (SPS) can define a choice in the tasking messages that the service can accept, thus leaving more possibilities to the users. - - - - - -Requirements Class: Block Components Package - -Block Components UML Package /req/uml-block-componentsSoftware Implementation or Encoding of the Conceptual Models/req/uml-simple-components/req/uml-simple-encodings - - - -This package defines additional aggregate components for describing arrays of values that are designed to be encoded as efficient data blocks. These additional aggregate components are purposely defined in a separate requirement class because they require a more advanced implementation for handling data values as encoded blocks. - -The UML models for these additional aggregate components are shown below: - - -Array Components - - - /req/uml-block-components/package-fully-implemented - -The encoding or software shall correctly implement all classes defined in the “Block Components” UML package. - - -The principle of these two classes is that the number and type of elements contained in the array is defined once, while the actual array values are listed separately without being redefined with each value. In order to achieve this, all array values are encoded as a single data block in the “values” attribute. Consequently, these classes are restricted to cases where all elements are homogeneous and thus can be described only once even though the array data may in fact contain many of them. - -This package also defines the “DataStream” class that is similar in principle to the “DataArray” class but cannot be nested within other aggregate data components. It is a top level class that encapsulates the description of a full data stream. - - -DataArray Class -The “DataArray” class is modeled on the corresponding definition of ISO 11404. This definition states that an array is a collection of elements of the same type (as opposed to a record where each field can have a different type), with a defined size. This class is shown on the following UML diagram: - - -DataArray Class - - -This class implements a full composite pattern, so that the “elementType” can be any data component, including simple and aggregate types. It can be used to group identical scalar components as well as records, choices and arrays in a recursive manner. - -Element Count - -The “elementCount” attribute is used to indicate the size of the array, that is to say the number of elements of the given type in the array. Note that each element is not necessarily scalar but can be a record, another array, etc. - -Element Type - -The content of the “elementType” attribute defines the exact structure of each element in the array. The data component used and all of its children shall not include any inline values, as these will be block encoded in the “values” attribute of the parent “DataArray”. - - /req/uml-block-components/array-component-no-value - -Data components that are children of an instance of a block component shall be used solely as data descriptors. Their values shall be block encoded in the “values” attribute of the block component rather than included inline. - - -However, the “DataArray” class itself, like any other data component can be used either as a data descriptor or as a data container. To use it as a data descriptor the “encoding” and “values” attributes are not set. To use it as a data container, these attributes are both set as described below. - -Encoding and Values - -The “encoding” and “values” fields are there to provide array data as an efficient block which can be encoded in several ways. The different encoding methods are described in . The “encoding” field shall have a value if the “values” field is present, and the data shall be encoded using the specified encoding. - - /req/uml-block-components/array-values-properly-encoded - -Whenever an instance of a block component contains values, an encoding method shall be specified by the “encoding” property and array values shall be encoded as specified by this method. - - -The choice of simple encodings (defined in the “Simple Encodings” package) allows encoding data as text using a delimiter separated values (DSV, a variant of CSV) format or as XML tagged values. The “Advanced Encodings” package defines binary encodings that can be used to efficiently package large datasets. - -Nested Components - -By combining instances of “DataArray”, “DataRecord” and scalar components, one can obtain the complex data structures that are necessary to fully describe any kind of sensor data. In particular, the possibility of nesting a “DataRecord” or “Vector” inside a “DataArray” allows defining structures such as trajectories, profiles, multi-band images, etc. - -Example 1 - -The “DataArray” class can be used to describe a simple 1D array of measurements such as radiance values obtained using a 12000 cells (1 row) CCD strip for instance. This can be done by using the “Quantity” class as the element type. In such a case, describing the dataset as a “DataRecord” would be a very repetitive task given the number of elements (12000 in this case!). - - - -Example 2 - -The “DataArray” class can be used as a descriptor for a trajectory dataset by using a vector of [latitude, longitude] coordinates as its element type. Note that this can also be considered as a 1D coverage in a 2D CRS. - - - - -Multi-dimensional Arrays - -Since the “DataArray” class alone can only represent 1-dimensional arrays, the construction of multi-dimensional arrays is done by nesting “DataArray” objects inside each other. - -Example - -The structure of panchromatic imagery data can be described with two nested arrays, which sizes indicate the two dimensions of the image. A “Quantity” is used as the element type of the nested array in order to indicate that the repeated element of the 2D array is of type infrared radiance with a given unit. - - - -In this example, the image is described as an array of rows, each row being an array of samples. It is also possible to describe an image as an array of columns by reversing the two dimensions. Note that this would change the order in which the data values would appear in a stream (by rows vs. by columns). - - -Array Size - -One powerful feature of the “DataArray” model is that it allows for the element count to be either fixed or variable, thus allowing the description of data streams with variable number of repetitive elements as is often the case with many kinds of sensor. - -In a fixed size array, the number of elements can be provided in the descriptor as an instance of the “Count” class with an inline value. This value is only present in the data description and not in the encoded block of array values. The definition of the “Count” instance is not required. - -In a variable size array, the “elementCount” attribute either contains an instance of the “Count” class with no value or references an instance of a “Count” class in a parent or sibling data component. The value giving the actual array size is then included in the stream, before the array values themselves, so that the block can be properly decoded. One obvious implementation constraint is that the value representing the array size must be received before the array values. This is detailed further in the XML implementation section. - -Examples - -Argo profiling floats can measure ocean salinity and temperature profiles of variable lengths by diving at different depths and depending on the conditions. A variable size “DataArray” could be used to describe their output data as well as a dataset aggregating data from several Argo floats. - -Variable size arrays can often be used to avoid unnecessary padding of fixed size array data. However for efficiency reasons (usually to enable fast random access w/o preliminary indexation), padding can also be specified in SWE Common when using the binary encoding. - - -Array Semantics - -As with any other data component, the “name” and “description” can be used to better describe the array and more importantly the “definition” attribute can be used to formally indicate the semantics behind the array. - -Example - -When a “DataArray” is used to package data relative to the spectral response of a sensor, the array “definition” attribute can be used to point to the formal out-of-band definition of the “spectral response” concept. - -Similarly a “DataArray” used to describe the output data of an Argo float would have its “definition” attribute reference the formal definition of a “profile”. - - -The value of the “definition” attribute of the “Count” instance used as the “elementCount” is also especially important, since it is used to define the meaning of the array dimension. Thanks to this, it is possible to tag the dimension of an array as spatial, temporal, spectral, or any other kind. However it is not mandatory as it is on other simple components. - -Examples - -In the CCD strip example described as a 1D array, the array index is the cell number in the strip. - -In the 2D image example, the outer array index is the row number, while the inner array index is the column (or sample) number. - -In a 1D array representing a time series, the array index is along the temporal dimension. - -In a 2D array representing a spatial coverage, the two array indices are along spatial dimensions. - -In a 3D array representing hyper-spectral imagery, the two first arrays have indices along spatial dimension while the most inner array is indexed along the spectral dimension. - - -This extra information can be used by software to make decisions (or at least ask the user by providing him this information) about how to represent or even interpolate the data. - - - -Matrix Class -The “Matrix” extends the “DataArray” class by providing a reference frame within which the matrix elements are expressed and a local frame of interest. The UML diagram of this class is shown below: - - -Matrix Class - - -The “Matrix” class is usually used to represent a position matrix or a tensor quantity of second or higher order. Each matrix element is expressed along the axis of a well defined reference frame. - -Element Type - -The “elementType” attribute inherited from the “DataArray” class can only take a nested “Matrix” instance or a scalar numerical component. Nested matrix objects allow the full description of N-dimensional matrices. - - /req/uml-block-components/matrix-element-type-valid - -The “elementType” attribute of an instance of the “Matrix” class can only be an instance of “Matrix” or of the classes listed in the “AnyNumerical” union. - - -Reference Frame - -The “referenceFrame” attribute is used in the same way as with the “Vector” class to specify the frame of reference with respect to which the matrix element values are expressed. It is inherited by all child components. - -Local Frame - -The “localFrame” attribute is used to identify the frame of interest, that is to say the frame whose orientation or position is given with the matrix in the case where it is a position matrix. If the matrix does not specify position, “localFrame” should not be used. Whether an instance of the “Matrix” class represents a position matrix or not should be disambiguated by setting the value of its “definition” attribute. - -Examples - -The “Matrix” class can be used to represent for instance: -- A 3D 3×3 stress tensor -- A 4D 4×4 homogeneous affine transformation matrix - -In particular it is often used to specify the orientation of an object relative to another one, like for instance the attitude of a plane relative to the earth. - - - - -DataStream Class -The “DataStream” class has a structure similar than the “DataArray” class but is not a data component (i.e. it does not derive from “AbstractDataComponent”) and thus cannot be used as a child of other aggregate components. Below is its UML diagram: - - -DataStream Class - - -This class should be used as the wrapper object to define a complete data stream. It defines a data stream as containing a list of elements with an arbitrary complex structure. An important feature is that the data stream can be open ended (i.e. the number of elements is not known in advance) and is thus designed to support real time streaming of data. - -Element Count - -The “elementCount” attribute is optional and can be used to indicate the number of elements in the stream if it is known. This is done by instantiating an instance of the “Count” class whose “value” attribute would be set to the number of elements. - -Element Type - -The “elementType” attribute is used to define the structure of each element in the stream. The data component used as the element type and all of its children shall be used solely as data descriptors, meaning that they shall not include any inline values. These values will instead be block encoded in the “values” attribute of the parent “DataStream”. - -Encoding and Values - -The “encoding” and “values” fields are there to provide the stream values as an efficient block which can be encoded in several ways. The same encoding methods as for the “DataArray” class are available and are described in . The “values” attribute is optional as the DataStream class can be used as a simple descriptor. - - /req/uml-block-components/datastream-array-valid - -Data components that are children of an instance of the ”DataStream” class shall be used solely used as data descriptors. Their values shall never be included inline since they will be block encoded in the stream described by the ”DataStream”. - - - - - -Requirements Class: Geometry Components Package - -Geometry Components UML Package /req/uml-geom-componentsSoftware Implementation or Encoding of the Conceptual Models/req/uml-simple-components - - - -This package defines an additional component for representing simple feature geometries, as defined by , within an encoded SWE Common data block or stream. - - /req/uml-geom-components/package-fully-implemented - -The encoding or software shall correctly implement all classes defined in the “Geometry Components” UML package. - - - -Geometry Class -The “Geometry” class extends the “AbstractDataComponent” class with a value of type geometry and a constraint that can be used to limit the types of allowed geometries. This class is shown on the following UML diagram: - - -Geometry Class - - -Coordinate Reference System - -The “crs” attribute provides the URI of the coordinate reference system w.r.t which the geometry coordinates are expressed. The unit of the coordinates is also provided by the coordinate reference system. - - /req/uml-geom-components/srs-valid - -The “srs” attribute shall reference the definition of a valid 2D or 3D spatial reference system. - - -Constraints - -The “constraint” attribute is used to restrict the possible geometries that can be provided using this component when it is used as a descriptor. The constraint is provided using the “AllowedGeometries” class that includes a list of allowed geometry types. - -Value - -The value of this component must be a geometry instance, whether it’s provided inline using the “value” attribute, or as part of a datastream. - - /req/uml-geom-components/geom-value-valid - -The “value” attribute shall be one of the concrete geometry value classes defined in : “Point”, “MultiPoint”, “LineString”, “MultiLineString”, “Polygon”, or “MultiPolygon”. - - -Encoding sections in this standard define how the geometry value is encoded: - -GML in the XML implementation and XML encoding rules - -GeoJSON in the JSON implementation and JSON encoding rules - -WKT in the Text encoding rules - -WKB in the Binary encoding rules - - - - - - - -Requirements Class: Simple Encodings Package - -Simple Encodings UML Package /req/uml-simple-encodingsSoftware Implementation or Encoding of the Conceptual Models/req/core - - - -Encoding methods describe how structured array and stream data is encoded into a low level byte stream (see related concepts in ). Once encoded as a sequence of bytes, the data can then be transmitted using various digital means such as files on a disk or network connections. - -This package includes two classes that provide definitions of simple encoding methods. They are used as descriptors of the method used to encode data component values wrapped by aggregate classes defined in the “Block Components” package. There model is shown on the diagram below: - - -Simple Encodings - - - /req/uml-simple-encodings/package-fully-implemented - -The encoding or software shall correctly implement all classes defined in the “Simple Encodings” UML package. - - -All classes defining encoding methods derive from a common abstract class called “AbstractEncoding”. Extensions to this standard that define new encoding methods shall derive encoding classes from this abstract class. - -The intent of this standard is to provide a set of core encodings covering most common needs. Each encoding has specific benefits that match the needs of different applications. Sometimes several encodings of the same dataset can be offered in order to satisfy several types of consumers and/or use cases. - -In the model provided in this standard, the encoding specification is provided separately from the data component tree describing the dataset structure, thus enabling several encodings to be applied to the same data structure without changing it. - - -TextEncoding Class -The “TextEncoding” class defines a method allowing encoding arbitrarily complex data using a text based delimiter separated values (DSV) format. The class used to specify this encoding method is shown below: - - -TextEncoding Class - - -The “tokenSeparator” attribute specifies the characters to use for separating each scalar value from one another. Scalar values appear sequentially in the stream alternatively with the token separator characters, in an order unambiguously defined by the data component structure. The detailed rules are given in the implementation . - -The “blockSeparator” attribute specifies characters used to mark the end of a “block”, corresponding to the complete structure defined by the data component tree (in a “DataArray”, “Matrix” or “DataStream” one block corresponds to one element, that is to say the structure defined by the “elementType” property). Stream or array data can then be composed of several blocks of the same type separated by block separator characters. - -The “decimalSeparator” attribute specifies the character used as the decimal point in decimal number. This attribute is optional and the default is a period (‘.’). - -Example - -In the case of a “DataStream” with an element type that is a “DataRecord” containing three fields – one of type “Category” and two of type “Quantity” — a data stream encoded using the Text method would look like the following: - -STATUS_OK,24.5,1022.5¶ -STATUS_OK,24.5,1022.5¶ -STATUS_OK,24.5,1022.5¶ - -Where , (comma) is the token separator and (carriage return) is the block separator (i.e. this is the CSV format). -Note that there could be many more values in a single block if the data set has a large number of fields, or if it contains an array of values. - - -The “collapseWhiteSpaces” attribute is a boolean flag used to specify if extra white spaces (including line feeds, tabs, spaces and carriage returns) surrounding the token and block separators should be ignored (skipped) when processing the stream. This is useful for encoded blocks of data that are embedded in an XML document, since formatting (indenting with spaces or tabs especially) is often done in XML content. - -This type of encoding is used when compactness is important but balanced by a desire of human readability. This type of encoding is easily readable (for debugging or manual usage) as well as easily imported in various spreadsheet, charting or scientific software. - -The main drawback of such an encoding is the impossibility of locating an error in the stream with certitude. Secondly, if only one expected value is missing, the whole block is usually lost since the parser cannot resynchronize correctly before the next block separator. This last issue can however be solved by transmitting this type of encoded stream using error resilient protocols when needed. - - - - -Requirements Class: Advanced Encodings Package - -Advanced Encodings UML Package /req/uml-advanced-encodingsSoftware Implementation or Encoding of the Conceptual Models/req/uml-simple-encodings - - - -This package defines an additional encoding method for packaging sensor data as raw or base 64 binary blocks. When this package is implemented, the binary encoding method is usable, as any other encoding method, within the “DataArray” and “DataStream” classes. - - /req/uml-advanced-encodings/package-fully-implemented - -The encoding or software shall correctly implement all classes defined in the “Advanced Encodings” UML package. - - - -BinaryEncoding Class -The “BinaryEncoding” class defines a method that allows encoding complex structured data using primitive data types encoded directly at the byte level, in the same way that they are usually represented in memory. - -The binary encoding method can lead to very compact streams that can be optimized for efficient parsing and fast random access. However this comes with the lack of human readability of the data and sometimes lack of compatibility with other software (i.e. software that is not SWE Common enabled). - -More information is needed to fully define a binary encoding, so the model is more complex than the other encodings. It is shown below: - - -BinaryEncoding Class - - -The main class “BinaryEncoding” specifies overall characteristics of the encoded byte stream such as the byte order (big endian or little endian) and the byte encoding (raw or base64). The two corresponding attributes, respectively “byteOrder” and “byteEncoding” are mandatory. Base64 encoding is usually chosen to insert binary content within an XML document. - -The “byteLength” attribute is optional and can be used to specify the overall length of the encoded data as a total number of bytes. This should be indicated whenever possible if the data size is known in advance as it can be useful for efficient memory allocation. - -The “BinaryEncoding” class also has several “member” attributes that contain detailed information about parts of the data stream. This attribute can take a choice of instance of two classes: “Component” or “Block”. - -The “Component” class is used to specify binary encoding details of a given scalar component in the stream. The following information can be provided for each scalar field: - -The “ref” attribute allows identifying the data component in the dataset structure for which we’re specifying the encoding parameters. Soft-typed property names are used to uniquely identify a given component in the tree. - -The “dataType” attribute allows selecting a data type among commonly accepted ones such as ‘byte’, ‘short’, ‘int’, ‘long’, ‘double’, ‘float’, ‘string’, etc… - -The “byteLength” or “bitLength” attributes are mutually exclusive and used to further specify the length of the data type in the case where it is not a standard length (i.e. to encode integer numbers on more than 8 bytes or less than 8 bits for instance). - -The “significantBits” can be used to signal that only some of the bits of the data type are actually used to carry the value (i.e. a value may be encoded as a byte but only use 4 bits to encode a value between 0 and 15). This is mostly informational. - -The “encryption” attribute can be used to select the method with which the value is encrypted before being written to the stream. - - - -The “Block” class is used to specify binary encoding details of a given aggregate component representing a block of values in the data stream. This is used either to specify padding before and/or after a block of data or to enable compression or encryption of all or part of a dataset. - -The “ref” attribute allows identifying the data component in the dataset structure for which we’re specifying the encoding parameters. Soft-typed property names are used to uniquely identify a given component in the tree. - -The optional “byteLength” attribute allows indicating the overall length of the encoded block to facilitate memory allocation. - -The “paddingBytes-before” and “paddingBytes-after” are used to specify the number of empty bytes (i.e. usually 0 bytes) that are inserted in the stream respectively before and after data for the referenced component. This is sometimes used to align data on N-bytes block for faster access. - -The “encryption” attribute identifies the encryption method that is used to encrypt the block of data before it is inserted in the stream. - -The “compression” attribute identifies the compression method that is used to compress the block of data before it is inserted in the stream. - - - -This standard does not define any concrete encryption and compression methods, so that software implementations of this requirement class are not required to support any value in the “encryption” and “compression” attributes of the “Component” and “Block” classes. Extensions of this standard that define binary encryption and compression methods shall describe how the encrypted or compressed data is inserted in the SWE Common data stream. - - - - - -JSON Implementation (normative) -This standard defines a normative JSON implementation of the conceptual models presented in . The standardization target type for all requirements classes in this clause is a JSON instance document that seeks compliance with this JSON encoding model. - -JSON schemas defined in this section are a direct implementation of the UML conceptual models described in . They have been generated from these models by strictly following well-defined encoding rules. All attributes and composition/aggregation associations contained in the UML models are encoded as JSON object members. - -All JSON examples given in this section are informative and are used solely for illustrating features of the normative model. Many of these examples reference semantic information by using URLs that resolve to the following online ontologies: - -The OGC online registry at . - -The QUDT quantity kinds ontology at . - -The SWEET ontology maintained by ESIP at . - -The MMI ontology registry and repository at . - - - -Some of the JSON examples contain inline values while others don’t. This is meant to illustrate that the component objects defined by the JSON implementation can be used as value objects for properties of larger metadata objects (e.g. SensorML system descriptions), but can also be used as descriptors to describe, for instance, the content of a datastream or the rangeset of a coverage. - - -Requirements Class: Basic Types and Simple Components JSON Schemas - -Basic Types and Simple Components JSON Schemas /req/json-simple-componentsJSON Document/req/uml-simple-components - - - -Validation patterns that implement all classes defined respectively in the “Basic Types” and “Simple Components” UML packages are provided as JSON schema files at . - -The entry point schema used for validation is “sweCommon.json”. - - /req/json-simple-components/schema-valid - -The JSON document instance shall be valid with respect to the JSON schema “sweCommon.json”. - - - -General JSON Principles -The following rules were used when generating the JSON schemas: - -Classes are implemented as JSON Objects; - -Any property with a multiplicty greater than one is implemented as a JSON Array and its name is converted to plural form; - -Textual fields are implemented as a JSON String; - -Decimal fields are implemented as a union of JSON Number and JSON String value types (the string value allowing for special values, see ); - -ISO8601 date/time fields are implemented as a JSON String with a union of date/time formats. - - - - - -Special Numerical Values -JSON does not define special decimal values for ‘Not a Number’, positive infinity and negative infinity. It is thus necessary to encode them as strings. - - /req/json-simple-components/special-numerical-values - -The special JSON Strings NaN, -Infinity and +Infinity shall be allowed as the inline or out-of-band value for Quantity and Time (and Count?) components (except when the Time component uses the ISO 8601 format). - - -These special value strings have been chosen because they are supported natively by Javascript/ECMA Script implementations. The + unary operator can be used to transparently parse one of these strings to a Number type (see ). - -These values also correspond to infinities and NaN values defined in . - - - - -Abstract Base Classes -The three abstract base classes defined in the UML models are implemented by the following JSON schemas: - -AbstractSweIdentifiable.json - -AbstractDataComponent.json - -AbstractSimpleComponent.json - - - - /req/json-simple-components/definition-resolvable - -The “definition” object member defined in the “AbstractDataComponent.json” schema shall contain a URI that can be resolved to the complete human readable definition of the property that is represented by the data component. - - - /req/json-simple-components/inline-value-constraint-valid - -The inline value included in a JSON instance validating against the “AbstractSimpleComponent.json” schema shall satisfy the constraints specified by this instance. - - - - -Boolean Object -The “Boolean” object is the JSON schema implementation of the “Boolean” UML class defined in . The schema for this class is provided in Boolean.json. - -The following snippet shows an example boolean component with an inline value: - -{ - "type": "Boolean", - "definition": "http://sweet.jpl.nasa.gov/2.0/physDynamics.owl#Motion", - "label": "Motion Detected", - "description": "True when motion was detected in the room", - "value": true -} - - -The next snippet is an example of boolean component used as data descriptor, hence with no value: - -{ - "type": "Boolean", - "definition": "http://mmisw.org/ont/q2o/test/timeContinuityTest", - "label": "Time Continuity Test", - "description": "Set to true to enable time continuity test" -} - - - - -Text Object -The “Text” object is the JSON schema implementation of the “Text” UML class defined in . The schema for this class is provided in Text.json. - -Constraints on a “Text” representation are expressed using the . - -The following snippets show how the “Text” component can be used to define human readable text fields, as well as any other alpha-numerical properties: - -{ - "type": "Text", - "definition": "http://sensorml.com/ont/swe/property/Manufacturer", - "label": "Manufacturer", - "value": "Ocean Devices, Inc." -} - - -{ - "type": "Text", - "definition": "http://sensorml.com/ont/x-swe/property/VehicleRegistrationNumber", - "label": "License Plate", - "value": "45ER-EJK-235" -} - - -Constraints can also be used — typically when the component is used as a descriptor — to limit the possible text values, either by enumeration or a regular expression pattern: - -{ - "type": "Text", - "definition": "http://sensorml.com/ont/x-swe/property/VehicleRegistrationNumber", - "label": "License Plate", - "constraint": { - "pattern": "^[0-9][A-Z]{4}-[A-Z]{3}-[0-9]{3}$" - } -} - - -This standard does not define any limit on the size of the text data than can be included as the value of a “Text” component, either inline or as part of a datastream. Implementations are responsible for documenting this upper limit. - - - - -Category Object -The “Category” object is the JSON schema implementation of the “Category” UML class defined in . The schema for this class is provided in Category.json. - -Constraints on a “Category” representation are expressed using the . - -The following examples illustrate how the “Category” component is used to define various fields with categorical representations. The categorical scale is defined either via a code space, an enumeration constraint, or both (in which case the enumeration constraint defines a subset of possible values from a code space): - -{ - "type": "Category", - "definition": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#GeologicTime", - "label": "Geological Period", - "description": "Name of the geological period according to the nomenclature of the International Commission on Stratigraphy", - "codeSpace": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#Period", - "value": "Jurassic" -} - - -{ - "type": "Category", - "definition": "http://sweet.jpl.nasa.gov/2.0/biol.owl#Species", - "label": "Bird Species", - "description": "Bird species according to the classification of the World Bird Database", - "codeSpace": "http://www.birdlife.org/datazone/species/index.html" -} - - - - -Count Object -The “Count” object is the JSON schema implementation of the “Count” UML class defined in . The schema for this class is provided in Count.json. - -Constraints on a “Count” representation are expressed using the . - -The following snippet shows a “Count” component used to define the size of a row in a raster dataset: - -{ - "type": "Count", - "definition": "http://www.opengis.net/def/property/OGC/0/NumberOfPixels", - "label": "Row Size", - "description": "Number of pixels in each row of the image", - "value": 1024 -} - - - - -Quantity Object -The “Quantity” object is the JSON schema implementation of the “Quantity” UML class defined in . The schema for this class is provided in Quantity.json. - -Constraints on a “Quantity” representation are expressed using the . - -The unit of measure is defined using either a URI or a code expressed using the Unified Code for Units of Measure () standard. - - /req/json-simple-components/ucum-code-used - -Whenever it can be constructed using the specification, the unit of measure shall be specified using a UCUM code as the value of the “uom/code” property. Otherwise the “uom/href” property shall be used to reference an external unit definition. - - -The following snippets show how “Quantity” components are used to define various (observable or controllable) properties with continuous decimal representations: - -{ - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Temperature", - "label": "Outside Temperature", - "description": "Outside temperature taken at the top of the antenna", - "uom": { "code": "Cel" }, - "value": 21.5 -} - - -{ - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/SpectralRadiance", - "label": "Radiance", - "description": "Radiance measured on band1", - "uom": { "code": "W.m-2.Sr-1.um-1" }, - "value": 2.83e-2 -} - - -{ - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/HeightAboveMSL", - "referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/5714", - "axisID": "H", - "label": "MSL Height", - "description": "Height above mean sea level", - "uom": { "code": "m" } -} - - - - -Time Object -The “Time” object is the JSON schema implementation of the “Time” UML class defined in . The schema for this class is provided in Time.json. - -Constraints on a “Time” representation are expressed using the . - -The unit of measure is defined using either a URI or a code expressed using the Unified Code for Units of Measure () standard. When the temporal property is provided in the format, this is indicated by using a specific URI. - - /req/json-simple-components/iso8601-uom-used - -When ISO 8601 notation is used to express the value associated to a “Time” element, the URI “http://www.opengis.net/def/uom/ISO-8601/0/Gregorian” shall be used as the value of the “uom/href” property. - - -The following snippets show how “Time” components are used to define various temporal properties, with different time scales: - -ISO8601 formatted time stamp based on the UTC time standard: - -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC-EO/0/MissionStartTime", - "referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC", - "localFrame": "urn:org:systems:001#MISSION-START-TIME", - "label": "Flight Time", - "description": "Time at take-off in UTC", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - }, - "value": "2009-01-26T10:21:45+01:00" -} - - -ISO8601 formatted time stamp based on the GPS time standard: - -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/USNO/0/GPS", - "label": "Sampling Time", - "description": "Time at which the measurement was made", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - }, - "value": "2009-11-05T16:29:26Z" -} - - -Time stamp in seconds past the Unix epoch: - -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/RunTime", - "referenceTime": "1970-01-01T00:00:00Z", - "label": "Model Run Time", - "description": "Run time of the model expressed as a Unix time", - "uom": {"code": "s" }, - "value": 1257415633 -} - - -Time stamp in seconds past a custom time reference called MISSION_START_TIME: - -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC-EO/0/ScanStartTime", - "referenceFrame": "urn:org:systems:001#MISSION-START-TIME", - "localFrame": "urn:org:systems:001#SCAN-START-TIME", - "label": "Scanline Time", - "description": "Acquisition time of the scan line", - "uom": { "code": "s" } -} - - - - -CategoryRange Object -The “CategoryRange” object is the JSON schema implementation of the “CategoryRange” UML class defined in . The schema for this class is provided in CategoryRange.json. - -“CategoryRange” objects share most properties with “Category” object, as shown on the following snippet: - -{ - "type": "CategoryRange", - "definition": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#GeologicTime", - "label": "Approximate Dating", - "description": "Approximate geological dating expressed as a range of geological eras", - "codeSpace": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#Era", - "value": ["Paleozoic", "Mesozoic"] -} - - - - -CountRange Object -The “CountRange” object is the JSON schema implementation of the “CountRange” UML class defined in . The schema for this class is provided in CountRange.json. - -“CountRange” objects share most properties with “Count” object, as shown on the following snippet: - -{ - "type": "CountRange", - "definition": "http://www.opengis.net/def/property/OGC/0/ArrayIndex", - "label": "Index Range", - "value": [0, 3000] -} - - - - -QuantityRange Object -The “QuantityRange” object is the JSON schema implementation of the “QuantityRange” UML class defined in . The schema for this class is provided in QuantityRange.json. - -“QuantityRange” objects share most properties with the “Quantity” object, as shown on the following snippet: - -{ - "type": "QuantityRange", - "definition": "http://mmisw.org/ont/mmi/device/OperationalRange", - "label": "Operational Range", - "description": "Operational temperature range of the cryogenic thermometer", - "uom": { "code": "K" }, - "value": [10, 300] -} - - - - -TimeRange Object -The “TimeRange” object is the JSON schema implementation of the “TimeRange” UML class defined in . The schema for this class is provided in TimeRange.json. - -“TimeRange” objects share most properties with the “Time” object, as shown on the following snippet: - -{ - "type": "TimeRange", - "definition": "http://www.opengis.net/def/property/EO/0/SurveyPeriod", - "referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC", - "label": "Survey Period", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - }, - "value": ["2008-01-05T11:02:54Z", "2009-11-05T16:29:26Z"] -} - - - - -NilValues Object -The “NilValues” object is the JSON schema implementation of the “NilValues” UML class defined in . Schema patterns for this class are provided in basicTypes.json. Several sub-patterns are defined for the decimal, integer and text cases. - -Examples of NIL values definitions are provided below, in the case of numerical, countable and textual representations: - -{ - "type": "Quantity", - "definition": "http://sweet.jpl.nasa.gov/2.0/physRadiation.owl#IonizingRadiation", - "label": "Radiation Dose", - "description": "Radiation dose measured by Gamma detector", - "uom": { "code": "uR" }, - "nilValues": [ - { "reason": "http://www.opengis.net/def/nil/OGC/0/BelowDetectionRange", "value": "-Infinity" }, - { "reason": "http://www.opengis.net/def/nil/OGC/0/AboveDetectionRange", "value": "Infinity" } - ] -} - - -{ - "type": "Count", - "definition": "http://sweet.jpl.nasa.gov/2.0/physRadiation.owl#Radiance", - "label": "Band 1", - "nilValues": [ - { "reason": "http://www.opengis.net/def/nil/OGC/0/BelowDetectionRange", "value": 0 }, - { "reason": "http://www.opengis.net/def/nil/OGC/0/AboveDetectionRange", "value": 255 } - ] -} - - -{ - "type": "Text", - "definition": "http://sensorml.com/ont/x-swe/property/VehicleRegistrationNumber", - "label": "License Plate", - "nilValues": [ - { "reason": "http://www.opengis.net/def/nil/OGC/0/Missing", "value": "Missing" }, - { "reason": "http://www.opengis.net/def/nil/OGC/0/Unknown", "value": "Unknown" } - ] -} - - - - -AllowedTokens Object -The “AllowedTokens” object is the JSON schema implementation of the “AllowedTokens” UML class defined in . The schema for this class is provided in basicTypes.json (see #definitions/AllowedTokens). - -Examples of constraints for textual or categorical properties are provided below: - -{ - "type": "Text", - "definition": "http://sensorml.com/ont/swe/property/ModelNumber", - "label": "Model Number", - "constraint": { - "pattern": "^[0-9][A-Z]{3}[0-9]{2}S1$" - } -} - - -{ - "type": "Category", - "definition": "http://www.opengis.net/def/property/OGC/0/SensorStatus", - "label": "Sensor Status", - "description": "Current connection status of the sensor", - "constraint": { - "values": [ "Off", "Stand-by", "Ready", "Busy" ] - } -} - - - - -AllowedValues Object -The “AllowedValues” object is the JSON schema implementation of the “AllowedValues” UML class defined in . The schema for this class is provided in basicTypes.json (see #definitions/AllowedValues). - -Examples of constraints for various numerical properties are provided below: - -{ - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Angle", - "label": "Planar Angle", - "uom": { "code": "deg" }, - "constraint": { - "intervals": [[-180, 180]] - } -} - - -{ - "type": "Count", - "definition": "http://www.opengis.net/def/property/OGC/0/NumberOfPixels", - "label": "Image Width", - "constraint": { - "values": [256, 512, 1024] - } -} - - -{ - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude", - "label": "Latitude", - "uom": { "code": "deg" }, - "constraint": { - "intervals": [[-90, 90]], - "significantFigures": 6 - } -} - - -Numerical constraints can also be unbounded: - -{ - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/RadialDistance", - "label": "Radial Distance", - "description": "Radial distance is always positive", - "uom": { "code": "m" }, - "constraint": { - "intervals": [[0, "+Infinity"]] - } -} - - - - -AllowedTimes Object -The “AllowedTimes” object is the JSON schema implementation of the “AllowedTimes” UML class defined in . The schema for this class is provided in basicTypes.json (see #definitions/AllowedTimes). - -Examples of constraints for various temporal properties, expressed as ISO-8601 or decimal values, are provided below: - -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/USNO/0/GPS", - "label": "Acquisition Time", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - }, - "constraint": { - "intervals": [["2009-01-01T00:00:00Z", "+Infinity"]] - } -} - - -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "urn:org:systems:001#SCAN-START-TIME", - "label": "Lidar Pulse Time", - "description": "Time stamp of LiDAR pulse relative to start of scan", - "uom": { "code": "ms" }, - "constraint": { - "intervals": [[0, 1e6]] - } -} - - - - - -Requirements Class: Record Components JSON Schema - -Record Components JSON Schema /req/json-record-componentsJSON Document/req/uml-record-components/req/json-simple-components - - - - -DataRecord Object -The “DataRecord” object is the JSON schema implementation of the “DataRecord” UML class defined in . The schema for this class is provided in DataRecord.json. - -The example below describes a record composed of weather data fields. In this case the “DataRecord” element is used as a descriptor for records of data that are provided as part of a datastream: - -{ - "type": "DataRecord", - "label": "Weather Data Record", - "fields": [ - { - "name": "time", - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC", - "label": "Sampling Time", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - } - }, - { - "name": "temperature", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/air_temperature", - "label": "Air Temperature", - "uom": { "code": "Cel" } - }, - { - "name": "pressure", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/air_pressure_at_mean_sea_level", - "label": "Air Pressure", - "uom": { "code": "mbar" } - }, - { - "name": "windSpeed", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/wind_speed", - "label": "Wind Speed", - "uom": { "code": "km/h" } - }, - { - "name": "windDirection", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/wind_to_direction", - "label": "Wind Direction", - "uom": { "code": "deg" } - } - ] -} - - -{ - "type": "DataRecord", - "definition": "urn:x-ogc:def:property:CSM::RadialDistortionCoefficients", - "label": "Radial Distortion Coefficients", - "fields": [ - { - "name": "k1", - "type": "Quantity", - "definition": "urn:x-ogc:def:property:CSM::DISTOR_RAD1", - "label": "Coef k1", - "uom": { "code": "mm-2" }, - "value": 1.92709e-5 - }, - { - "name": "k2", - "type": "Quantity", - "definition": "urn:x-ogc:def:property:CSM::DISTOR_RAD2", - "label": "Coef k2", - "uom": { "code": "mm-2" }, - "value": -5.14206e-10 - }, - { - "name": "k3", - "type": "Quantity", - "definition": "urn:x-ogc:def:property:CSM::DISTOR_RAD3", - "label": "Coef k3", - "uom": { "code": "mm-2" }, - "value": -3.33356e-12 - } - ] -} - - - - -Vector Object -The “Vector” object is the JSON schema implementation of the “Vector” UML class defined in . The schema for this class is provided in Vector.json. - -{ - "type": "Vector", - "definition": "http://www.opengis.net/def/property/OGC/0/PlatformLocation", - "referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/4326", - "label": "Platform Location", - "coordinates": [ - { - "name": "lat", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude", - "label": "Latitude", - "axisID": "Lat", - "uom": { "code": "deg" }, - "value": 45.36 - }, - { - "name": "lon", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Longitude", - "label": "Longitude", - "axisID": "Lon", - "uom": { "code": "deg" }, - "value": 5.2 - } - ] -} - - -{ - "type": "Vector", - "definition": "http://qudt.org/vocab/quantitykind/LinearVelocity", - "referenceFrame": "http://www.opengis.net/def/crs/OGC/0/ECI_J2000", - "label": "Platform Velocity", - "coordinates": [ - { - "name": "vx", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Speed", - "label": "Velocity X", - "uom": { "code": "m/s" } - }, - { - "name": "vy", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Speed", - "label": "Velocity Y", - "uom": { "code": "m/s" } - }, - { - "name": "vz", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Speed", - "label": "Velocity Z", - "uom": { "code": "m/s" } - } - ] -} - - -{ - "type": "Vector", - "definition": "http://sensorml.com/ont/swe/property/RotationQuaternion", - "referenceFrame": "http://www.opengis.net/def/crs/OGC/0/ECI_J2000", - "localFrame": "urn:org:systems:001#PLATFORM_FRAME", - "label": "Platform Orientation", - "coordinates": [ - { - "name": "qx", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Coordinate", - "label": "QX", - "uom": { "code": "1" } - }, - { - "name": "qy", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Coordinate", - "label": "QY", - "uom": { "code": "1" } - }, - { - "name": "qz", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Coordinate", - "label": "QZ", - "uom": { "code": "1" } - }, - { - "name": "qw", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Coordinate", - "label": "QW", - "uom": { "code": "1" } - } - ] -} - - - - - -Requirements Class: Choice Components JSON Schema - -Choice Components JSON Schema /req/json-choice-componentsJSON Document/req/uml-choice-components/req/json-simple-components - - - - -DataChoice Object -The “DataChoice” object is the JSON schema implementation of the “DataChoice” UML class defined in . The schema for this class is provided in DataChoice.json. - -{ - "type": "DataChoice", - "label": "Weather Data Message", - "items": [ - { - "name": "TEMP", - "type": "DataRecord", - "label": "Temperature Measurement", - "fields": [ - { - "name": "time", - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC", - "label": "Sampling Time", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - } - }, - { - "name": "temp", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/air_temperature", - "label": "Air Temperature", - "uom": { "code": "Cel" } - } - ] - }, - { - "name": "PRESS", - "type": "DataRecord", - "label": "Pressure Measurement", - "fields": [ - { - "name": "time", - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC", - "label": "Sampling Time", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - } - }, - { - "name": "press", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/air_pressure_at_mean_sea_level", - "label": "Air Pressure", - "uom": { "code": "HPa" } - } - ] - } - ] -} - - - - - -Requirements Class: Block Components JSON Schema - -Block Components JSON Schema /req/json-block-componentsJSON Document/req/uml-block-components/req/json-simple-components - - - - -DataArray Object -The “DataArray” element is the JSON schema implementation of the “DataArray” UML class defined in . The schema for this class is provided in DataArray.json. - -{ - "type": "DataArray", - "label": "Calibration Table", - "elementType": { - "name": "point", - "type": "DataRecord", - "label": "Data Point", - "fields": [ - { - "name": "t", - "type": "Quantity", - "definition": "https://qudt.org/vocab/quantitykind/Temperature", - "label": "Temperature", - "uom": { "code": "Cel" } - }, - { - "name": "r", - "type": "Quantity", - "definition": "https://qudt.org/vocab/quantitykind/Resistance", - "label": "Resistance", - "uom": { "code": "KOhm" } - } - ] - }, - "values": [ - {"t": 12, "r": 3.03}, - {"t": 30.1, "r": 1.68}, - {"t": 40.0, "r": 1.16}, - {"t": 50.1, "r": 0.85}, - {"t": 59.8, "r": 0.62} - ] -} - - -When provided inline, “DataArray” values are encoded using the method defined in . - -The following example shows how to define a 1D variable size array whose data is provided separately. - -{ - "type": "DataArray", - "definition": "http://sensorml.com/ont/swe/property/Trajectory", - "label": "Mobile Trajectory", - "elementCount": { - "definition": "http://www.opengis.net/def/property/OGC/0/NumberOfPoints", - "label": "Implicit Size" - }, - "elementType": { - "name": "point", - "type": "Vector", - "definition": "http://www.opengis.net/def/property/OGC/0/PlatformLocation", - "referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/4326", - "label": "Location Point", - "coordinates": [ - { - "name": "lat", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude", - "label": "Latitude", - "axisID": "Lat", - "uom": { "code": "deg" } - }, - { - "name": "lon", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Longitude", - "label": "Longitude", - "axisID": "Lon", - "uom": { "code": "deg" } - } - ] - } -} - - -“DataArray” components can also be nested to form multi-dimensional arrays, as shown in the following example of a 2D array: - -{ - "type": "DataArray", - "definition": "http://sensorml.com/ont/swe/property/RasterImage", - "label": "Satellite Image", - "elementCount": { - "definition": "http://www.opengis.net/def/property/OGC/0/NumberOfRows", - "value": 3000 - }, - "elementType": { - "name": "row", - "type": "DataArray", - "definition": "http://sensorml.com/ont/swe/property/RasterImage", - "elementCount": { - "definition": "http://www.opengis.net/def/property/OGC/0/NumberOfSamples", - "value": 3000 - }, - "elementType": { - "name": "pixel", - "type": "DataRecord", - "definition": "http://sensorml.com/ont/swe/property/GridCell", - "fields": [ - { - "name": "band1", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Radiance", - "label": "Radiance", - "description": "Radiance measured on band1", - "uom": { "code": "W.m-2.Sr-1" } - }, - { - "name": "band2", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Radiance", - "label": "Radiance", - "description": "Radiance measured on band2", - "uom": { "code": "W.m-2.Sr-1" } - }, - { - "name": "band3", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Radiance", - "label": "Radiance", - "description": "Radiance measured on band3", - "uom": { "code": "W.m-2.Sr-1" } - } - ] - } - } -} - - - - -Matrix Object -The “Matrix” object is the JSON schema implementation of the “Matrix” UML class defined in . The schema for this class is provided in Matrix.json. - -{ - "type": "Matrix", - "definition": "http://sensorml.com/ont/swe/property/RotationMatrix", - "referenceFrame": "http://www.opengis.net/def/crs/OGC/0/ECI_J2000", - "label": "3D Orientation Matrix", - "elementType": { - "name": "row", - "type": "Matrix", - "elementType": { - "name": "coef", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Coordinate", - "label": "Matrix Coef", - "uom": { "code": "1" } - } - }, - "values": [ - [0.36,0.48,-0.8], - [-0.8,0.6,0], - [0.48,0.64,0.6] - ] -} - - -When provided inline, “Matrix” values are encoded using the method defined in . - - - -DataStream Object -The “DataStream” object is the JSON schema implementation of the “DataStream” UML class defined in . The schema for this class is provided in DataStream.json. - -{ - "type": "DataStream", - "label": "Aircraft Navigation", - "elementType": { - "name": "navData", - "type": "DataRecord", - "fields": [ - { - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/USNO/0/GPS", - "referenceTime": "1970-01-01T00:00:00Z", - "label": "Sampling Time", - "uom": { "code": "s" } - }, - { - "name": "location", - "type": "Vector", - "definition": "http://www.opengis.net/def/property/OGC/0/PlatformLocation", - "referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/4979", - "label": "Platform Location", - "coordinates": [ - { - "name": "lat", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude", - "label": "Latitude", - "axisID": "Lat", - "uom": { "code": "deg" } - }, - { - "name": "lon", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Longitude", - "label": "Longitude", - "axisID": "Lon", - "uom": { "code": "deg" } - }, - { - "name": "alt", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/HeightAboveEllipsoid", - "label": "Altitude", - "axisID": "h", - "uom": { "code": "m" } - } - ] - }, - { - "name": "attitude", - "type": "Vector", - "definition": "http://www.opengis.net/def/property/OGC/0/PlatformOrientation", - "referenceFrame": "http://www.opengis.net/def/cs/OGC/0/ENU", - "label": "Platform Attitude", - "coordinates": [ - { - "name": "heading", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/TrueHeading", - "label": "Heading", - "axisID": "Z", - "uom": { "code": "deg" } - }, - { - "name": "pitch", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/PitchAngle", - "label": "Pitch", - "axisID": "X", - "uom": { "code": "deg" } - }, - { - "name": "roll", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/RollAngle", - "label": "Roll", - "axisID": "Y", - "uom": { "code": "deg" } - } - ] - } - ] - }, - "encoding": { - "type": "TextEncoding", - "tokenSeparator": ",", - "blockSeparator": "\n", - "decimalSeparator": "." - } -} - - -When provided inline, “DataStream” values are encoded using the method defined in . - - - -Inline Value Blocks -This clause specifies how inline vaues for “DataArray”, “Matrix” and “DataStream” components shall be encoded when provided within a JSON document. No other method is allowed within a JSON document compliant with this standard. - -However, when values are provided separately from the component description (e.g. when datastream values are provided separately), any encoding methods defined in can be used. - -Inline block component values shall always be wrapped using JSON Arrays. - - - - -Requirements Class: Geometry Components JSON Schema - -Geometry Components JSON Schema /req/json-geom-componentsJSON Document/req/uml-geom-components/req/json-simple-components - - - - -Geometry Object -The “Geometry” object is the XML schema implementation of the “Geometry” UML class defined in . The schema for this class is provided in Geometry.json. - -{ - "type": "Geometry", - "definition": "http://sensorml.com/ont/swe/property/TargetLocation", - "srs": "http://www.opengis.net/def/crs/EPSG/0/4326", - "label": "Target Location", - "description": "A point geometry", - "value": { - "type": "Point", - "coordinates": [12.34, 56.36] - } -} - -{ - "type": "Geometry", - "definition": "http://sensorml.com/ont/swe/property/Trajectory", - "srs": "http://www.opengis.net/def/crs/EPSG/0/4326", - "label": "Desired Trajectory", - "description": "Desired UxS trajectory defined as a line string", - "value": { - "type": "LineString", - "coordinates": [[12.34, 56.36], [12.45, 56.37], [12.45, 56.39], [12.34, 56.36]] - } -} - -{ - "type": "Geometry", - "definition": "http://sensorml.com/ont/x-swe/property/SurveillanceArea", - "srs": "http://www.opengis.net/def/crs/EPSG/0/4326", - "label": "Surveillance Area", - "description": "Desired UxS surveillance area defined as a polygon", - "value": { - "type": "Polygon", - "coordinates": [ - [[12.34, 56.36], [12.45, 56.37], [12.45, 56.39], [12.34, 56.36]] - ] - } -} - - - - - -Requirements Class: Simple Encodings JSON Schema - -Simple Encodings JSON Schema /req/json-simple-encodingsJSON Document/req/json-simple-encodings/req/text-encoding-rules/req/json-encoding-rules - - - -Validation patterns that implement classes defined respectively in the “Simple Encodings” UML packages are provided in the JSON schema encodings.json. - -When datastream or data array values are provided out-of-band (i.e. not inline in the “DataArray”, “Matrix” or “DataStream” description), a different encoding than JSON can be selected. This is specified by using one of the following classes. - - -TextEncoding Object -The “TextEncoding” object is the JSON schema implementation of the “TextEncoding” UML class defined in . The schema for this class is provided in encodings.json#/definitions/TextEncoding. - -{ - "type": "TextEncoding", - "tokenSeparator": ",", - "blockSeparator": "\n", - "decimalSeparator": "." -} - - - - - -Requirements Class: Advanced Encodings JSON Schema - -Advanced Encodings JSON Schema /req/json-advanced-encodingsJSON Document/req/uml-advanced-encodings/req/json-simple-encodings/req/binary-encoding-rules - - - -This requirement class defines an additional encoding method that can be used to encode data values as raw or base64 binary blocks. - - -BinaryEncoding Object -The “BinaryEncoding” object is the JSON schema implementation of the “BinaryEncoding” UML class defined in . The schema for this class is provided in encondings.json#/definitions/BinaryEncoding. - - - -These elements allow for the detailed specification of the encoding parameters associated to components of the data description tree as discussed in . The “ref” attribute takes a value of a particular syntax that allows pointing to any data component. The syntax is a ‘/’ separated list of component names, starting with the name of the root component and listed hierarchically. Each of these component names shall match the value of the “name” attribute defined in the data definition tree. - - /req/xsd-advanced-encodings/ref-syntax-valid - -The “ref” attribute of the “Component” and “Block” elements shall contain a hierarchical ‘/’ separated list of data component names. - - -The “ref” attribute used on the “Component” element shall point exclusively to a scalar component. - - /req/xsd-advanced-encodings/scalar-ref-component-valid - -The “ref” attribute of a “Component” element shall reference a scalar or range component. - - -This standard defines the list of data types that are allowed for scalar values when encoded with the binary encoding method. The corresponding URIs listed below shall be used as the value of the datatype attribute of an instance of the “Component” element. - - /req/xsd-advanced-encodings/datatype-valid - -The value of the “dataType” XML attribute of the “Component” element shall be one of the URIs listed in . - - -These data types are specified in the normative table below: - - -Allowed Binary Data Types -Common Name -URI to use in “dataType” attribute -Description -Signed Byte - -8-bits signed binary integer. - Range: −128 to +127 -Unsigned Byte - -8-bits unsigned binary integer. - Range: 0 to +255 -Signed Short - -16-bits signed binary integer. - Range: −32,768 to +32,767 -Unsigned Short - -16-bits unsigned binary integer. - Range: 0 to +65,535 -Signed Int - -32-bits signed binary integer. - Range: −2,147,483,648 to +2,147,483,647 -Unsigned Int - -32-bits unsigned binary integer. - Range: 0 to +4,294,967,295 -Signed Long - -64-bits signed binary integer. - Range: −263 to +263 — 1 -Unsigned Long - -64-bits unsigned binary integer. - Range: 0 to +264 — 1 -Half Precision - Float - -16-bits single precision floating point number as defined in IEEE 754. -Float - -32-bits single precision floating point number as defined in IEEE 754. -Double - or - -64-bits double precision floating point number as defined in IEEE 754. -Long Double - -128-bits quadruple precision floating point number as defined in IEEE 754. -UTF-8 String - (Variable Length) - - “byteLength” attribute is not set. -Variable length string composed of a 2-bytes unsigned short value indicating its length followed by a sequence of UTF-8 encoded characters as specified by the Unicode Standard (2.5). -UTF-8 String* - (Fixed Length) - - “byteLength” attribute is set. -Fixed length string composed of a sequence of UTF-8 encoded characters as specified by the Unicode Standard (2.5), and padded with 0 characters. - - - -The data type should be chosen so that its range allows the encoding of all possible values for a field (i.e. compatible with the field representation and constraints) including NIL values. This means that certain combinations of data type and components are not allowed. If a scalar component does not specify any constraint, any data type compatible with its representation can be used and it is the responsibility of the implementation to insure that all future values for the component will “fit” in the data type. - - /req/xsd-advanced-encodings/datatype-compatible - -The chosen data type shall be compatible with the scalar component representation, constraints and NIL values. - - -Only data types marked with an asterisk allow the usage of the “byteLength” or “bitLength” attribute to customize their size. Usage of these attributes is forbidden on all other data types since their size is fixed and already specified in this standard (in the case of a variable length string, the size is included in the stream). This is enforced by a Schematron pattern. - - /req/xsd-advanced-encodings/no-datatype-length - -The “bitLength” and “byteLength” XML attributes shall not be set when a fixed size data type is used. - - -The value of the “byteEncoding” XML attribute allows the selection of either the ‘raw’ or ‘base64’ encoding methods. When ‘base64’ is selected each byte is converted to its base 64 representation before it is included in encoded block, making it possible to include the values directly inline in the XML instance. - -The following binary encoded image data illustrates how the BinaryEncoding element is used to specify encoding options to each scalar value in the dataset: - - - - - -Data Blocks and Streams Encoding Rules (normative) - -Requirements Class: General Encoding Rules - -General Encoding Rules/req/general-encoding-rulesEncoded Values Instanceindirect-dependency/req/uml-simple-encodings - - - -All encodings defined in this standard follow general principles so that it is possible to implement them in a similar way. - -The way values are encoded is linked to the data structure specified using a hierarchy of data components. The values are included sequentially in the data stream by recursively processing all data components composing the dataset definition tree. - - -Rules for Scalar Components -The value of each scalar component is encoded as a single scalar value. The actual binary representation of this scalar value depends on the encoding method. For example, in “TextEncoding”, a numerical value is represented by its string representation that usually span several bytes (e.g. ‘1.2345’ spans 6 bytes), why with the “BinaryEncoding” encode a similar value would likely be encoded as an IEEE 754 single precision floating-point format. - -The value of a “Time” component is encoded either as a decimal value or as a string in the case where a calendar representation or indeterminate value is used. - -When the value of a scalar component is NIL, the appropriate nil value is used in the stream and replaces the actual measurement value. This is always possible because nil values are required to be expressed with a data type that is compatible with the representation of the corresponding field. - - - -Rules for Range Components -The values of range components are encoded as a sequence of two successive values, first the lower bound of the range, then the upper bound. Each of these values is encoded exactly like the values of scalar components. - - - -Rules for DataRecord and Vector -Both “DataRecord” and “Vector” components are aggregates consisting of an ordered sequence of child components. The values contained in these aggregates are encoded by successively encoding each child component in the order in which they are listed in the XML description and including the resulting values sequentially in the stream. - -The definition of a “DataRecord” (or “Vector”) structure composed of N fields (or coordinates for vectors) can be represented in the following way: - - - -The data block corresponding to such a structure would sequentially include all values for field 1, then all values for field 2, etc. until the last field is reached. Each field may consist of a single value if it is a scalar but may also consist of multiple values if it is itself an aggregate or a range component. - - /req/general-encoding-rules/record-encoding-rule - -“DataRecord” fields or “Vector” coordinates shall be encoded sequentially in a data block in the order in which these fields or coordinates are listed in the data descriptor. - - - - -Rules for DataChoice -The “DataChoice” is an aggregate consisting of a choice of several child components called items. When values of a data choice are encoded, the resulting data block consists of two things: A token identifying the selecting item and the item values themselves. Only values of a single item can be encoded in each instance of a choice. - - - -The data block corresponding to such a structure would then sequentially include the item identifier (i.e. the choice value) and then the value(s) for the selected item. The item may consist of a single value if it is a scalar or multiple values if it is itself an aggregate or a range component. - - /req/general-encoding-rules/choice-encoding-rule - -Encoded values for the selected item of a “DataChoice” shall be provided along with information that unambiguously identifies the selected item. - - - - -Rules for DataArray and Matrix -The “DataArray” is an aggregate consisting of a number of repeated elements, all of the same type as defined by the element type. Values contained by a “DataArray” are encoded by sequentially including the values of each element. - -The definition of a “DataArray” (“Matrix”) structure composed of the array dimension and size and the element type definition. This can be represented in the following way: - - - -The data block corresponding to such a structure would sequentially include the number representing the array size (only if it is variable) followed by one or more values corresponding to each array element. The number of values encoded for each element depends only on the array element definition, and the total number of values also depends on the array size. - - /req/general-encoding-rules/array-encoding-rule - -“DataArray” elements shall be encoded sequentially in a data block in the order of their index in the array (i.e. from low to high index). - - - /req/general-encoding-rules/array-size-encoding-rule - -Encoded data for a variable size “DataArray” shall include a number specifying the array size whatever the encoding method used. - - - - - -Requirements Class: JSON Encoding Rules - -JSON Encoding Rules/req/json-encoding-rulesEncoded Values Instance/req/general-encoding-rulesindirect-dependency/req/uml-simple-encodings - - - -The “JSON Encoding” method encodes field values by their JSON representation. - - /req/json-encodings-rules/json-valid - -Data blocks and datastreams encoded using the JSON Encoding rules shall be valid JSON documents as defined by . - - -The encoding rules defined in this document refer to JSON data types defined by . Their definitions are recalled below: - -JSON Object: An object structure is represented as a pair of curly brackets surrounding zero or more name/value pairs (or members). Members are separated by commas. Each member must have a distinct name. - -JSON Array: An array structure is represented as square brackets surrounding zero or more values (or elements). Elements are separated by commas. - -JSON Number: A decimal or integer number represented in base 10, with a sign and optional exponent. - -JSON String: A string of Unicode characters that begins and ends with quotation marks. - - -Rules for Scalar Components -Scalar components are encoded as specified in . Special numerical values allowed for “Quantity” and “Time” components are defined in . - - /req/json-encoding-rules/scalar-value-valid - -The value of a scalar component shall be represented using a JSON Number, a JSON String, or a boolean literal value, as defined in . - - - -Simple Component to JSON Value Types Mapping -Component Type -JSON Value Type -Examples - -Boolean -Boolean literal -true - false -Text -JSON String -"word" - "a full sentence" - "BYC-589-AA" -Category -JSON String -"ON" - "Paleozoic" - "diesel" -Count -JSON Number -12 - 0 -Quantity -JSON Number, or - JSON String with special numerical value. -12 - 23.1 - "NaN" - "-Infinity" - "+Infinity" -Time -JSON String with a ISO8601 date/time string, or - JSON Number, or - JSON String with special numerical value. -"2023-03-15T12:45:56Z" - -23.1 - 12 - "NaN" - "-Infinity" - "+Infinity" - - - - - -Rules for Range Components -A range component is encoded using a JSON array of two values. - - /req/json-encoding-rules/range-value-validValues of range components shall be wrapped in a JSON Array with exactly 2 scalar values. -Each value is encoded in the same manner as the corresponding scalar component as defined in . - - - - -Range Component to JSON Mapping -Component Type -Examples - -CategoryRange -["Cenozoic", "Paleozoic"] -CountRange -[0, 12] -QuantityRange -[-12, 35] - [-180.0, 180.0] - ["-Infinity", 0.0] - [10.0, "+Infinity"] - ["NaN", "NaN"] -TimeRange -["2023-01-01T00:00:00Z", "2023-03-15T12:45:56Z"] - ["2023-01-01T00:00:00Z", "+Infinity"] - ["-Infinity", "2023-01-01T00:00:00Z"] - ["2023-01-01T00:00:00Z", "+Infinity"] - ["NaN", "NaN"] - - - - - -Rules for DataRecord and Vector -“DataRecord” components are encoded using a JSON Object whose members are named like the record fields. - - /req/json-encoding-rules/record-object-valid“DataRecord” values shall be wrapped in a JSON Object. -The name of the JSON object members shall be the same as the “DataRecord” field names. -The value of each JSON Object member shall be chosen by following the encoding rules of the data component used as the record field with the same name. -If a record field is marked as ‘optional’, the corresponding JSON object member can be omitted or its JSON value can be set to null. - - - - /req/json-encoding-rules/vector-object-valid“Vector” values shall be wrapped in a JSON Object. -The name of the JSON object members shall be the same as the “Vector” coordinate names. -The value of each JSON Object member shall be chosen by following the encoding rules of the data component used as the vector coordinate field with the same name. - - - -When a field has its ‘optional’ flag set to true, its value can be either omitted or set to the literal value null. - -See the following examples: - - - - - - - - - - - -Rules for DataChoice -Values of “DataChoice” components are encoded using a JSON Object with a single member whose name is the name of the selected choice item. - - /req/json-encoding-rules/choice-object-valid“DataChoice” values shall be encapsulated in a JSON Object. -The JSON object shall contain a single member whose name is the same as the selected choice item. -The JSON value of this unique member shall be chosen according to the encoding rules of the data component corresponding to the selected item. - - - -See example: - - - -Rules for DataArray and Matrix -Values of “DataArray” and “Matrix” components are encoded using a JSON Array, containing as many elements as there are elements in the Array component. - - /req/json-encoding-rules/array-values-valid“DataArray” and “Matrix” values shall be encapsulated in a JSON Array. -Each array element shall be encoded using the rules corresponding to the data component used as the array element type. - - - -See the following examples: - - - - - - - - - -Rules for Geometry -The value of a “Geometry” component is encoded using a GeoJSON Geometry object. - - /req/json-encodings-rules/geometry-validThe value of a “Geometry” component shall be encoded as a GeoJSON Geometry Object, following rules defined by . -The allowed GeoJSON geometry types shall be restricted to: Point, LineString, Polygon, MultiPoint, MultiLineString, and MultiPolygon -The number of dimensions of the GeoJSON geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component. - - - -See example: - - - -JSON Schema -In order to maximize compatibility with existing tools, A JSON Schema can be easily auto-generated from the Datastream description. - - - -Media Types -When array or datastream values are encoded with the JSON encoding method and provided standalone (i.e. outside of any wrapper format), one of the following media type identifiers shall be used: - -One of application/json or application/swe+json shall be used as the content-type for files and HTTP reponses. - -application/swe+json shall be used for format negotiation between server and client (e.g. when the format is advertised by an API or web service). In particular, this media type shall be used in HTTP Accept and Link headers and in any server response used to advertise support or link to a resource encoded with this format. - - - -alternative would be application/vnd.ogc.swe+json - - - - -Requirements Class: Text Encoding Rules - -Text Encoding Rules/req/text-encoding-rulesEncoded Values Instance/req/general-encoding-rulesindirect-dependency/req/uml-simple-encodings - - - -The “TextEncoding” method encodes field values (especially numbers) by their text representation. Special characters provide a way to separate successive values and successive blocks. The ABNF syntax defined in IETF RFC 5234 is used to formalize the encoding rules, and thus all ABNF snippets provided in this section are normative. - - /req/text-encodings-rules/abnf-syntax-valid - -The encoded values block shall be formatted as defined by the ABNF grammar defined in this clause. - - - -Separators -Token separators are used between single values and the block separator is used at the end of each block. The block corresponds to one element of the “DataArray” or “DataStream” carrying the “values” element in which the values are encoded. There are no special separators to delimitate nested records, arrays and choices. - -Separators shall be chosen so that nothing in the dataset contains the exact same character sequence as the one chosen for token or block separator. - - /req/text-encodings-rules/separators-valid - -Block and token separators used in the “TextEncoding” method shall be chosen as a sequence of characters that never occur in the data values themselves. - - -When the attribute “collapseWhiteSpaces” is set to true (its default value), all white space characters surrounding the token and block separators shall be ignored. The BNF grammar for separators is given below: - -white-space = %d9 / %d10 / %d13 / %d32 ; TAB, LF, CR or SPACE - -token-separator-chars = < Value of the tokenSeparator attribute > - -block-separator-chars = < Value of the blockSeparator attribute > - -token-separator = [white-space] token-separator-chars [white-space] - -block-separator = [white-space] block-separator-chars [white-space] - - -White spaces around separators are in fact only allowed when the “collapseWhiteSpaces” attribute is set to ‘true’ (which is the default). - - - -Rules for Scalar Components -The value for a scalar component is encoded as its text representation, following XML schema datatypes conventions. - -scalar-value = xs:bool / xs:string / xs:double / xs:int / xs:date / xs:dateTime - - -Nil values are included in the stream just like normal scalar values. Since their data type has to match the field data type, there is no special treatment necessary for a decoder or encoder. It is the responsibility of the application to match the data value against the list of registered nil values for a given field in order to detect if it is associated to a nil reason or if it is an actual measurement value. - - - -Rules for Range Components -Range components are encoded as a sequence of two tokens (each one representing a scalar value) separated by a token separator: - -min-value = scalar-value - -max-value = scalar-value - -range-values = min-value token-separator max-value - - - - -Rules for DataRecord and Vector -Values of fields of a “DataRecord” are recursively encoded following rules associated to the type of component used for the field’s description (i.e. scalar, record, array, etc.) and separated by token separators as expressed by the following grammar: - -field-count = < Number of fields in the record minus one. Greater or equal to 0 > - -any-field-value = scalar-value / range-values / record-values / choice-values / array-values - -mandatory-field-value = any-field-value - -optional-field-value = (“Y” token-separator any-field-value) / “N” - -field-value = mandatory-field-value / optional-field-value - -record-values = field-value <field-count>*(token-separator field-value) - - -When a field is marked as optional in the definition, the token ‘Y’ or ‘N’ shall be inserted in the data block. When the field value is omitted, the token ‘N’ is inserted alone. When it is included, the token ‘Y’ is inserted followed by the actual field value. - - /req/text-encodings-rules/optional-field-marker-present - -The ‘Y’ or ‘N’ token shall be inserted in a text encoded data block for all fields that have the “optional” attribute set to ‘true’. - - -Coordinate values of “Vector” components are encoded with a similar syntax, but a coordinate value can only be scalar and cannot be omitted: - -coord-count = < Number of coordinates in the vector minus one. Greater or equal to 0 > - -vector-values = scalar-value <coord-count>*(token-separator scalar-value) - - -See the following examples: - - - - - - - - - - - -Rules for DataChoice -A “DataChoice” is encoded with the text method by providing the name of the selected item before the item values themselves. The name used shall correspond to the “name” attribute of the “item” property element that describes the structure of the selected item. - -selected-item-name = < Value of the “name” attribute of the item selected > -selected-item-values = scalar-value / range-values / record-values / choice-values / array-values -choice-values = selected-item-name token-separator selected-item-values - - - /req/text-encodings-rules/choice-selection-marker-valid - -The selected-item-name token shall correspond to the value of the “name” attribute of the “item” property element that represents the selected item. - - -See example: . - - - -Rules for DataArray and Matrix -Values of each “DataArray” or “Matrix” element are recursively encoded following rules associated to the type of component used for the element type (i.e. scalar, record, array, etc.). Groups of values (or single value in the case of a scalar element type) corresponding to each element are sequentially appended to the data block and separated by token or block separators, depending on the context: When the “DataArray” is the root of the component tree that is being encoded, its elements are separated by block separators, otherwise its elements are separated by token separators. - -A “DataArray” or “Matrix” can have a fixed or variable size, which leads to two slightly different syntaxes for encoding values: -array-separator = token-separator / block-separator ; block-separator is only used when the array is the root of the component tree whose values are being encoded. - -array-values = fixed-size-array-values / variable-size-array-values - - -Fixed size arrays have a size of at least one, and are encoded as defined below: - -fixed-element-count = < Number of elements in a fixed size array minus one. Greater or equal to 0 since fixed size is always at least one > - -element-values = scalar-value / range-values / record-values / choice-values / array-values - -fixed-size-array-values = element-values <fixed-element-count>*(array-separator element-values) - - -When a “DataArray” (“Matrix”) is defined as variable size, its size can be 0 and the array size is included as a token in the data block, before the actual array elements values are listed: - -variable-element-count = < Number of elements in a variable size array. Greater or equal to 0 since variable size can be 0 for an empty array > - -variable-size-array-values = variable-element-count <variable-element-count>*(array-separator element-values) - - -See the following examples: - - - - - - - - - - - -Rules for DataStream -Values of “DataStream” elements are encoded as a sequence of tokens in a way similar to how “DataArray” values are encoded. Groups of encoded values corresponding to one element of a “DataStream” are always separated by block separators, while all values within these groups are separated by token separators: - -stream-element-count = < Number of elements in a data stream minus one. Greater or equal to 0 since the number of elements in a data stream is always at least one > - -stream-values = element-values <stream-element-count>*(block-separator element-values); - - -Examples of “DataStream” with “TextEncoding” have already been given in previous sections. - - - -Rules for Geometry -The value of a “Geometry” component is encoded using the WKT format defined in the Simple Feature Access Standard (). - - /req/text-encodings-rules/geometry-validThe value of a “Geometry” component shall be encoded using the WKT format defined in , clause 7. -The WKT representation shall be either a “Two-Dimension Geometry WKT” (clause 7.2.2 of ) or a “Three-Dimension Geometry WKT” (clause 7.2.3 of ). The ‘M’ coordinate shall not be used. -The number of dimensions of the WKT geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component. -When a geometry value is included in a text-encoded datastream, the token separator shall not be the comma character (ASCII code 44) to avoid conflicting with commas used inside the WKT representation. - - - -See example: - - - -Media Types -When array or datastream values are encoded with the Text encoding method and provided standalone (i.e. outside of any wrapper format such as an XML document), one of the following media type identifiers shall be used: - -One of text/plain, text/csv, or application/swe+text shall be used as the content-type for files and HTTP reponses. -text/csv can be used only when the token separator is set to a single comma ‘,’ and the block separator is set to ‘CRLF’. - -text/plain and application/swe+text can be used for any combination of separators. - - - -application/swe+text shall be used for format negotiation between server and client (e.g. when the format is advertised by an API or web service). In particular, this media type shall be used in HTTP Accept and Link headers and in any server response used to advertise support or link to a resource encoded with this format. - -It is recommended that the character set code be correctly appended to these media types if it differs from US-ASCII or UTF-8. - - - - -alternative would be application/vnd.ogc.swe+text - - - - -Requirements Class: Binary Encoding Rules - -Binary Encoding Rules/req/binary-encoding-rulesEncoded Values Instance/req/general-encoding-rulesindirect-dependency/req/uml-advanced-encodings - - - -The “BinaryEncoding” method encodes field values by their binary representation. The ABNF syntax defined in IETF RFC 5234 is used to formalize the encoding rules, and thus all ABNF snippets provided in this section are normative. - - /req/binary-encoding-rules/abnf-syntax-valid - -The encoded values block shall be formatted as defined by the ABNF grammar defined in this clause. - - -The encoding rules are similar to those of the “TextEncoding” method except that numerical values are encoded directly as their binary representation and that no separators are used. Separators are not needed because data types have either a fixed size or contain length information (See String encoding). - - -Rules for Scalar Components -The value for a scalar component is encoded as its binary representation. This especially applies to numerical values that are encoded directly in binary form in accordance to the selected data type and the value of the “byteOrder” attribute. - -scalar-value = < binary value encoded according to data type, byte encoding and byte order specifications > - - -The last column of in indicates how each data type shall be binary encoded into a low level byte sequence. The actual order of bytes composing a multi-bytes data type depends on the value of the “byteOrder” attribute. The ‘bigEndian’ option indicates that muti-bytes data types are encoded with the most significant byte (MSB) first, while selecting ‘littleEndian’ signifies that encoding is done with the less significant byte (LSB) first. A UTF-8 string is not considered as a multi-byte data type and is always encoded in the same order, as specified by the Unicode Standard. - - /req/binary-encoding-rules/type-encoding-valid - -Binary data types in shall be encoded according to their definition in the description column and the value of the “byteOrder” attribute. - - -Nil values are included in the stream just like normal scalar values. Since their data type has to match the field data type, there is no special treatment necessary for a decoder or encoder. It is the responsibility of the application to match the data value against the list of registered nil values for a given field in order to detect if it is associated to a nil reason or if it is an actual measurement value. - -When the ‘raw’ byte encoding option is selected, bytes resulting from the data type encoding process defined above are inserted in the binary stream directly. This is refered to as ‘raw binary’ encoding. When the ‘base64’ option is selected, each byte resulting from the binary encoding process is also encoded in Base64 before being included in the stream. Scalar values can be Base 64 encoded one by one or by blocks as long as the resulting stream is compatible with requirements of IETF RFC 2045. - - /req/binary-encoding-rules/base64-translation-applied - -When the ‘base64’ encoding option is selected, binary data shall be encoded with the Base64 technique defined in IETF RFC 2045 Section 6.8: Base64 Content-Transfer-Encoding. - - - - -Rules for Range Components -Range components are encoded as a sequence of two binary values (each one representing a scalar value): - -min-value = scalar-value - -max-value = scalar-value - -range-values = min-value max-value - - -Values are always included in the same order: The lower bound of the range first, followed by the upper bound. - - - -Rules for DataRecord and Vector -Values of fields of a “DataRecord” are recursively encoded following rules associated to the type of component used as the field’s description (i.e. scalar, record, array, etc.) and appended to the binary block: - -field-count = < Number of fields in the record. Greater or equal to 1 > - -any-field-value = scalar-value / range-values / record-values / choice-values / array-values / block_values - -mandatory-field-value = any-field-value - -optional-field-value = (“Y” any-field-value) / “N” - -field-value = mandatory-field-value / optional-field-value - -record-values = <field-count>*field-values - - -When a field is marked as optional in the definition, the 1-byte value ‘Y’ (ASCII code 89) or ‘N’ (ASCII code 78) shall be inserted in the data block. When the field value is omitted, the token ‘N’ is inserted alone. When it is included, the token ‘Y’ is inserted followed by the actual field value. - - /req/binary-encoding-rules/optional-field-marker-present - -The one byte ASCII character ‘Y’ or ‘N’ shall be inserted in a binary encoded data block for all “DataRecord” fields that have the “optional” attribute set to ‘true’. - - -Coordinate values of “Vector” components are encoded with a similar syntax, but a coordinate value can only be scalar and cannot be omitted: - -coord-count = < Number of coordinates in the vector. Greater or equal to 1 > - -vector-values = <coord-count>*scalar-value - - -Vector coordinates cannot be optional. - - - -Rules for DataChoice -A “DataChoice” is encoded with the binary method by providing the zero-based index of the selected item before the item values themselves. The index value ranges from 0 for the first choice item to (number_of_items - 1) for the last item. - -selected-item-idx = < Index of the item selected > - -selected-item-value = scalar-value / range-values / record-values / choice-values / array-values - -choice-values = selected-item-idx selected-item-value - - - /req/binary-encoding-rules/choice-selection-marker-valid - -The value of the selected-item-idx flag shall be the zero-based index of the selected item (within the ordered list of items provided by the choice descriptor) and be encoded on a single unsigned byte. - - - - -Rules for DataArray and Matrix -Values of each “DataArray” or “Matrix” element are recursively encoded following rules associated to the type of component used for the element type (i.e. scalar, record, array, etc.). Groups of values (or single value in the case of a scalar element type) corresponding to each element are sequentially appended to the data block. Since a “DataArray” or “Matrix” can have a fixed or variable size, two slightly different syntaxes for encoding values are possible: - -array-values = fixed-size-array-values / variable-size-array-values - -element-value = scalar-value / range-values / record-values / choice-values / array-values / block_values - - -Fixed size arrays have a size of at least one, and are encoded as defined below: - -fixed-element-count = < Number of elements in a fixed size array > - -fixed-size-array-values = <fixed-element-count>*element-value - - -When a “DataArray” (“Matrix”) is defined as variable size, its size can be 0 and the array size is included as a token in the data block, before the actual array elements values are listed: - -variable-element-count = < Number of elements in a variable size array > - -variable-size-array-values = variable-element-count <variable-element-count>*element-value - - -When the array size is 0, only this number is encoded and no element values are included in the data block. - - - -Rules for DataStream -Values of “DataStream” elements are encoded exactly as elements of an array: - -stream-element-count = < Number of elements in a data stream > - -stream-values = <stream-element-count>*element-value - - -A data stream usually contains at least one value but could be empty. - - - -Rules for Geometry -The value of “Geometry” is encoded using the WKB format defined in the Simple Feature Access Standard (). - - /req/binary-encodings-rules/geometry-validThe value of a “Geometry” component shall be encoded using the WKB format defined in , clause 8. -The WKB geometry type shall be one of the following types listed in , clause 8.2.3, table 7: Point, LineString, Polygon, MultiPoint, MultiLineString, MultiPolygon, Point Z, LineString Z, Polygon Z, MultiPoint Z, MultiLineString Z, MultiPolygon Z. Other geometry type codes shall not be used. -The number of dimensions of the WKB geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component. - - - -No specific marker or length information needs to be pre-pended to the binary representation since the WKB format is self descriptive and parsable without knowing the total length ahead of time. - - - -Block encoded components -When block encoding characteristics are also specified in the encoding description, the encryption and/or compression algorithm shall be applied after the binary encoding process described above is completed for the block. Extensions of this standard can define compression and encryption methods that fit the needs of particular communities. - -In order to maximize compatibility with existing software, when compressing a binary encoded data stream results in a well known binary format, the corresponding mime type can be used instead of application/octet-stream. For instance video/h264 can be used when the entirety of the dataset (presumably a video stream) is compressed using the H264 video codec. - - - -Media Types -When array or stream values are encoded with the Binary encoding method and provided standalone (i.e. outside of any wrapper format), one of the following media type identifiers shall be used: - -One of application/octet-stream or application/swe-binary shall be used as the content-type for files and HTTP responses. - -application/swe+binary shall be used for format negotiation between server and client (e.g. when the format is advertised by an API or web service). In particular, this media type shall be used in HTTP Accept and Link headers and in any server response used to advertise support or link to a resource encoded with this format. - - - -alternative would be application/vnd.ogc.swe-binary - - - - - - - - - - - - - - -Conformance Class Abstract Test Suite - -Core Conformance Classes - -Conformance Class: Core Concepts - /conf/coreTarget TypeDerived Models and Software Implementationstarget/req/core - - - -Core concepts are the base of all derived models/conf/core/core-concepts-usedtarget/req/core/core-concepts-usedVerify that the target implementation correctly implements the core concepts. - - - -Inspect the target implementation. - - - - -A boolean representation consists of a boolean value/conf/core/boolean-rep-validtarget/req/core/boolean-rep-validVerify that the target implementation correctly implements the Boolean representation. - - - -Inspect the target implementation. - - - - -A categorical representation consists of a token with a code space/conf/core/categorical-rep-validtarget/req/core/categorical-rep-validVerify that the target implementation correctly implements the Categorical representation. - - - -Inspect the target implementation. - - - - -A continuous numerical representation consists of a number with a scale/conf/core/numerical-rep-validtarget/req/core/numerical-rep-validVerify that the target implementation correctly implements the Numerical representation. - - - -Inspect the target implementation. - - - - -A countable representation consists of an integer number/conf/core/countable-rep-validtarget/req/core/countable-rep-validVerify that the target implementation correctly implements the Countable representation. - - - -Inspect the target implementation. - - - - -A textual representation is implemented as a character string/conf/core/textual-rep-validtarget/req/core/textual-rep-validVerify that the target implementation correctly implements the Textual representation. - - - -Inspect the target implementation. - - - - -A semantic definition of each property shall be provided/conf/core/semantics-definedtarget/req/core/semantics-definedVerify that the target implementation allows attaching a semantic definition to all property representations. - - - -Inspect the target implementation. - - - - -References to semantical information shall be resolvable/conf/core/semantics-resolvabletarget/req/core/semantics-resolvableVerify that the target implementation encodes the semantic links in a way that they can be resolved to an actual concept definition. - - - -Inspect the target implementation. - - - - -A temporal quantity is associated to a temporal reference frame/conf/core/temporal-frame-definedtarget/req/core/temporal-frame-definedVerify that the target implementation allows providing a temporal reference frame along with any date/time quantity. - - - -Inspect the target implementation. - - - - -A spatial quantity is associated to an axis of a spatial reference frame/conf/core/spatial-frame-definedtarget/req/core/spatial-frame-definedVerify that the target implementation allows providing a spatial reference frame and axis along with any quantity that is projected along a spatial dimension. - - - -Inspect the target implementation. - - - - -A NIL value maps a reserved value to a reason/conf/core/nil-reasons-definedtarget/req/core/nil-reasons-definedVerify that the target implementation allows providing a reason along with each NIL (reserved) value. - - - -Inspect the target implementation. - - - - -Aggregate data types are modeled according to ISO 11404/conf/core/aggregates-model-validtarget/req/core/aggregates-model-validVerify that the target implementation models aggregate data types according to ISO 11404 definitions. - - - -Inspect the target implementation. - - - - -Encoding methods shall be defined for all possible data structures/conf/core/encoding-method-validtarget/req/core/encoding-method-validVerify that the target implementation provides encoding methods for all representations and all implemented data structures. - - - -Inspect the target implementation. - - - - - - -UML Conformance Classes - -Conformance Class: Basic Types and Simple Components UML Packages - -Basic Types and Simple Components UML Packages/conf/uml-simple-components/conf/coreTarget TypeDerived Models and Software Implementationstarget/req/uml-simple-components - - - - -Compliance with UML models defined in this package/conf/uml-simple-components/package-fully-implementedtarget/req/uml-simple-components/package-fully-implementedVerify that the target implements all classes in the UML package. - - - -Inspect the model or software implementation. - - - - -Compliance with UML models defined in ISO 19103/conf/uml-simple-components/iso19103-implementedtarget/req/uml-simple-components/iso19103-implementedVerify that the target implements all classes imported from ISO 19103 UML packages. - - - -Inspect the model or software implementation. - - - - -Compliance with UML models defined in ISO 19108/conf/uml-simple-components/iso19108-implementedtarget/req/uml-simple-components/iso19108-implementedVerify that the target implements all classes imported from ISO 19108 UML packages. - - - -Inspect the model or software implementation. - - - - -A definition URI is mandatory on all simple components/conf/uml-simple-components/definition-presenttarget/req/uml-simple-components/definition-presentVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -The value of the axisID and axisAbbrev attributes match/conf/uml-simple-components/axis-validtarget/req/uml-simple-components/axis-validVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -The axis ID is always specified on scalar spatial properties/conf/uml-simple-components/axis-definedtarget/req/uml-simple-components/axis-definedVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -The reference frame is specified on scalar spatial properties not part of a vector/conf/uml-simple-components/ref-frame-definedtarget/req/uml-simple-components/ref-frame-definedVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -The value of a component satisfies the constraints/conf/uml-simple-components/value-constraint-validtarget/req/uml-simple-components/value-constraint-validVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -All derived simple components have an optional value attribute/conf/uml-simple-components/value-attribute-presenttarget/req/uml-simple-components/value-attribute-presentVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -The list of values allowed in a Category component is a subset of the code space/conf/uml-simple-components/category-constraint-validtarget/req/uml-simple-components/category-constraint-validVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -A Category component always specifies a list of possible values/conf/uml-simple-components/category-enum-definedtarget/req/uml-simple-components/category-enum-definedVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -The value of a Category component is one defined in the code space/conf/uml-simple-components/category-value-validtarget/req/uml-simple-components/category-value-validVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -The temporal reference frame is defined/conf/uml-simple-components/time-ref-frame-definedtarget/req/uml-simple-components/time-ref-frame-definedVerify that the implementation correctly assumes the default value when the attribute is not set. - - - -Inspect the model or software implementation. - - - - -The time of reference is expressed relative to the origin of the reference frame/conf/uml-simple-components/time-ref-time-validtarget/req/uml-simple-components/time-ref-time-validVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -The local and reference frames of a Time component are different/conf/uml-simple-components/time-local-frame-validtarget/req/uml-simple-components/time-local-frame-validVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -Values of range components satisfy the same requirements as scalar values/conf/uml-simple-components/range-value-validtarget/req/uml-simple-components/range-value-validVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -CategoryRange components satisfy all requirements of a Category component/conf/uml-simple-components/category-range-validtarget/req/uml-simple-components/category-range-validVerify that the target implementation has constraints that enforce the requirement. - - - -Inspect the model or software implementation. -Apply the following conformance tests to the “CategoryRange” class: - - - - - - - - - - - - -The code space of a CategoryRange component is well-ordered/conf/uml-simple-components/category-range-codespace-ordertarget/req/uml-simple-components/category-range-codespace-orderVerify that the code space contains elements that have a specific order (either implied or defined). - - - -Inspect instances generated by the implementation of the “CategoryRange” class, including a codepace, to verify the requirement. - - - - -TimeRange components satisfy all requirements of the Time class/conf/uml-simple-components/time-range-validtarget/req/uml-simple-components/time-range-validVerify that the target implementation has constraints that enforce the requirement. - - - -Inspect the model or software implementation. -Apply the following conformance tests to the “TimeRange” class: - - - - - - - - - - - - -The reason attribute is a URI that is resolvable to a definition/conf/uml-simple-components/nil-reason-resolvabletarget/req/uml-simple-components/nil-reason-resolvableVerify that the target implementation allows the value of a NIL reason identifier to be either: -a well known reason code defined by OGC - -a URI that can be resolved to the textual description of a custom reason. - - - - - -Inspect the model or software implementation. - - - - -Values reserved for NIL reasons are compatible with the component data type/conf/uml-simple-components/nil-value-type-coherenttarget/req/uml-simple-components/nil-value-type-coherentVerify that the target implementation has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -The scale of constraints is the same as the scale of the component value/conf/uml-simple-components/allowed-values-unit-coherenttarget/req/uml-simple-components/allowed-values-unit-coherentVerify that numerical constraints are expressed with the correct scale. - - - -Inspect instances generated by the implementation of the “Quantity”, “Count” and “Time” classes, including an “AllowedValues” constraint, to verify the requirement. - - - - - -Conformance Class: Record Components UML Package - -Record Components UML Package/conf/uml-record-components/conf/uml-simple-componentsTarget TypeDerived Models and Software Implementationstarget/req/uml-record-components - - - - -Compliance with UML models defined in this package/conf/uml-record-components/package-fully-implementedtarget/req/uml-record-components/package-fully-implementedVerify that the target implements all classes in the UML package. - - - -Inspect the model or software implementation. - - - - -Each DataRecord field has a unique name/conf/uml-record-components/record-field-name-uniquetarget/req/uml-record-components/record-field-name-uniqueVerify that the implementation of the “DataRecord” class has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -Each Vector coordinate has a unique name/conf/uml-record-components/vector-coord-name-uniquetarget/req/uml-record-components/vector-coord-name-uniqueVerify that the implementation of the “Vector” class has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - -The reference frame is not specified on individual coordinates of a Vector/conf/uml-record-components/vector-component-no-ref-frametarget/req/uml-record-components/vector-component-no-ref-frameVerify that the implementation of the “Vector” class has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. -The “referenceFrame” attribute shall be ommited from all data components used to define coordinates of a “Vector” instance. - - - - -The axis ID is specified on all coordinates of a Vector/conf/uml-record-components/vector-component-axis-definedtarget/req/uml-record-components/vector-component-axis-definedVerify that the implementation of the “Vector” class has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. -The “axisID” attribute shall be present on all data components used to define coordinates of a “Vector” instance. - - - - -The local and reference frames of a Vector component are different/conf/uml-record-components/vector-local-frame-validtarget/req/uml-record-components/vector-local-frame-validVerify that the implementation of the “Vector” class has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - - -Conformance Class: Choice Components UML Package - -Choice Components UML Package/conf/uml-choice-components/conf/uml-simple-componentsTarget TypeDerived Models and Software Implementationstarget/req/uml-choice-components - - - - -Compliance with UML models defined in this package/conf/uml-choice-components/package-fully-implementedtarget/req/uml-choice-components/package-fully-implementedVerify that the target implements all classes in the UML package. - - - -Inspect the model or software implementation. - - - - -Each DataChoice item has a unique name/conf/uml-choice-components/choice-item-name-uniquetarget/req/uml-choice-components/choice-item-name-uniqueVerify that the implementation of the “DataChoice” class has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - - -Conformance Class: Block Components UML Package - -Block Components UML Package/conf/uml-block-components/conf/uml-simple-componentsTarget TypeDerived Models and Software Implementationstarget/req/uml-block-components - - - - -Compliance with UML models defined in this package/conf/uml-block-components/package-fully-implementedtarget/req/uml-block-components/package-fully-implementedVerify that the target implements all classes in the UML package. - - - -Inspect the model or software implementation. - - - - -Components nested in a block component are data descriptors/conf/uml-block-components/array-component-no-valuetarget/req/uml-block-components/array-component-no-valueVerify that implementations of the block component classes have a constraint that enforces the requirement. - - - -Inspect the model or software implementation. -Check that the “DataArray”, “Matrix” and “DataStream” classes have the constraint. - - - - -An encoding method is specified whenever an encoded data block is included/conf/uml-block-components/array-values-properly-encodedtarget/req/uml-block-components/array-values-properly-encodedtarget/req/uml-block-components/datastream-array-validVerify that the implementation of block component classes have a constraint that enforces the requirement. - - - -Inspect the model or software implementation. -Check that the “DataArray”, “Matrix” and “DataStream” classes have the constraint. -Inspect instances of these classes generated by the implementation to verify that an encoding method is specified whenever there are encoded values present. - - - - -Elements of a matrix are of scalar types or nested matrices/conf/uml-block-components/matrix-element-type-validtarget/req/uml-block-components/matrix-element-type-validVerify that the implementation of the “Matrix” class has a constraint that enforces the requirement. - - - -Inspect the model or software implementation. - - - - - -Conformance Class: Simple Encodings UML Package - -Simple Encodings UML Package/conf/uml-simple-encodings/conf/coreTarget TypeDerived Models and Software Implementationstarget/req/uml-simple-encodings - - - - -Compliance with UML models defined in this package/conf/uml-simple-encodings/package-fully-implementedtarget/req/uml-simple-encodings/package-fully-implementedVerify that the target implements all classes in the UML package. - - - -Inspect the model or software implementation. - - - - - -Conformance Class: Advanced Encodings UML Package - -Advanced Encodings UML Package/conf/uml-advanced-encodings/conf/uml-simple-encodingsTarget TypeDerived Models and Software Implementationstarget/req/uml-advanced-encodings - - - - -Compliance with UML models defined in this package/conf/uml-advanced-encodings/package-fully-implementedtarget/req/uml-advanced-encodings/package-fully-implementedVerify that the target implements all classes in the UML package. - - - -Inspect the model or software implementation. - - - - - - -Datastream Encoding Conformance Classes - -Conformance Class: General Encoding Rules - -General Encoding Rules/conf/general-encoding-rulesTarget TypeEncoded Values Instancetarget/req/general-encoding-rules - - - - -DataRecord fields and Vector coordinates are encoded recursively/conf/general-encoding-rules/record-encoding-ruletarget/req/general-encoding-rules/record-encoding-rule - - -Verify that the sequence of scalar values (obtained after decoding the section of the encoded data block corresponding to the “DataRecord” or “Vector”) includes values for the successive fields/coordinates in the right order. - - - - -DataChoice selected item is properly encoded/conf/general-encoding-rules/choice-encoding-ruletarget/req/general-encoding-rules/choice-encoding-rule - - -Verify that the sequence of scalar values (obtained after decoding the section of the encoded data block corresponding to the “DataChoice”) includes a value identifying the selected item as well as values for the item itself. - - - - -DataArray elements are encoded recursively/conf/general-encoding-rules/array-encoding-ruletarget/req/general-encoding-rules/array-encoding-rule - - -Verify that the sequence of scalar values obtained after decoding the section of the encoded data block corresponding to the “DataArray” includes values for the successive elements of the array. - - - - -The length of variable size arrays is encoded in the data block/conf/general-encoding-rules/array-size-encoding-ruletarget/req/general-encoding-rules/array-size-encoding-rule - - -Verify that the sequence of values obtained after decoding the section of the encoded data block corresponding to a variable size “DataArray” includes a value specifying the size of the array. - - - - - -Conformance Class: Text Encoding Rules - -Text Encoding Rules/conf/text-encoding-rules/conf/general-encoding-rulesTarget TypeEncoded Values Instancetarget/req/text-encoding-rules - - - - -Compliance with ABNF grammar/conf/text-encoding-rules/abnf-syntax-validtarget/req/text-encoding-rules/abnf-syntax-valid - - -Verify that the text encoded data block is correct with respect to the ABNF grammar corresponding to the particular dataset (The complete ABNF grammar of the dataset should be dynamically constructed from the ABNF snippets provided in the specification). - - - - -Separator characters are well chosen/conf/text-encoding-rules/separators-validtarget/req/text-encoding-rules/separators-valid - - -Verify that the values encoded in the data block never include the reserved separator characters. This can be detected by looking for invalid or superfluous values. - - - - -Special flags are inserted before optional component values/conf/text-encoding-rules/optional-field-marker-presenttarget/req/text-encoding-rules/optional-field-marker-present - - -Verify that the sequence of values corresponding to the optional field starts with the ‘Y’ or ‘N’ flag. - - - - -The name of a selected choice item is inserted in the stream/conf/text-encoding-rules/choice-selection-marker-validtarget/req/text-encoding-rules/choice-selection-marker-valid - - -Verify that the sequence of values corresponding to the “DataChoice” starts with a character string matching the name of one item of the choice descriptor. - - - - - -Conformance Class: Binary Encoding Rules - -Binary Encoding Rules/conf/binary-encoding-rules/conf/general-encoding-rulesTarget TypeEncoded Values Instancetarget/req/binary-encoding-rules - - - - -Compliance with ABNF grammar/conf/binary-encoding-rules/abnf-syntax-validtarget/req/binary-encoding-rules/abnf-syntax-valid - - -Verify that the binary encoded data block is correct with respect to the ABNF grammar of the particular dataset (The complete ABNF grammar of the dataset should be dynamically constructed from the ABNF snippets provided in the specification). - - - - -Data types are encoded as specified in this standard/conf/binary-encoding-rules/type-encoding-validtarget/req/binary-encoding-rules/type-encoding-valid - - -Verify that valid and realistic scalar values are obtained when the binary data block is parsed by extracting the number of bits specified in the table and decoding the resulting bytes in the order specified by the “byteOrder” attribute. When the encoded data and the encoding parameters are not consistent, abberant values (such as -65502 for a temperature field, etc…) are usually obtained, which can be easily detected. - - - - -Base64 encoding is implemented as defined by IETF/conf/binary-encoding-rules/base64-translation-appliedtarget/req/binary-encoding-rules/base64-translation-applied - - -Verify that only characters allowed by base64 encoding are used in the encoded data content. - -Verify that the data block can be properly parsed after the base64 data is decoded into a raw binary data stream. - - - - - - -Special flags are inserted before optional component values/conf/binary-encoding-rules/optional-field-marker-presenttarget/req/binary-encoding-rules/optional-field-marker-present - - -Verify that any optional field is preceded by the a 1-byte ASCII character with value ‘Y’ or ‘N’. - -Verify that the actual field value is only present if the flag has the ‘Y’ value. - - - - - - -The name of a selected choice item is inserted in the stream/conf/binary-encoding-rules/choice-selection-marker-validtarget/req/binary-encoding-rules/choice-selection-marker-valid - - -Verify that the sequence of bytes corresponding to the “DataChoice” starts with a byte value that is greater or equal to 0 and less than the total number of items defined in the choice descriptor. - -Verify that the parsed index value corresponds to the proper item in the choice descriptor. - - - - - - - -Examples - -Text Encoding Rules Examples - -DataArray with inline values (curve) -The following example shows how elements of an array defined as a “DataRecord” can be encoded inline with the text method: - -<swe:DataArray definition="http://sweet.jpl.nasa.gov/2.0/mathFunction.owl#Function"> - <swe:description>Measurement error vs. temperature</swe:description> - <swe:elementCount> - <swe:Count> - <swe:value>5</swe:value> - </swe:Count> - </swe:elementCount> - <swe:elementType name="point"> - <swe:DataRecord> - <swe:label>Error vs. Temperature</swe:label> - <swe:field name="temp"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/physThermo.owl#Temperature"> - <swe:label>Temperature</swe:label> - <swe:uom code="Cel"/> - </swe:Quantity> - </swe:field> - <swe:field name="error"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/sciUncertainty.owl#Error"> - <swe:label>Relative Error</swe:label> - <swe:uom code="%"/> - </swe:Quantity> - </swe:field> - </swe:DataRecord> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator=" " tokenSeparator=","/> - </swe:encoding> - <swe:values>0,5 10,2 50,2 80,5 100,15</swe:values> -</swe:DataArray> - - -In this example, each element consists of a record of two values. The array element structure also corresponds to one block so that tuples are separated by block separators (here the ‘,’ character). Since the array is of size 5, there are 5 tuples listed sequentially in the data block, each one composed of the two values of the data record separated by the token separator. The pattern is “temp,error temp,error …” since values have to be listed in the same order as the fields. - - - -Datastream with records (weather data) -The following snippet defines a datastream with an element of type record: - -<swe:DataStream> - <swe:label>Weather Data</swe:label> - <swe:elementType name="weatherData"> - <swe:DataRecord> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime" - referenceFrame="http://www.opengis.net/def/trs/BIPM/0/UTC"> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="temp"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/air_temperature"> - <swe:label>Air Temperature</swe:label> - <swe:uom code="Cel"/> - </swe:Quantity > - </swe:field> - <swe:field name="press"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/air_pressure_at_mean_sea_level"> - <swe:label>Atmospheric Pressure</swe:label> - <swe:uom code="HPa"/> - </swe:Quantity > - </swe:field> - <swe:field name="windSpeed"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_speed"> - <swe:label>Wind Speed</swe:label> - <swe:uom code="km/h"/> - </swe:Quantity> - </swe:field> - <swe:field name="windDir"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_to_direction"> - <swe:label>Wind Direction</swe:label> - <swe:uom code="deg"/> - </swe:Quantity> - </swe:field> - </swe:DataRecord> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=","/> - </swe:encoding> -</swe:DataStream> - - -The datastream records are encoded using the Text encoding method as shown below: - -2023-03-20T15:40:00Z,15.3,1014,3.5,56.0 -2023-03-20T15:45:00Z,15.4,1015,5.6,123.0 -2023-03-20T15:50:00Z,15.8,1014,13.2,34.0 -... - - - - -Datastream with records and optional fields (navigation data) -The following snippet defines a datastream with an element of type record that contains optional fields: - -<swe:DataStream> - <swe:label>Aircraft Navigation</swe:label> - <swe:elementType name="navData"> - <swe:DataRecord> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime" - referenceFrame="http://www.opengis.net/def/trs/OGC/0/GPS"> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="speed"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/humanTransportAir.owl#GroundSpeed"> - <swe:uom code="m/s"/> - </swe:Quantity > - </swe:field> - <swe:field name="location"> - <swe:Vector optional="true" referenceFrame="http://www.opengis.net/def/crs/EPSG/0/4979"> - <swe:coordinate name="lat"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/spaceCoordinates.owl#Latitude" axisID="Lat"> - <swe:uom code="deg"/> - </swe:Quantity> - </swe:coordinate> - <swe:coordinate name="lon"> - <swe:Quantity definition=" http://sweet.jpl.nasa.gov/2.0/spaceCoordinates.owl#Longitude" axisID="Long"> - <swe:uom code="deg"/> - </swe:Quantity> - </swe:coordinate> - <swe:coordinate name="alt"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/spaceExtent.owl#Altitude" axisID="h"> - <swe:uom code="m"/> - </swe:Quantity> - </swe:coordinate> - </swe:Vector> - </swe:field> - </swe:DataRecord> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=","/> - </swe:encoding> -</swe:DataStream> - - -The datastream records are encoded using the Text encoding method as shown below: - -2007-10-23T15:46:12Z,15.3,Y,45.3,-90.5,311 -2007-10-23T15:46:22Z,25.3,N -2007-10-23T15:46:32Z,20.6,Y,45.3,-90.6,312 -2007-10-23T15:46:52Z,18.9,Y,45.4,-90.6,315 -2007-10-23T15:47:02Z,22.3,N -... - - -In this example, the whole location “Vector” is marked as optional and thus the coordinate values are only included when the optional flag is set to ‘Y’ in the stream. Field values in each block have to be listed in the same order as the field properties in the record definition thus following the “time,speed,Y,lat,lon,alt” or “time,speed,N” pattern depending on whether or not the location is omitted. - - - -Datastream with choice (navigation data) -This is illustrated by the following example: - -<swe:DataStream> - <swe:elementType name="message"> - <swe:DataChoice> - <swe:item name="TEMP"> - <swe:DataRecord> - <swe:label>Temperature Measurement</swe:label> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime"> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="temp"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/air_temperature"> - <swe:uom code="Cel"/> - </swe:Quantity> - </swe:field> - </swe:DataRecord> - </swe:item> - <swe:item name="WIND"> - <swe:DataRecord> - <swe:label>Wind Measurement</swe:label> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime"> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="wind_speed"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_speed"> - <swe:uom code="km/h"/> - </swe:Quantity> - </swe:field> - <swe:field name="wind_dir"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_to_direction"> - <swe:uom code="deg"/> - </swe:Quantity> - </swe:field> - </swe:DataRecord> - </swe:item> - </swe:DataChoice> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=","/> - </swe:encoding> -</swe:DataStream> - - -The datastream records are encoded using the Text encoding method as shown below: - -TEMP,2009-05-23T19:36:15Z,25.5 -TEMP,2009-05-23T19:37:15Z,25.6 -WIND,2009-05-23T19:37:17Z,56.3,226.3 -TEMP,2009-05-23T19:38:15Z,25.5 -... - - -This datastream interleaves different types of messages separated by the block separator character. The element type is a “DataChoice” which means that each encoded block is composed of the item name ‘TEMP’ or ‘WIND’, followed by values of the item. This example also demonstrates that items of a choice can be of different types and length. - - - -Fixed size 2D array (stress matrix) -The following example illustrates how values of a fixed size 3×3 stress matrix can be text encoded inline: - -<swe:Matrix definition="http://sweet.jpl.nasa.gov/2.0/physPressure.owl#Stress"> - <swe:elementCount> - <swe:Count> - <swe:value>3</swe:value> - </swe:Count> - </swe:elementCount> - <swe:elementType name="row"> - <swe:Matrix definition="http://sweet.jpl.nasa.gov/2.0/info.owl#Row"> - <swe:elementCount> - <swe:Count> - <swe:value>3</swe:value> - </swe:Count> - </swe:elementCount> - <swe:elementType name="coef"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/mathVector.owl#Coordinate"> - <swe:uom code="MPa"/> - </swe:Quantity> - </swe:elementType> - </swe:Matrix> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator=" " tokenSeparator=","/> - </swe:encoding> - <swe:values>0.36,0.48,-0.8 -0.8,0.6,0.0 0.48,0.64,0.6</swe:values> -</swe:Matrix> - - -Note that elements of the outer array (i.e. a matrix is a special kind of array) are separated by block separators (i.e. each block surrounded by spaces corresponds to one row of the matrix) while the inner array elements are separated by token separators. - - - -Datastream of variable size 1D arrays (profile series) -The following example shows how SWE Common can be used to encode a series of irregular length profiles by using a variable size array: - -<swe:DataStream> - <swe:elementType name="profileData"> - <swe:DataRecord> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime"> - <swe:label>Sampling Time</swe:label> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="profilePoints"> - <swe:DataArray definition="http://sweet.jpl.nasa.gov/2.0/info.owl#Profile"> - <swe:elementCount> - <swe:Count/> - </swe:elementCount> - <swe:elementType name="point"> - <swe:DataRecord> - <swe:field name="depth"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/depth"> - <swe:label>Sampling Point Vertical Location</swe:label> - <swe:uom code="m"/> - </swe:Quantity> - </swe:field> - <swe:field name="salinity"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter#sea_water_salinity"> - <swe:label>Salinity</swe:label> - <swe:uom code="[ppth]"/> - </swe:Quantity> - </swe:field> - </swe:DataRecord> - </swe:elementType> - </swe:DataArray> - </swe:field> - </swe:DataRecord> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator="@@&#10;" tokenSeparator=","/> - </swe:encoding> -</swe:DataStream> - - -The datastream records are encoded using the Text encoding method as shown below: - -2005-05-16T21:47:12Z,5,0,45,10,20,20,30,30,35,40,40@@ -2005-05-16T22:43:05Z,4,0,45,10,20,20,30,30,35@@ -2005-05-16T23:40:52Z,5,0,45,10,20,20,30,30,35,40,40 -... - - -The example shows data for 3 profiles with a variable number of measurements along the vertical dimension. The number of measurements is indicated in the encoded data block by a number inserted after the timestamp, and before the measurements themselves. Since the array is itself the element of a “DataStream”, elements of the array are separated by token separators. - - - -Datastream with geometry (feature detection) -The following snippet is an example of datastream that contains a geometry. Here, each datastream record represents a feature detected in a video stream, and is composed of a timestamp, a scalar field and the geometry of the geolocated feature. - -<swe:DataStream> - <swe:label>Feature Detections</swe:label> - <swe:elementType name="detection"> - <swe:DataRecord> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime" - referenceFrame="http://www.opengis.net/def/trs/OGC/0/GPS"> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="type"> - <swe:Category definition="http://www.opengis.net/def/featureType"> - <swe:codeSpace xlink:href="http://x-myorg.net/def/VehicleTypes"/> - </swe:Category> - </swe:field> - <swe:field name="geom"> - <swe:Geometry definition="http://www.opengis.net/def/property/OGC/0/SamplingTime" srs="http://www.opengis.net/def/crs/EPSG/0/4326"> - <swe:constraint> - <swe:AllowedGeometries> - <swe:geomType>Point</swe:geomType> - <swe:geomType>Polygon</swe:geomType> - </swe:AllowedGeometries> - </swe:constraint> - </swe:Geometry> - </swe:field> - </swe:DataRecord> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=";"/> - </swe:encoding> -</swe:DataStream> - - -The datastream records are encoded using the Text encoding method as shown below: - -2007-10-23T15:46:12Z;Car;POINT(-86.3254 35.4812) -2007-10-23T15:49:03Z;Truck;POLYGON((-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812)) -2007-10-23T15:56:45Z;Bus;POLYGON((-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812)) -... - - - - - -XML Encoding Rules Examples -The following examples build on the ones provided in the section. The datastream descriptions are kept the same, except that the encoding method would have to be changed to: - -<swe:encoding> - <swe:XMLEncoding/> -</swe:encoding> - - -In the following sections, encoded values were kept identical to the ones used in the text encoding section, in order to facilitate comparison. - - -Datastream with records (weather data) -This example is based on the same datastream description as the one provided in . - -The following snippet shows how this datastream records are encoded using the XML encoding method: - -<swe:values xmlns:ns="http://www.myorg.com/datasets/id"> - <ns:weatherData> - <ns:time>2023-03-20T15:40:00Z</ns:time> - <ns:temp>15.3</ns:temp> - <ns:press>1014</ns:press> - <ns:windSpeed>3.5</ns:windSpeed> - <ns:windDir>56.0</ns:windDir> - </ns:weatherData> - <ns:weatherData> - <ns:time>2023-03-20T15:45:00Z</ns:time> - <ns:temp>15.4</ns:temp> - <ns:press>1015</ns:press> - <ns:windSpeed>5.6</ns:windSpeed> - <ns:windDir>123.0</ns:windDir> - </ns:weatherData> - <ns:weatherData> - <ns:time>2023-03-20T15:50:00Z</ns:time> - <ns:temp>15.8</ns:temp> - <ns:press>1014</ns:press> - <ns:windSpeed>13.2</ns:windSpeed> - <ns:windDir>34.0</ns:windDir> - </ns:weatherData> - ... -</swe:values> - - - - -Datastream with records and optional fields (navigation data) -This example is based on the same datastream description as the one provided in . - -The following snippet shows how this datastream records are encoded using the XML encoding method: - -<swe:values xmlns:ns="urn:myorg:dataset:X156822"> - <ns:navData> - <ns:time>2007-10-23T15:46:12Z</ns:time> - <ns:speed>15.3</ns:speed> - <ns:location> - <ns:lat>45.3</ns:lat> - <ns:lon>-90.5</ns:lon> - <ns:alt>311</ns:alt> - </ns:location> - </ns:navData> - <ns:navData> - <ns:time>2007-10-23T15:46:22Z</ns:time> - <ns:speed>25.3</ns:speed> - </ns:navData> - <ns:navData> - <ns:time>2007-10-23T15:46:32Z</ns:time> - <ns:speed>20.6</ns:speed> - <ns:location> - <ns:lat>45.3</ns:lat> - <ns:lon>-90.6</ns:lon> - <ns:alt>312</ns:alt> - </ns:location> - </ns:navData> - ... -</swe:values> - - -Notice that the optional ‘location’ field in the second stream element has been completely omitted. - - - -Datastream with choice (navigation data) -This example is based on the same datastream description as the one provided in . - -The following snippet shows how this datastream records are encoded using the XML encoding method: - -<swe:values xmlns:ns="urn:myorg:dataset:DC4578"> - <ns:message> - <ns:TEMP> - <ns:time>2009-05-23T19:36:15Z</ns:time> - <ns:temp>25.5</ns:temp> - </ns:TEMP> - </ns:message> - <ns:message> - <ns:TEMP> - <ns:time>2009-05-23T19:37:15Z</ns:time> - <ns:temp>25.6</ns:temp> - </ns:TEMP> - </ns:message> - <ns:message> - <ns:WIND> - <ns:time>2009-05-23T19:37:17Z</ns:time> - <ns:wind_speed>56.3</ns:wind_speed> - <ns:wind_dir>226.3</ns:wind_dir> - </ns:WIND> - </ns:message> - <ns:message> - <ns:TEMP> - <ns:time>2009-05-23T19:38:15Z</ns:time> - <ns:temp>25.5</ns:temp> - </ns:TEMP> - </ns:message> - ... -</swe:values> - - - - -Datastream of variable size 1D arrays (profile series) -This example is based on the same datastream description as the one provided in . - -The following snippet shows how this datastream records are encoded using the XML encoding method: - -<swe:values xmlns:ns="urn:myorg:dataset:PS3658"> - <ns:profileData> - <ns:time>2005-05-16T21:47:12Z</ns:time> - <ns:profilePoints elementCount="5"> - <ns:point> - <ns:depth>0</ns:depth> - <ns:salinity>45</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>10</ns:depth> - <ns:salinity>20</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>20</ns:depth> - <ns:salinity>30</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>30</ns:depth> - <ns:salinity>35</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>40</ns:depth> - <ns:salinity>40</ns:salinity> - </ns:point> - </ns:profilePoints> - </ns:profileData> - <ns:profileData> - <ns:time>2005-05-16T22:43:05Z</ns:time> - <ns:profilePoints elementCount="4"> - <ns:point> - <ns:depth>0</ns:depth> - <ns:salinity>45</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>10</ns:depth> - <ns:salinity>20</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>20</ns:depth> - <ns:salinity>30</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>30</ns:depth> - <ns:salinity>35</ns:salinity> - </ns:point> - </ns:profilePoints> - </ns:profileData> - ... -</swe:values> - - -This example shows how the array size is specified on the ‘profilePoints’ element corresponding to each nested array, and how element local names correspond to the “name” attributes of each component’s parent property. - - - -Datastream with geometry (feature detection) -This example is based on the same datastream description as the one provided in . - -The following snippet shows how this datastream records are encoded using the XML encoding method: - -<swe:values xmlns:ns="urn:myorg:dataset:X151451" xmlns:gml="http://www.opengis.net/gml/3.2"> - <ns:detection> - <ns:time>2007-10-23T15:46:12Z</ns:time> - <ns:type>Car</ns:type> - <ns:geom> - <gml:Polygon srsName="http://www.opengis.net/def/crs/EPSG/0/4326"> - <gml:exterior> - <gml:LinearRing> - <gml:posList srsDimension="2">-86.3254 35.4812 -86.3253 35.4812 -86.3253 35.4811 -86.3254 35.4811 -86.3254 35.4812</gml:posList> - </gml:LinearRing> - </gml:exterior> - </gml:Polygon> - </ns:geom> - </ns:detection> - <ns:detection> - <ns:time>2007-10-23T15:49:03Z</ns:time> - <ns:type>Truck</ns:type> - <ns:geom> - <gml:Polygon srsName="http://www.opengis.net/def/crs/EPSG/0/4326" > - <gml:exterior> - <gml:LinearRing> - <gml:posList srsDimension="2">-86.3254 35.4812 -86.3253 35.4812 -86.3253 35.4811 -86.3254 35.4811 -86.3254 35.4812</gml:posList> - </gml:LinearRing> - </gml:exterior> - </gml:Polygon> - </ns:geom> - </ns:detection> - <ns:detection> - <ns:time>2007-10-23T15:56:45Z</ns:time> - <ns:type>Bus</ns:type> - <ns:geom> - <gml:Polygon srsName="http://www.opengis.net/def/crs/EPSG/0/4326"> - <gml:exterior> - <gml:LinearRing> - <gml:posList srsDimension="2">-86.3254 35.4812 -86.3253 35.4812 -86.3253 35.4811 -86.3254 35.4811 -86.3254 35.4812</gml:posList> - </gml:LinearRing> - </gml:exterior> - </gml:Polygon> - </ns:geom> - </ns:detection> - ... -</swe:values> - - - - - -JSON Encoding Rules Examples -The following examples build on the ones provided in the section. The datastream descriptions are kept the same, except that the encoding method would have to be changed to: - -<swe:encoding> - <swe:JSONEncoding/> -</swe:encoding> - - -In the following sections, encoded values were kept identical to the ones used in the text encoding section, in order to facilitate comparison. - - -DataArray with inline values (curve) -This example is based on the same “DataArray” description as the one provided in . - -The equivalent JSON description for this “DataArray” is provided below: - -{ - "type": "DataArray", - "definition": "http://sweet.jpl.nasa.gov/2.0/mathFunction.owl#Function" - "description": "Measurement error vs. temperature", - "elementCount": { - "type": "Count", - "value": 5 - }, - "elementType": { - "name": "point", - "type": "DataRecord", - "label": "Error vs. Temperature", - "fields": [ - { - "name": "temp", - "type": "Quantity", - "definition": "http://sweet.jpl.nasa.gov/2.0/physThermo.owl#Temperature", - "label": "Temperature", - "uom": { "code": "Cel" } - }, - { - "name": "error", - "type": "Quantity", - "definition": "http://sweet.jpl.nasa.gov/2.0/sciUncertainty.owl#Error", - "label": "Relative Error", - "uom": { "code": "%" } - } - ] - }, - "values": [[0,5], [10,2], [50,2], [80,5], [100,15]] -} - - - - -Datastream with records (weather data) -This example is based on the same datastream description as the one provided in . - -The following snippet shows how this datastream records are encoded using the JSON encoding method: - -[ - { - "time": "2023-03-20T15:40:00Z", - "temp": 15.3, - "press": 1014, - "windSpeed": 3.5, - "windDir": 56.0 - }, - { - "time": "2023-03-20T15:45:00Z", - "temp": 15.4, - "press": 1015, - "windSpeed": 5.6, - "windDir": 123.0 - }, - { - "time": "2023-03-20T15:50:00Z", - "temp": 15.8, - "press": 1014, - "windSpeed": 13.2, - "windDir": 34.0 - }, - ... -] - - - - -Datastream with records and optional fields (navigation data) -This example is based on the same datastream description as the one provided in . - -The following snippet shows how this datastream records are encoded using the XML encoding method: - -[ - { - "time": "2007-10-23T15:46:12Z", - "speed": 15.3, - "location": { - "lat": 45.3, - "lon": -90.5, - "alt": 311 - } - }, - { - "time": "2007-10-23T15:46:22Z", - "speed": 25.3, - "location": null - }, - { - "time": "2007-10-23T15:46:32Z", - "speed": 20.6, - "location": { - "lat": 45.3, - "lon": -90.6, - "alt": 312 - } - }, - ... -] - - - - -Datastream with choice (navigation data) -This example is based on the same datastream description as the one provided in . - -The following snippet shows how this datastream records are encoded using the JSON encoding method: - -[ - { - "TEMP": { - "time": "2009-05-23T19:36:15Z", - "temp": 25.5 - } - }, - { - "TEMP": { - "time": "2009-05-23T19:37:15Z", - "temp": 25.6 - } - }, - { - "WIND": { - "time": "2009-05-23T19:37:17Z", - "wind_speed": 56.3, - "wind_dir": 226.3 - } - }, - { - "TEMP": { - "time": "2009-05-23T19:38:15Z", - "temp": 25.5 - } - }, - ... -] - - - - -Fixed size 2D array (stress matrix) -This example is based on the same “Matrix” description as the one provided in . - -The equivalent JSON description for this “Matrix” is provided below: - -{ - "type": "Matrix", - "definition": "http://sweet.jpl.nasa.gov/2.0/physPressure.owl#Stress" - "elementCount": { - "type": "Count", - "value": 3 - }, - "elementType": { - "name": "row", - "type": "Matrix", - "elementCount": { - "type": "Count", - "value": 3 - }, - "elementType": { - "name": "coef", - "type": "Quantity", - "definition": "http://sweet.jpl.nasa.gov/2.0/mathVector.owl#Coordinate", - "uom": { "code": "MPa" } - } - }, - "values": [[0.36,0.48,-0.8], [-0.8,0.6,0.0], [0.48,0.64,0.6]] -} - - - - -Datastream of variable size 1D arrays (profile series) -This example is based on the same datastream description as the one provided in . - -The following snippet shows how this datastream records are encoded using the JSON encoding method: - -[ - { - "time": "2005-05-16T21:47:12Z", - "profilePoints": [ - { "depth": 0, "salinity": 45 }, - { "depth": 10, "salinity": 20 }, - { "depth": 20, "salinity": 30 }, - { "depth": 30, "salinity": 35 }, - { "depth": 40, "salinity": 40 } - ] - }, - { - "time": "2005-05-16T22:43:05Z", - "profilePoints": [ - { "depth": 0, "salinity": 45 }, - { "depth": 10, "salinity": 20 }, - { "depth": 20, "salinity": 30 }, - { "depth": 30, "salinity": 35 } - ] - }, - { - "time": "2005-05-16T23:40:52Z", - "profilePoints": [ - { "depth": 0, "salinity": 45 }, - { "depth": 10, "salinity": 20 }, - { "depth": 20, "salinity": 30 }, - { "depth": 30, "salinity": 35 }, - { "depth": 40, "salinity": 40 } - ] - }, - ... -] - - - - -Datastream with geometry (feature detection) -This example is based on the same datastream description as the one provided in . - -The following snippet shows how this datastream records are encoded using the JSON encoding method: - -[ - { - "time": "2007-10-23T15:46:12Z", - "type": "Car", - "geom": { - "type": "Point", - "coordinates": [-86.3254, 35.4812] - } - }, - { - "time": "2007-10-23T15:49:03Z", - "type": "Truck", - "geom": { - "type": "Polygon", - "coordinates": [ - [-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812] - ] - } - }, - { - "time": "2007-10-23T15:56:45Z", - "type": "Bus", - "geom": { - "type": "Polygon", - "coordinates": [ - [-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812] - ] - } - }, - ... -] - - - - -Relationship with other ISO models - -Feature model -SWE “Records” can sometimes be seen as feature data from which GML feature representations could be derived. Even if it is true that a SWE “Record” contains values of feature properties, it does not always represent an object like a “Feature” does. The “Record” is simply a logical collection of fields that may be grouped together for a different reason than the fact that they all represent properties of the same object. - -The “Feature” model is a higher level model that is used to regroup property values inside the objects that they correspond to, as well as associate a meaning to the object itself. - -A good example is a set of weather observations obtained from different sensors that may be grouped into a single “Record” in SWE Common, but which does not constitute a feature in the GIS sense. - - - -Coverage model -SWE “Arrays” can sometimes be interpreted as coverage range data or grid data. However, SWE data arrays are lower level data types and don’t constitute a “Coverage” in themselves. The “Coverage” model described in OGC Abstract Topic 6 (OGC 07-011) can be used on top of the SWE “Array” model (which only provides means for describing and encoding the data), in order to provide a stronger link between range data and domain definition. - -Additionally, sensor descriptions given in SensorML (and thus using the SWE Common model) can be used to define a geo-referencing transformation that can be associated with a coverage via the same model. - - -Revision History -Date -Release -Editor -Primary clauses modified -Description - -2008-08-20 -2.0 draft -Alexandre Robin -All -Initial draft version -2008-10-30 -2.0 draft -Ingo Simonis -All -General revision -2009-10-30 -2.0 draft -Alexandre Robin -All -Draft candidate standard -2009-11-04 -2.0 draft -Peter Taylor -Clauses 6 and 7 -Additional examples, minor edits -2009-11-10 -2.0 draft -Alexandre Robin -All -General revision, added section 8 -2010-01-15 -2.0 draft -Alexandre Robin -All -Clarifications in requirements -2010-03-10 -2.0 final -Alexandre Robin -All -Corrections following RFC comments -2023-03-07 -2.1 draft -Alexandre Robin -All -Conversion to AsciiDoc / Metanorma -2023-03-08 -2.1 draft -Alexandre Robin -Clauses 7,8,9 -Removed requirements that were redundant with dependencies -2023-03-16 -2.1 draft -Alexandre Robin -Clause 7,8,9 -Added Geometry class -2023-03-21 -2.1 draft -Alexandre Robin -Clause 9 -Added JSON datastream encoding rules -2023-03-21 -2.1 draft -Alexandre Robin -Clause 9 -Clarified use of media types -2024-04-29 -3.0 draft -Alexandre Robin -All -Refactored to v3.0, removed XML encoding sections - - - -Normative referencesThe following documents are referred to in the text in such a way that some or all of their content constitutes requirements of this document. For dated references, only the edition cited applies. For undated references, the latest edition of the referenced document (including any amendments) applies. - - - - - 2024-02-05 -The Specification Model - -Standard for Modular specifications - -The Specification Model — Standard for Modular specifications - https://portal.ogc.org/files/?artifact_id=34762&version=2 08-131r3 2009-10-19 - Policy SWG - -Open Geospatial Consortium - 3 en Latn This standard contains requirements for writing standards to be used for any document whose eventual purpose is the specification of requirements for software, services or data structures. - 2024-02-05 -OpenGIS Implementation Specification for Geographic information - -Simple feature access - -Part 1: Common architecture - -OpenGIS Implementation Specification for Geographic information — Simple feature access — Part 1: Common architecture - http://www.opengis.net/doc/is/sfa/1.2.1 https://portal.ogc.org/files/?artifact_id=25355 06-103r4 2011-05-28 - John Herring - -Open Geospatial Consortium - 4 en Latn The OpenGIS® Simple Features Interface Standard (SFS) provides a well-defined and common way for applications to store and access feature data in relational or object-relational databases, so that the data can be used to support other applications through a common feature model, data store and information access interface. OpenGIS Simple Features are geospatial features described using vector data elements such as points, lines and polygons. - 2024-02-05 -Geography Markup Language (GML) simple features profile (with Corrigendum) - -Geography Markup Language (GML) simple features profile (with Corrigendum) - https://portal.ogc.org/files/?artifact_id=42729 10-100r3 2011-05-11 - Linda van den Brink - - Clemens Portele - - Panagiotis (Peter) A. Vretanos - -Open Geospatial Consortium - 3 en Latn This approved OGC Implementation Standard defines a Simple Features profile of the Geography Markup Language version 3.2. This Simple Features Profile has been aligned with the OGC Simple Features standard for SQL version 1.2. Simple Features include: Point, Curve (LineString), Surface (Polygon), Geometry, MultiPoint, MultiCurve, MultiSurface, and MultiGeometry. The detailed abstract model for OGC features and geometry can be found in the OGC Abstract Specification, Topic Volume 1: Features (which is equivalent to ISO 19107). This Simple Features profile of GML began as a product of OGC’s Interoperability Program: a global, collaborative, hands-on engineering and testing program designed to deliver prototype technologies and proven candidate standards into the OGC’s Specification Development Program. In OGC Interoperability Initiatives, international teams of technology providers work together to solve specific geo-processing interoperability problems posed by Initiative. - -Date and time — Representations for information interchange — Part 1: Basic rules. International Organization for Standardization, Geneva (2019). . -ISO 8601:201986012019 -ISO - - -Date and time — Representations for information interchange — Part 2: Extensions. International Organization for Standardization, Geneva (2019). . -ISO 8601:201986012019 -ISO - - 2024-02-05 -Information technology - -Information technology - https://www.iso.org/standard/39479.html https://www.iso.org/contents/data/standard/03/94/39479.detail.rss https://standards.iso.org/ittf/PubliclyAvailableStandards/index.html ISO/IEC 11404:2007 ISO/IEC 11404:2007(E) urn:iso:std:iso-iec:11404:stage-90.92:ed-2 11404 2007-12 -International Organization for Standardization - ISO www.iso.org -International Electrotechnical Commission - IEC www.iec.ch 2 en Latn ISO/IEC 11404:2007 specifies the nomenclature and shared semantics for a collection of datatypes commonly occurring in programming languages and software interfaces, referred to as the General-Purpose Datatypes (GPD). It specifies both primitive datatypes, in the sense of being defined ab initio without reference to other datatypes, and non-primitive datatypes, in the sense of being wholly or partly defined in terms of other datatypes. The specification of datatypes in ISO/IEC 11404:2007 is “general-purpose” in the sense that the datatypes specified are classes of datatype of which the actual datatypes used in programming languages and other entities requiring the concept “datatype” are particular instances. These datatypes are general in nature; thus, they serve a wide variety of information processing applications. ISO/IEC 11404:2007 expressly distinguishes three notions of datatype: — the conceptual, or abstract, notion of a datatype, which characterizes the datatype by its nominal values and properties; — the structural notion of a datatype, which characterizes the datatype as a conceptual organization of specific component datatypes with specific functionalities; and — the implementation notion of a datatype, which characterizes the datatype by defining the rules for representation of the datatype in a given environment. ISO/IEC 11404:2007 defines the abstract notions of many commonly used primitive and non-primitive datatypes which possess the structural notion of atomicity. ISO/IEC 11404:2007 does not define all atomic datatypes; it defines only those which are common in programming languages and software interfaces. ISO/IEC 11404:2007 defines structural notions for the specification of other non-primitive datatypes, and provides a means by which datatypes not defined herein can be defined structurally in terms of the GPDs defined herein. ISO/IEC 11404:2007 defines a partial terminology for implementation notions of datatypes and provides for the use of this terminology in the definition of datatypes. The primary purpose of this terminology is to identify common implementation notions associated with datatypes and to distinguish them from conceptual notions. ISO/IEC 11404:2007 specifies the required elements of mappings between the GPDs and the datatypes of some other language. ISO/IEC 11404:2007 does not specify the precise form of a mapping, but rather the required information content of a mapping. 90 92 2007 -ISO/IEC - ISO/IEC 11404:1996 ISO/IEC 11404:1996 - ISO/IEC CD 11404 ISO/IEC CD 11404 - Geneva - 2024-02-05 -Geographic information - -Geographic information - https://www.iso.org/standard/59164.html https://www.iso.org/contents/data/standard/05/91/59164.detail.rss ISO 19101-1:2014 ISO 19101-1:2014(E) urn:iso:std:iso:19101:-1:stage-90.93:ed-1 19101 2014-11 -International Organization for Standardization - ISO www.iso.org 1 en Latn ISO 19101-1:2014 defines the reference model for standardization in the field of geographic information. This reference model describes the notion of interoperability and sets forth the fundamentals by which this standardization takes place. Although structured in the context of information technology and information technology standards, ISO 19101-1:2014 is independent of any application development method or technology implementation approach. 90 93 2014 -ISO - ISO 19101:2002 ISO 19101:2002 - Geneva - -Conceptual Schema Language -ISO 19103:2005191032005 -ISO - - -Spatial Schema -ISO 19107:2003191072003 -ISO - - 2024-02-05 -Geographic information - -Geographic information - https://www.iso.org/standard/26013.html https://www.iso.org/contents/data/standard/02/60/26013.detail.rss ISO 19108:2002 ISO 19108:2002(E) urn:iso:std:iso:19108:stage-90.93:ed-1 19108 2002-09 -International Organization for Standardization - ISO www.iso.org 1 en Latn ISO 19108:2002 defines concepts for describing temporal characteristics of geographic information. It depends upon existing information technology standards for the interchange of temporal information. It provides a basis for defining temporal feature attributes, feature operations, and feature associations, and for defining the temporal aspects of metadata about geographic information. Since this International Standard is concerned with the temporal characteristics of geographic information as they are abstracted from the real world, it emphasizes valid time rather than transaction time. 90 93 2002 -ISO - ISO 19108:2002/Cor 1:2006 ISO 19108:2002/Cor 1:2006 2021-03-15 - Geneva - -Spatial Referencing by Coordinates -ISO 19111:2007191112007 -ISO - -Unified Code for Units of Measure (UCUM), Version 2.1, November 2017, UCUM -Unicode Technical Std #18, Unicode Regular Expressions, Version 13, Aug. 2009Unicode -The Unicode Standard, Version 5.2, October 2009Unicode - - 2024-02-05 -The JavaScript Object Notation (JSON) Data Interchange Format - https://www.rfc-editor.org/info/rfc8259 RFC 8259 10.17487/RFC8259 RFC8259 2017-12 - T. Bray - -RFC Publisher - -RFC Series - en Latn JavaScript Object Notation (JSON) is a lightweight, text-based, language-independent data interchange format. It was derived from the ECMAScript Programming Language Standard. JSON defines a small set of formatting rules for the portable representation of structured data. - This document removes inconsistencies with other specifications of JSON, repairs specification errors, and offers experience-based interoperability guidance. - -STD - 90 -RFC - 8259 -IETF - - 2024-02-05 -The GeoJSON Format - https://www.rfc-editor.org/info/rfc7946 RFC 7946 10.17487/RFC7946 RFC7946 2016-08 - H. Butler - - M. Daly - - A. Doyle - - S. Gillies - - S. Hagen - - T. Schaub - -RFC Publisher - -RFC Series - en Latn GeoJSON is a geospatial data interchange format based on JavaScript Object Notation (JSON). It defines several types of JSON objects and the manner in which they are combined to represent data about geographic features, their properties, and their spatial extents. GeoJSON uses a geographic coordinate reference system, World Geodetic System 1984, and units of decimal degrees. - -RFC - 7946 -IETF - JSON Geospatial JavaScript Object Notation - 2024-02-05 -Web Linking - https://www.rfc-editor.org/info/rfc8288 RFC 8288 10.17487/RFC8288 RFC8288 2017-10 - M. Nottingham - -RFC Publisher - -RFC Series - en Latn This specification defines a model for the relationships between resources on the Web (“links”) and the type of those relationships (“link relation types”). - It also defines the serialisation of such links in HTTP headers with the Link header field. - -RFC - 8288 -IETF - link relation -JSON Schema Validation: A Vocabulary for Structural Validation of JSON, Version 2020-12, IETF JSON Schema - 2024-02-05 -Multipurpose Internet Mail Extensions (MIME) Part One: Format of Internet Message Bodies - https://www.rfc-editor.org/info/rfc2045 RFC 2045 10.17487/RFC2045 RFC2045 1996-11 - N. Freed - - N. Borenstein - -RFC Publisher - -RFC Series - en Latn This initial document specifies the various headers used to describe the structure of MIME messages. [STANDARDS-TRACK] - -RFC - 2045 -IETF - MIME media types headers - 2024-02-05 -Augmented BNF for Syntax Specifications: ABNF - https://www.rfc-editor.org/info/rfc5234 RFC 5234 10.17487/RFC5234 RFC5234 2008-01 - D. Crocker - - P. Overell - -RFC Publisher - -RFC Series - en Latn Internet technical specifications often need to define a formal syntax. Over the years, a modified version of Backus-Naur Form (BNF), called Augmented BNF (ABNF), has been popular among many Internet specifications. The current specification documents ABNF. It balances compactness and simplicity with reasonable representational power. The differences between standard BNF and ABNF involve naming rules, repetition, alternatives, order-independence, and value ranges. This specification also supplies additional rule definitions and encoding for a core lexical analyzer of the type common to several Internet specifications. [STANDARDS-TRACK] - -STD - 68 -RFC - 5234 -IETF - ABNF backus-naur form augmented backus-naur form rule definitions encoding core lexical analyzer - 2024-02-05 -IEEE Standard for Floating-Point Arithmetic - https://ieeexplore.ieee.org/document/4610935 IEEE 754-2008 IEEE 754™-2008 978-0-7381-5752-8 10.1109/IEEESTD.2008.4610935 IEEE 754-2008 2009-01-26 2008-08-29 2013-08-15 2008-06-12 -Institute of Electrical and Electronics Engineers - IEEE http://www.ieee.org en Latn This standard specifies interchange and arithmetic formats and methods for binary and decimal floating-point arithmetic in computer programming environments. This standard specifies exception conditions and their default handling. An implementation of a floating-point system conforming to this standard may be realized entirely in software, entirely in hardware, or in any combination of software and hardware. For operations specified in the normative part of this standard, numerical results and exceptions are uniquely determined by the values of the input data, sequence of operations, and destination formats, all under user control. 2008 -Institute of Electrical and Electronics Engineers - IEEE http://www.ieee.org IEEE 754-2019 IEEE 754-2019 - revises ANSI/IEEE 754-1985 ANSI/IEEE 754-1985 - IEEE 754-2019 IEEE 754-2019 - revises ANSI/IEEE 754-1985 ANSI/IEEE 754-1985 - revises ANSI/IEEE 754-1985 ANSI/IEEE 754-1985 - IEEE 754-2019 IEEE 754-2019 - IEEE Standards Floating-point arithmetic Microprocessors Software Hardware Trademarks 754-2008 arithmetic binary computer decimal exponent floating-point format interchange NaN number rounding significand subnormal - -Bibliography -TODOThe TC has approved Springer LNCS as the official document citation type. - -Springer LNCS is widely used in technical and computer science journals and other publications - - -– Actual References: - -[n] Journal: Author Surname, A.: Title. Publication Title. Volume number, Issue number, Pages Used (Year Published) - - OGC: OGC Testbed 12 Annex B: Architecture (2015). - OGCTB12 - 12 - - - - - - - - - - - - - - - : - - - - -sourcecode table td { padding: 5px; } -sourcecode table pre { margin: 0; } -sourcecode, sourcecode .w { - color: #444444; -} -sourcecode .cp { - color: #CC00A3; -} -sourcecode .cs { - color: #CC00A3; -} -sourcecode .c, sourcecode .ch, sourcecode .cd, sourcecode .cm, sourcecode .cpf, sourcecode .c1 { - color: #1E90FF; -} -sourcecode .kc { - color: #C34E00; -} -sourcecode .kd { - color: #0000FF; -} -sourcecode .kr { - color: #007575; -} -sourcecode .k, sourcecode .kn, sourcecode .kp, sourcecode .kt, sourcecode .kv { - color: #0000FF; -} -sourcecode .s, sourcecode .sb, sourcecode .sc, sourcecode .ld, sourcecode .sd, sourcecode .s2, sourcecode .se, sourcecode .sh, sourcecode .si, sourcecode .sx, sourcecode .sr, sourcecode .s1, sourcecode .ss { - color: #009C00; -} -sourcecode .sa { - color: #0000FF; -} -sourcecode .nb, sourcecode .bp { - color: #C34E00; -} -sourcecode .nt { - color: #0000FF; -} -
- - - -Copyright notice -

Copyright © 2024 Open Geospatial Consortium
-To obtain additional rights of use, visit -

-
- - -Note -

Attention is drawn to the possibility that some of the elements of this document may be the subject of patent rights. The Open Geospatial Consortium shall not be held responsible for identifying any or all such patent rights.

- -

Recipients of this document are requested to submit, with their comments, notification of any relevant patent claims or other intellectual property rights of which they may be aware that might be infringed by any implementation of the standard set forth in this document, and to provide supporting documentation.

-
-
- - - - -License Agreement -

Use of this document is subject to the license agreement at

-
-
- - - - -Notice for Drafts -

This document is not an OGC Standard. This document is distributed for review and comment. This document is subject to change without notice and may not be referred to as an OGC Standard.

- -

Recipients of this document are invited to submit, with their comments, notification of any relevant patent rights of which they are aware and to provide supporting documentation.

-
-
- - - - -

Suggested additions, changes and comments on this document are welcome and encouraged. Such suggestions may be submitted using the online change request form on OGC web site:

-
-
-
Contents -I.<tab/>Abstract

The primary focus of the SWE Common Data Model is to define and package data in a self-describing and semantically enabled way. The main objective is to achieve interoperability, first at the syntactic level, and later at the semantic level (by using ontologies and probably semantic mediation) so that (sensor) data can be better understood by machines, processed automatically in complex workflows and easily shared between intelligent nodes.

- -

This standard is one of several implementation standards produced under OGC’s Connected Systems activity, and is a revision of content that was previously developed in the context of the Sensor Web Enablement initiative. These common data models are intended to be used in various OGC standards, and in particular, SensorML and OGC API — Connected Systems.

-
-II.<tab/>Keywords -

The following are keywords to be used by search engines and document catalogues.

-

ogcdoc, OGC document, html, SWE, sensor, sensorweb, connected systems, json, encoding, observation, command, tasking, property

- -III.<tab/>Preface -

The OGC SWE Common Data Model Encoding Standard is the result of worked done by the Connected Systems Working Group of the OGC, with the aim of modernizing the Sensor Wen Enablement (SWE) suite of Standards.

- -

To increase the brevity and readability of this Standard, many OGC document titles are shortened and/or abbreviated. Therefore, in the context of this document, the following phrases are defined:

- -

“this Standard” shall be interpreted as equivalent to “OGC SWE Common Data Model Encoding Standard”. -“SensorML” or “SensorML Standard” shall be interpreted as equivalent to “OGC Sensor Modeling Language Encoding Standard”

-
-IV.<tab/>Security considerations -

No security considerations have been made for this Standard.

-
-V.<tab/>Submitting Organizations -

The following organizations submitted this Document to the Open Geospatial Consortium (OGC):

-
  • GeoRobotix, Inc.
  • -
  • Botts Innovative Research, Inc.
  • -
  • Cesium GS, Inc.
  • -
  • 52° North Initiative for Geospatial Open Source Software GmbH
  • -
  • Pelagis Data Solutions
  • -
  • National Geospatial-Intelligence Agency (NGA)
-
- -VI.<tab/>Submitters -

All questions regarding this submission should be directed to the editor or the submitters:

- - - - - - - - - - - - - -
NameAffiliation
Alex Robin (Editor)GeoRobotix, Inc.
Christian Autermann52° North Initiative
Chuck HeazelHeazeltech
Mike BottsBotts Innovative Research, Inc.
- -

Additional contributors to this Standard include the following:

- - - - - - - - - - - - - - - - - - - - -
NameAffiliation
Arne Broering52° North Initiative
Barry ReffUS DHS
Ingo SimonisiGSI
Johannes EchterhoffiGSI
John HerringOracle USA
Luis BermudezSURA
Nick GarayBotts Innovative Research, Inc.
Peter TaylorCSIRO
-
-VII.<tab/>Foreword -

This document deprecates version 2.0 of the OGC® SWE Common Data Model Encoding Standard (OGC 08-094r2).

- -

The following changes have been made:

- -
  • Addition of the JSON encodings and schemas

    -
  • -
  • Addition of the Geometry data component (modeled on OGC simple feature geometries)

    -
  • -
  • Deprecation of the XML encodings

    -
  • -
  • Technical revision and improved explanations in various clauses

    -
  • -
- -

This release is not fully backward compatible with version 2.0 even though changes were kept to a minimum.

-
- - - - - - - -1.<tab/>Scope -

This standard defines low level data models for exchanging sensor related data between nodes of the OGC® Connected Systems framework (previously Sensor Web Enablement (SWE) framework). These models allow applications and/or servers to structure, encode and transmit sensor datasets in a self describing and semantically enabled way.

- -

More precisely, the SWE Common Data Model is used to define the representation, nature, structure and encoding of sensor related data. These four pieces of information, essential for fully describing a data stream, are further defined in section 6.

- -

The SWE Common Data Model is intended to be used for describing static data (files) as well as dynamically generated datasets (on the fly processing), data subsets, process and web service inputs and outputs, and real time streaming data and commands. All categories of sensor observations are in scope ranging from simple in-situ temperature data to satellite imagery and full motion video.

- -

This standard defines JSON encodings for the dataset/datastream description, while the data itself can be encoded in JSON, text or binary form. This standard is used by other existing OGC standards such as the Sensor Model Language (SensorML) and OGC API — Connected Systems. One goal of the SWE Common Data Model is to maintain the functionality and consistency between these related standards.

-
- - -2.<tab/>Conformance -

This standard has been written to be compliant with the OGC Specification Model – A Standard for Modular Specification (OGC 08-131r3). Extensions of this standard shall themselves be conformant to the OGC Specification Model.

- -

Conformance with this specification shall be checked using all the relevant tests specified in Annex A. The framework, concepts, and methodology for testing, and the criteria to be achieved to claim conformance are specified in ISO 19105: Geographic information — Conformance and Testing. In order to conform to this OGC™ encoding standard, a standardization target shall implement the core conformance class, and choose to implement any one of the other conformance classes.

- -

Additionally, it is highly recommended that JSON based implementations of the conceptual models do implement requirement classes from clause 8 and clause 9 of this standard, respectively, and pass the corresponding conformance classes instead of defining new encodings.

- -

TODO

- -

This standard defines XXXX.

- -

Requirements for N standardization target types are considered:

- -
  • AAAA

    -
  • -
  • BBBB

    -
  • -
- -

Conformance with this standard shall be checked using all the relevant tests specified in Annex A (normative) of this document. The framework, concepts, and methodology for testing, and the criteria to be achieved to claim conformance are specified in the OGC Compliance Testing Policies and Procedures and the OGC Compliance Testing web site.

- -

In order to conform to this OGC® interface standard, a software implementation shall choose to implement:

- -
  • Any one of the conformance levels specified in Annex A (normative).

    -
  • -
  • Any one of the Distributed Computing Platform profiles specified in Annexes TBD through TBD (normative).

    -
  • -
- -

All requirements-classes and conformance-classes described in this document are owned by the standard(s) identified.

-
- - - - -4.<tab/>Terms and definitions

This document uses the terms defined in OGC Policy Directive 49, which is based on the ISO/IEC Directives, Part 2, Rules for the structure and drafting of International Standards. In particular, the word “shall” (not “must”) is the verb form used to indicate a requirement to be strictly followed to conform to this document and OGC documents do not use the equivalent phrases in the ISO/IEC Directives, Part 2.

-

This document also uses terms defined in the OGC Standard for Modular specifications (OGC 08-131r3), also known as the ‘ModSpec’. The definitions of terms such as standard, specification, requirement, and conformance test are provided in the ModSpec.

-

For the purposes of this document, the following additional terms and definitions apply.

- -

This document uses the terms defined in Sub-clause 5.3 of [OGC06-121r9], which is based on the ISO/IEC Directives, Part 2, Rules for the structure and drafting of International Standards. In particular, the word “shall” (not “must”) is the verb form used to indicate a requirement to be strictly followed to conform to this standard.

- -

For the purposes of this document, the following additional terms and definitions apply.

- -

TODO

- -4.1.Feature -

Abstraction of real-world phenomena

- - - [SOURCE: ISO-19101, definition 4.11]
- -4.2.Observation -

Act of observing a property

- - - [SOURCE: ISO-19156, definition 4.10]
- -4.3.Observation Procedure -

Method, algorithm or instrument, or system of these which may be used in making an observation

Note: In the context of the sensor web, an observation procedure is often composed of one or more sensors that transform a real world phenomenon into digital information, plus additional processing steps.

- - - - - [SOURCE: ISO-19156, definition 4.11]
- -4.4.Property -

Facet or attribute of an object referenced by a name -Example : Abby’s car has the colour red, where “colour red” is a property of the car instance

- - - [SOURCE: ISO-19143]
- -4.5.Sensor -

Type of observation procedure that provides the estimated value of an observed property at its output -Note: A sensor uses a combination of physical, chemical or biological means in order to estimate the underlying observed property. At the end of the measuring chain electronic devices often produce signals to be processed

-
- -4.6.Sensor Network -

A collection of sensors and processing nodes, in which information on properties observed by the sensors may be transferred and processed -Note: A particular type of a sensor network is an ad hoc sensor network.

-
- -4.7.Sensor Data -

List of digital values produced by a sensor that represents estimated values of one or more observed properties of one or more features -Note: Sensor data is usually available in the form of data streams or computer files.

-
- -4.8.Sensor Related Data -

List of digital values produced by a sensor that contains auxiliary information that is not directly related to the value of observed properties -Example: sensor status, quality of measure, quality of service, etc… When such data is measured, it is sometimes considered sensor data as well.

-
- -4.9.Data Component -

Element of sensor data definition corresponding to an atomic or aggregate data type -Note: A data component is a part of the overall dataset definition. The dataset structure can then be seen as a hierarchical tree of data components.

-
-
- - -6.<tab/>Conventions - -6.1.<tab/>Identifiers -

The normative provisions in this standard are denoted by the URI

- -

- -

All requirements and conformance tests that appear in this document are denoted by partial URIs which are relative to this base.

-
- - -6.2.<tab/>Abbreviated terms -

In this document the following abbreviations and acronyms are used or introduced:

- -
  • CRS: Coordinate Reference System

    -
  • -
  • CSML: Climate Science Modeling Language

    -
  • -
  • GPS: Global Positioning System

    -
  • -
  • ISO International Organization for Standardization

    -
  • -
  • MISB Motion Imagery Standards Board

    -
  • -
  • OGC Open Geospatial Consortium

    -
  • -
  • SAS Sensor Alert Service

    -
  • -
  • SensorML Sensor Model Language

    -
  • -
  • SI Système International (International System of Units)

    -
  • -
  • SOS Sensor Observation Service

    -
  • -
  • SPS Sensor Planning Service

    -
  • -
  • SWE Sensor Web Enablement

    -
  • -
  • TAI Temps Atomique International (International Atomic Time)

    -
  • -
  • UML Unified Modeling Language

    -
  • -
  • UTC Coordinated Universal Time

    -
  • -
  • XML eXtended Markup Language

    -
  • -
  • 1D One Dimensional

    -
  • -
  • 2D Two Dimensional

    -
  • -
  • 3D Three Dimensional

    -
  • -
-
- -6.3.<tab/>UML Notation -

The diagrams that appear in this standard are presented using the Unified Modeling Language (UML) static structure diagram. The UML notations used in this standard are described in the diagram below.

- -
Figure 1
-
-
- - -7.<tab/>Requirements Class: Core Concepts (normative core) - - -

Requirements class 1: Core Concepts

Identifier/req/core
Target typeDerived Models and Software Implementations
Conformance classConformance class A.1: /conf/core
- - -7.1.<tab/>Introduction -

The generic SWE Common data model defined by this standard aims at providing verbose information to robustly describe sensor related datasets. We define Sensor Data as data resulting from the observation of properties of virtual or real world objects (or features) by any type of Observation Procedure (See the Observation and Measurements specification OGC 07-022r1 for a more complete description of the observation model used in SWE).

- -

Sensor related datasets however are not limited to sensor observation values, but can also include auxiliary information such as status or ancillary data. In the following sections, we will use the term ‘property’ in a broader sense, which does not necessarily imply “property measured by a sensor”.

- -

A dataset is composed of Data Components whose values need to be put into context in order to be fully understood and interpreted, by either humans or machines. The SWE Common Data Model provides several pieces of information that are necessary to achieve this goal. More precisely, the SWE Common Data Model covers the following aspects of datasets description:

- -
  • Representation

    -
  • -
  • Nature of data and semantics (by using identifiers pointing to external semantics)

    -
  • -
  • Quality

    -
  • -
  • Structure

    -
  • -
  • Encoding

    -
  • -
- -

This requirement class constitutes the core of this standard. The standardization target types of this core are all models or software implementations seeking compliance with this standard.

- - - -

Requirement 1

Identifier/req/core/core-concepts-used
Statement

A derived model or software implementation shall correctly implement the concepts defined in the core of this standard.

-
- - -7.2.<tab/>Data Representation -

Data representation deals with how property values are represented and stored digitally. Each component (or field) in a dataset carries a value that represents the state of a property. This representation will vary depending on the nature of the method used to capture the data and/or the target usage. For instance, a fluid temperature can be represented as a decimal number expressed in degrees Celsius (i.e. 25.4 °C), or as a categorical value taken from a list of possible choices (such as “freezing, cold, normal, warm, hot”).

- -

The following types of representations have been identified: Boolean, Categorical, Continuous Numerical, Discrete Countable and Textual. The paragraphs below explain basic features of each of these representation types.

- - -7.2.1.<tab/>Boolean -

A Boolean representation of a property can take only two values that should be “true/false” or “yes/no”. In a sense, this type of representation is a particular case of the categorical representation with only two predefined options.

- -

Examples

- -

Motion detectors output can be represented by a boolean value -– TRUE if there is motion in the room, FALSE otherwise.

- -

On/Off status of a measurement system can be represented by a boolean value -– TRUE if the system in on, FALSE if the system is off.

-
- - - -

Requirement 2

Identifier/req/core/boolean-rep-valid
Statement

A boolean representation shall at least consist of a boolean value.

- -

The “Boolean” class described in Clause 8.2.4 is used to define a data component with a Boolean representation.

-
- - -7.2.2.<tab/>Categorical -

A categorical representation is a type of discrete representation of a property that only allows picking a value from a well defined list of possibilities (i.e. categories). This list is called a code space in this standard, following ISO 19103 terminology.

- -

The different possible values constituting a code space are usually listed explicitly in an out-of-band dictionary or ontology. This is necessary because each value should be defined formally and unambiguously, so that it can be interpreted correctly.

- -

Examples

- -

Biological or chemical species data is usually represented by a categorical data component that can leverage on existing controlled vocabulary.

- -

A camera mode can be represented by a categorical value: AUTO_FOCUS, MANUAL_FOCUS, etc…​

-
- - - -

Requirement 3

Identifier/req/core/categorical-rep-valid
Statement

A categorical representation shall at least consist of a category identifier and information describing the value space of this identifier.

- -

The “Category” class described in Clause 8.2.6 is used to define a data component with a categorical representation.

-
- - -7.2.3.<tab/>Numerical (continuous) -

Perhaps the most used representation of a property value, especially in the science and technical communities, is the numerical one, as the majority of properties measured by sensors can be represented by numbers.

- -

Numerical representation is often used for continuous values and, in this case, the representation consists of a decimal (often floating point) number associated to a scale or unit of measure. The unit specification is mandatory even for quantities such as ratios that have no physical unit (in this case a scale factor is provided such as 1, 1/100 for percents, 1/1000 for per thousands, etc.).

- -

Examples

- -

Temperature measurements can be represented by a number associated to a unit such as degrees Celsius or Fahrenheit: 23.51°C, 94°F

- -

A velocity vector is composed of several values (usually 2 or 3) associated to a unit of speed: [1.0 2.0 3.0] m/s.

-
- - - -

Requirement 4

Identifier/req/core/numerical-rep-valid
Statement

A continuous numerical representation shall at least consist of a decimal number and the scale (or unit) used to express this number.

- -

The “Quantity” class described in Clause 8.2.8 is used to define a data component with a decimal representation and a unit of measure.

-
- - -7.2.4.<tab/>Countable (discrete) -

Discrete countable properties are also of interest and are most accurately captured with a numerical integer representation. They do not require a unit since the unit is always the unit of count (i.e. the person if we are counting persons, the pixel if we are counting pixels, etc). Note that continuous properties can also be represented as integers with certain combinations of scale and precision. This case should not be confused with the countable properties described here.

- -

Examples

- -

Array indices and sizes are countable properties with no unit.

- -

There are numerous other countable properties such as number of persons, number of bytes, number of frames, etc. for which the unit is obvious from the definition of the property itself.

-
- -

A discrete countable representation should not be confused with a continuous numerical representation whose scale and precision allow encoding the property value as an integer.

- - - -

Requirement 5

Identifier/req/core/countable-rep-valid
Statement

A countable representation shall at least consist of an integer number.

- -

The “Count” class described in Clause 8.2.7 is used to define a data component with an integer representation and no unit of measure.

-
- - -7.2.5.<tab/>Textual -

A textual representation is useful for providing human readable data, expressed in natural language, as well as various alpha numeric tokens that cannot be assigned to well-defined categories.

- -

Examples

- -

Comments or notes written by humans (ex: data annotations, quality assessments).

- -

Machine generated messages for which there is no taxonomy (ex: automatic alert messages).

- -

Alphanumeric identifier schemes leading to a large number of possibilities that cannot be explicitly enumerated (ex: UUID, ISBN code, URN).

-
- - - -

Requirement 6

Identifier/req/core/textual-rep-valid
Statement

A textual representation shall at least consist of a character string.

- -

The “Text” class described in Clause 8.2.5 is used to define a data component with a textual representation.

-
- - -7.2.6.<tab/>Constraints -

Constraints can be added to some representation types to further restrict the set of possible values allowed for a given property:

- -
  • A boolean representation cannot be restricted further since it is already limited to only two possibilities.

    -
  • -
  • A numerical representation can be constrained by a list of allowed values and/or bounded or unbounded intervals. A decimal representation can also be constrained by the number of significant digits after the decimal point.

    -
  • -
  • A categorical representation can be constrained by a list of possible choices, which should be a subset of the list of possibilities defined by the code space.

    -
  • -
  • A textual representation can be constrained by a pattern expressed in a well known language such as regular expression syntax.

    -
  • -
- -

These constraints apply only to the value of the data component to which they are associated. They shall not be used to express constraints on other data components or on any other information than the value.

- -

Examples

- -

A decimal representation of an angular property such as latitude can be constrained to the [-90° 90°] interval.

- -

A temperature reading produced by a sensor can be constrained to the [-50°C +250°C] range.

-
-
-
- - -7.3.<tab/>Nature of Data -

We define “Nature of data” as the information needed to understand what property the value represents. It is thus connected to semantics and the semantic details are often provided by external sources such as dictionaries, taxonomies or ontologies. Note that it is independent of the type of representation used and it does not include information about how the data was actually measured or acquired. This lineage information should be described by other means as explained in Clause 7.4.3.

- - -7.3.1.<tab/>Human readable information -

The first means by which nature of data can be communicated is through human readable text. The data component’s description, which is present in all data types defined in this specification, can hold any length of text for this purpose. The data component’s label is used to carry short human readable information (i.e. a short name); this is useful to allow data consumers to quickly identify the represented property.

- -

It is not recommended to use the concepts of “description” and “label” in a way that they contain robust semantic information (i.e. that machines can rely upon). The content of such fields is intended to be interpretable solely by humans.

-
- - -7.3.2.<tab/>Robust semantics -

All SWE Common data types allow for associating each data component in a dataset with the definition of the Property that it represents.

- - - -

Requirement 7

Identifier/req/core/semantics-defined
Statement

All data values shall be associated with a clear definition of the property that the value represents.

- -

It is recommended that a model uses references to out-of-band dictionaries rather than inline information because semantics are supposed to be shared by multiple datasets. Using references also helps by providing a framework that is independent from the actual semantic technology used.

- -

The SWE Common UML models and XML schemas desribed in this standard can be used in combination with any semantic web technology. It is thus possible to connect a SWE dataset description to an existing taxonomy provided the external register exposes a unique identifier for each entry.

- -

These semantic references point to out-of-band semantic information that can be encoded in various languages, such as the Ontology Web Language (OWL) or GML dictionary.

- - - -

Requirement 8

Identifier/req/core/semantics-resolvable
Statement

If semantic information is provided by referencing out-of-band data, the locators or identifiers used to point to this information shall be resolvable by some well-defined method.

-
- - -7.3.3.<tab/>Time, space and projected quantities -

Temporal, spatial and other projected quantities need to be further defined by specifying the reference frame and axis with respect to which the quantity is expressed. In SWE Common, any simple component type can be associated to a particular axis of a given reference frame.

- -

Examples

- -

Satellite position data can be defined as a vector of 3 components, expressed in the J2000 ECI Cartesian frame, the 1st component being associated to the X axis, the 2nd to the Y axis and the 3rd to the Z axis.

- -

Angular velocity data from an Inertial Measurement Unit can be defined as a vector of 3 components, expressed in the plane reference frame (for instance ENU defined by local East, North, Up directions), the Euler components being mapped to X, Y, Z respectively.

- -

Relative time data can be given with respect to an arbitrary epoch itself positioned in a well defined reference frame such as TAI (from the French “Temps Atomique International” = International Atomic Time).

-
- - - -

Requirement 9

Identifier/req/core/temporal-frame-defined
Statement

A temporal quantity shall be expressed with respect to a well defined temporal reference frame and this frame shall be specified.

- - - -

Requirement 10

Identifier/req/core/spatial-frame-defined
Statement

A spatial quantity shall be expressed with respect to the axes of a well defined spatial reference frame and this frame shall be specified.

- -

The “Time” class described in Clause 8.2.9 is designed for carrying a temporal reference frame or a time of reference in the case of relative time data.

- -

The “Vector” class detailed in Clause 8.3.2 is a special type of record used to assign a reference frame to all its child-components.

- -

The “Matrix” class defined in Clause 8.5.2 allows the definition of higher order tensor quantities.

- -

This standard does not impose requirements on the type of reference frames that a standardization target shall support. Standards that are dependent on this specification can (and often should) however define a minimum set of reference frames that shall be supported by all implementations.

-
-
- - -7.4.<tab/>Data Quality -

Quality information can be essential to the data consumer and the SWE Common Data Model provides simple and flexible ways to associate qualitative information with each component of a dataset.

- - -7.4.1.<tab/>Simple quality information -

Simple quality information can be associated with any scalar data component, in the form of another scalar or range value. The quality information defined here applies solely to the value of the associated data component (i.e. the measurement value) and, depending on its data type, quality can be represented by a numerical, categorical or textual value, or by a range of values.

- -

This quality information can be static, i.e. constant over the whole dataset, or dynamic and provided with the data itself. In this case, the quality value is in fact carried by another component of the dataset (and described in SWE Common as such).

- -

The exact type of quality information provided should be specified via semantic tagging just like with any other property in SWE Common.

- -

Examples

- -

Examples of quality measures are “absolute accuracy”, “relative accuracy”, “absolute precision”, “tolerance”, and “confidence level”.

- -

Quality related comments can also describe operating conditions, such as “sensor contained blockage and was removed” or “engineer on site, values may be affected”. This information can inform the user of potential inaccuracy in the data across certain periods.

-
-
- - -7.4.2.<tab/>Nil Values -

The concept of NIL value is used to indicate that the actual value of a property cannot be given in the data stream, and that a special code (i.e. reserved value) is used instead. It is thus a kind of quality information. The reason for which the value is not included is essential for a good interpretation of the data, so each reserved value is associated to a well-defined reason. In that sense, a NIL value definition is essentially a mapping between a reserved value and a reason.

- -

Each component of a dataset can define one or several NIL values corresponding to one or more reasons.

- -

Example

- -

In low level satellite imagery with, for instance, 8-bits per channel, the imagery metadata often defines: -- A reserved value to indicate that a pixel value was “Below Detection Limit” usually set to ‘0’ -- A reserved value to indicate that a pixel value was “Above Detection Limit” usually set to ‘255’

-
- - - -

Requirement 11

Identifier/req/core/nil-reasons-defined
Statement

A model of a NIL value shall always include a mapping between the selected reserved value and a well-defined reason.

-
- - -7.4.3.<tab/>Full lineage and traceability -

Full lineage and traceability is not in the scope of this specification. It is fully addressed by the OGC® Sensor Model Language Standard, which allows robust definition of measurement chains, with detailed information about the processing that takes place at each stage of the chain. This means that complex lineage guarantying full traceability can be recorded in a SensorML process chain, separately from the data itself.

- -

Datasets can be associated to lineage information described using the Sensor Model Language by using a metadata wrapper such as the “Observation” object defined in the OGC® Observations and Measurements Standard (O&M). In this standard, the “procedure” property of the “Observation” class allows attaching detailed information about the measurement procedure, that is to say a description of how the data was obtained (i.e. lineage), to the data itself.

-
-
- - -7.5.<tab/>Data Structure -

Data structure defines how individual pieces of data are grouped, ordered, repeated and interleaved to form a complete data stream. The SWE Common models are based on data structures commonly accepted in computer science and formalized in ISO 11404. -Classical aggregate datatypes are defined below:

- -
  • Record: consists of a list of fields, each of them being keyed by a field identifier and defining its own type that can be any scalar or aggregate structure.

    -
  • -
  • Array: consists of many elements of the same type, usually indexed by an integer. The element type can be any data structure including scalars and aggregates. The array size constitutes the upper bound of the index.

    -
  • -
  • Choice: consists of a list of alternatives, each of them being keyed by a tag value and having its own type. Only values for one alternative at a time are actually present in the data stream described by such a structure.

    -
  • -
- - - -

Requirement 12

Identifier/req/core/aggregates-model-valid
Statement

Aggregate data structures shall be implemented in a way that is consistent with definitions of ISO 11404.

- -

This standard also defines the concept of “data component” as any part of the structure of a dataset, aggregate or not. It is thus the superset of all the aggregate structures described above and of all scalar elements implementing the representations described in Clause 7.2.

- -

Example

- -

A dataset representing a time series of observations acquired by a mobile sensor can be encoded with various methods depending on the requirements:

- -
  • XML encoding can be used when data needs to be easily styled to other markup formats (such as HTML) or when precise error localization (in the case of an error in the stream) is needed.

    -
  • -
  • ASCII encoding can be used to achieve a good compromise between readability and size efficiency.

    -
  • -
  • Binary encoding can be used (eventually with embedded compression) when pure performance (i.e. size but also reading and writing throughput) is the main concern.

    -
  • -
-
- -

A data component can be both a data descriptor and a data container:

- -
  • A data component used as a data descriptor defines the structure, representation, semantics, quality, and other metadata of a data set but does not include the actual data values.

    -
  • -
  • A data component used as a data container equally defines the dataset but also includes the actual property values.

    -
  • -
-
- - -7.6.<tab/>Data Encoding -

A key concept of the SWE Common Data Model is the ability to separate data values themselves from the description of the data structure, semantics and representation. This allows verbose metadata to be used in order to robustly define the content and meaning of a dataset while still being able to package the data values in very efficient manners.

- -

Data encoding methods define how the data is packed as blocks that can efficiently be transferred or stored using various protocols and formats. Different methods allow encoding the data as JSON, text (CSV like), binary and even compressed or encrypted formats in a way that is agnostic to a particular structure. This allows any of the encodings methods to be selected and used based on a particular requirement, such as performance, re-use of tools, alignment with existing standards and so on.

- - - -

Requirement 13

Identifier/req/core/encoding-method-valid
Statement

All encoding methods shall be applicable to any arbitrarily complex data structures as long as they are made of the data components described in Clause 7.5.

-
-
- - -8.<tab/>UML Conceptual Models (normative) -

This standard defines normative UML models with which derived encoding models as well as all future separate extensions should be compliant. The standardization target type for the UML requirements classes defined in this clause is thus a software implementation or an encoding model that directly implements the conceptual models defined in this standard.

- - -8.1.<tab/>Package Dependencies -

The following packages are defined by the SWE Common Data Model:

- -
-Figure 2 — Internal Package Dependencies -
- -

This standard also has dependencies on external packages defined by other standards, namely ISO 19103, ISO 19108 and ISO 19111, as show below:

- -
-Figure 3 — External Package Dependencies -
-
- - -8.2.<tab/>Requirements Class: Basic Types and Simple Components Packages - - -

Requirements class 2: Simple Components UML Package

Identifier/req/uml-simple-components
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.2: /conf/uml-simple-components
PrerequisiteRequirements class 1: /req/core
- -

Data components are the most essential part of the SWE Common Data Model. They are used to describe all types of data structures, whether they represent data stream contents, tasking messages, alert messages or process inputs/outputs.

- -

The “Simple Components” UML package contains classes modeling simple data components, that is to say scalar components and range components (i.e. value extents). These classes implement concepts defined in the core section of this standard, and are designed to collect information about nature, representation and quality of data. These include six scalar types – Boolean, Text, Category, Count, Quantity, and Time – as well as four range types – CategoryRange, CountRange, QuantityRange and TimeRange.

- -

The “Basic Types” UML package from which the “Simple Components” package is dependent is also included in this requirements class.

- -

As an overview, conceptual models of the six scalar component types are shown on the following UML class diagram:

- -
-Figure 4 — Scalar Data Components -
- -

Classes representing the four range data components are shown on the diagram below:

- -
-Figure 5 — Range Data Components -
- -

Details and requirements about each of these classes are given in the following sections.

- - - -

Requirement 14

Identifier/req/uml-simple-components/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Simple Components” and “Basic Types” UML packages.

- -

Several dependencies to ISO standards exist and are detailed below.

- -

Data types from several packages of the ISO 19103 standard are used directly which makes this requirement class dependent on it. These data types are “CharacterString”, “Boolean”, “Real”, “Integer”, “Date”, “Time”, “DateTime”, “ScopedName”, “UnitOfMeasure” and “UomTime”.

- - - -

Requirement 15

Identifier/req/uml-simple-components/iso19103-implemented
Statement

The encoding or software shall correctly implement all UML classes defined in ISO 19103 that are referenced directly or indirectly by this standard.

- -

The “TM_Position” data type from the “Temporal Reference System” package of the ISO 19108 standard is also used.

- - - -

Requirement 16

Identifier/req/uml-simple-components/iso19108-implemented
Statement

The encoding or software shall correctly implement all UML classes defined in ISO 19108 that are referenced directly or indirectly by this standard.

- -

The “SC_CRS” and “TM_Temporal_CRS” classifiers are referenced conceptually from ISO 19111 but their implementation is not required by this standard. Implementations are allowed to simply use a CRS identifier as a mean of recognizing predefined coordinate reference systems. The use of identifiers from the EPSG database is recommended in this case. However, when new CRS definitions need to be created (e.g. engineering CRS attached to sensors or platforms), the models defined in ISO 19111 shall be used.

- - -8.2.1.<tab/>Basic Data Types -

This requirement class also includes requirements for the “Basic Types” UML package. This package defines low level data types that are used as property types by classes defined in the other packages.

- -

Data types defined in this package relate to defining pairs of data types defined in ISO 19103 for use within classes describing value extents:

- -
-Figure 6 — Basic types for pairs of scalar types -
-
- - -8.2.2.<tab/>Attributes shared by all data components -

All SWE Common data component classes carry standard attributes inherited (transitively) from the “AbstractDataComponent” and “AbstractSWEValue” classes (The “AbstractSWEValue” class is actually defined in the “Basic Types” package but is shown here for clarity). The class hierarchy is shown on the following UML diagram:

- -
-Figure 7 — AbstractDataComponent Class -
- -

Extension Slot

- -

The “extension” attribute is used as a container for future extensions. It allows adding new extended properties to an existing class at the instance level.

- -

Name and Description

- -

The optional “name” and “description” attributes can be used to provide human readable information describing what property the component represents. The “name” is meant to hold a short descriptive name whereas “description” can carry any length of plain text. These two fields should not be used to specify robust semantic information (see Clause 7.3.2). Instead, the “definition” attribute described below should be used for that purpose.

- -

Identifier

- -

The optional “identifier” attribute allows assigning a unique identifier to the component, so that it can be referenced later on. It can be used, for example, when defining the unique identifier of a universal constant.

- -

Definition

- -

The “definition” attribute identifies the property (often an observed property in our context) that the data component represents by using a scoped name. It should map to a controlled term defined in an (web accessible) dictionary, registry or ontology. Such terms provide the formal textual definition agreed upon by one or more communities, eventually illustrated by pictures and diagrams as well as additional semantic information such as relationships to units and other concepts, ontological mappings, etc.

- -

Examples

- -

The definition may indicate that the value represents an atmospheric temperature using a URN such as “urn:ogc:def:property:OGC::SamplingTime” referencing the complete definition in a register.

- -

The definition may also be a URL linking to a concept defined in an ontology such as [http//www.opengis.net/def/OGC/0/SamplingTime]. -The label could be “Sampling Time”, which allows quick identification by human data consumers.

- -

The description could be “Time at which the observation was made as measured by the on-board clock” which adds contextual details.

-
- -

Flags

- -

The “optional” attribute is an optional flag indicating if the component value can be omitted in the data stream. It is only meaningful if the component is used as a schema descriptor (i.e. not for a component containing an inline value). It is ‘false’ by default.

- -

The “updatable” attribute is an optional flag indicating if the component value is fixed or can be updated. It is only applicable if the data component is used to define the input of a process (i.e. when used to define the input or parameter of a service, process or sensor, but not when used to define the content of a dataset).

- -

Examples

- -

The “updatable” flag can be used to identify what parameters of a system are changeable. The exact semantics depends on the context. For example:

- -
  • In SensorML process chains, the “updatable” flag is used to identify process parameters that can accept an incoming connection (and thus can get changed while the process is in execution).

    -
  • -
  • In a SensorML System it is used to indicate whether or not a system parameter is changeable, either by an operator (i.e. by turning a screw or inserting a jumper) or remotely by sending a command.

    -
  • -
  • In the Sensor Planning Service it is used to indicate if tasking parameters are changeable by the client (i.e. by using the Update operation) after a task has been submitted.

    -
  • -
-
-
- - -8.2.3.<tab/>Attributes shared by all simple data components -

As shown on Figures 4 and 5, classes modeling simple data components inherit attributes from the “AbstractSimpleComponent” class from which they are directly derived. This abstract class is shown again below:

- -
-Figure 8 — AbstractSimpleComponent Class -
- -

The definition attribute inherited from the “AbstractDataComponent” class is mandatory on this class and thus on all its descendants.

- - - -

Requirement 17

Identifier/req/uml-simple-components/definition-present
Statement

The “definition” attribute shall be specified by all instances of concrete classes derived from “AbstractSimpleComponent”.

- -

Reference Frames and Axes

- -

It provides two attributes allowing the association of a data component to a reference frame and an axis and thus implements core concepts introduced in Clause 7.3.3. These attributes are used for a component which value is the projection of a property along a temporal or spatial axis.

- -

The “referenceFrame” attribute identifies the reference frame (as defined by the “SC_CRS” object) relative to which the coordinate value is given. The “axisID” attribute takes a string that uniquely identifies one of the reference frame’s axes along which the coordinate value is given.

- - - -

Requirement 18

Identifier/req/uml-simple-components/axis-valid
Statement

The value of the “axisID” attribute shall correspond to the “axisAbbrev” attribute of one of the coordinate system axes listed in the specified reference frame definition.

- -

The union of these two attributes thus uniquely identifies one axis of one given reference frame along which the value of the component is expressed. Note that even though the ISO 19111 model assigns units to CRS axes in addition to a direction, only the direction is used in this standard and the unit is defined by the data component itself. This allows expressing other quantities than the one predefined along the CRS’s axes such as velocity, acceleration or rotation.

- -

A component representing a projected quantity can be defined in isolation or can be contained within a “Vector” or ”Matrix” aggregate when it contributes to the specification of a multi-dimensional quantity (see Clauses 8.3.2 and 8.5.2). In this last case the reference frame definition is usually inherited from the parent “Vector” or ”Matrix” instance and is thus omitted from the scalar component itself. However, the “axisID” attribute still needs to be specified on “Vector” components.

- - - -

Requirement 19

Identifier/req/uml-simple-components/axis-defined
Statement

The “axisID” attribute shall be specified by all instances of concrete classes derived from “AbstractSimpleComponent” and representing a property projected along a spatial axis.

- - - -

Requirement 20

Identifier/req/uml-simple-components/ref-frame-defined
Statement

The “referenceFrame” attribute shall be specified by all instances of concrete classes derived from “AbstractSimpleComponent” and representing a property projected along a spatial or temporal axis, except if it is inherited from a parent aggregate (Vector or Matrix).

- -

Quality

- -

The optional “quality” attribute is used to provide simple quality information as discussed in Clause 7.4.1. It is of type “Quality” which is a union of several classes as defined in Clause 8.2.15. Its multiplicity is more than one which means that several quality measures can be given on for a single data component.

- -

Example

- -

Both precision and accuracy of the value associated to a data component can be specified concurrently (see for a good explanation of the difference between the two).

-
- -

Nil Values

- -

The optional “nilValues” attribute is used to provide a list (i.e. one or more) of NIL values as defined in Clause 7.4.2. The model of the “NilValues” class is detailed in Clause 8.2.16.

- -

Concrete sub-classes of “AbstractSimpleComponent” can also define a “constraint” attribute that allows further restriction of the possible values allowed by the corresponding representation. This implements concepts defined in Clause 7.2.6. These constraints always apply to the value of the property as represented by the corresponding data component whether this value is given inline (data container case) or out-of-band (data descriptor case).

- -

Constraints

- - - -

Requirement 21

Identifier/req/uml-simple-components/value-constraint-valid
Statement

The property value (formally the representation of the property value) attached to an instance of a class derived from “AbstractSimpleComponent” shall satisfy the constraints specified by this instance.

- -

All concrete sub-classes of “AbstractSimpleComponent” also define a “value” attribute. This attribute is not defined in this abstract class because it has a different primitive type in each concrete data component class (See following clauses).

- - - -

Requirement 22

Identifier/req/uml-simple-components/value-attribute-present
Statement

All concrete classes derived from the “AbstractSimpleComponent” class (directly or indirectly) shall define an optional “value” attribute and use it as defined by this standard.

- -

The “value” attribute is always optional on any simple data component in order to allow for both data descriptor and data container cases:

- -
  • When the data component is used as a data container, this attribute always carries the value of the associated property (formally the representation of the estimated or asserted value of the property). Quality information, nil values definitions and constraints thus apply to the value taken by this attribute.

    -
  • -
  • When the data component is used as a data descriptor, its actual value is provided somewhere else, often encoded as part of a larger data block. In this case, quality information, nil values definitions and constraints apply to the out-of-band value and not to the “value” attribute. Instead, the “value” attribute can then be used to specify a default value.

    -
  • -
- -

Whether the data component is used as a descriptor or a container depends on the context and should be explicitly stated by any standard that makes use of the SWE Common Data Model.

- -

All UML classes in this package that derive from “AbstractSimpleComponent” define a “value” attribute with the adequate primitive type and whose meaning is the one explained above.

-
- - -8.2.4.<tab/>Boolean Class -

The “Boolean” class is used to specify a scalar data component with a Boolean representation as defined in Clause 7.2.1. It derives from “AbstractSimpleComponent” and is shown below:

- -
-Figure 9 — Boolean Class -
- -

The “value” attribute of this class is of the boolean primitive type.NOTE

The boolean primitive type is defined in ISO19103 and is not to be confused with the “Boolean” class defined in this standard. This clause is the only place in this standard where the ISO 19103 boolean data type is referenced. All other occurrences of the “Boolean” class in this standard refer to the class defined in this clause.

-

- - -
- - -8.2.5.<tab/>Text Class -

The “Text” class is used to specify a component with a textual representation as defined in Clause 7.2.5. It derives from “AbstractSimpleComponent” and is shown below:

- -
-Figure 10 — Text Class -
- -

Constraints

- -

The “constraint” attribute allows further restricting the range of possible values by using the “AllowedTokens” class defined in Clause 8.2.17. This class allows the definition of the constraint by either enumerating the allowed tokens and/or by specifying a pattern that the value must match.

- -

Value

- -

The “value” attribute (or the corresponding value in out-of-band data) is a string that must match the constraint.NOTE

The “Text” component can be used to wrap a string representing complex content such as an expression in a programming language, xml or html content. This practice should however be used only for systems that don’t require high level of interoperability since the client must know how to interpret the content. Also care must be taken to properly escape such content before it is inserted in an XML document or in a SWE Common data stream.

-

- - -
- - -8.2.6.<tab/>Category Class -

The “Category” class is used to specify a scalar data component with a categorical representation as defined in Clause 7.2.2. It derives from “AbstractSimpleComponent” and is shown below:

- -
-Figure 11 — Category Class -
- -

Code Space

- -

The “codeSpace” attribute is of type “Dictionary” and allows listing and defining the meaning of all possible values for this component. It is expected that instances of the “Dictionary” class will usually be referenced (rather than included inline) by implementations of this class since the code space definition is usually obtained from a controlled vocabulary maintained at a remote location. This type of implementation is the one chosen in the XML encodings defined by this standard.

- -

Constraints

- -

The “constraint” attribute allows further restricting the list of possible values by using the “AllowedTokens” class defined in Clause 8.2.17. This is usually done by specifying a limited list of possible values, which have to be extracted from the code space.

- - - -

Requirement 23

Identifier/req/uml-simple-components/category-constraint-valid
Statement

When an instance of the “Category” class specifies a code space, the list of allowed tokens provided by the “constraint” property of this instance shall be a subset of the values listed in this code space.

- -

It is also possible to use this class without a code space, even though it is not recommended as values allowed in the component would then not be formally defined. However, as the intent of this class is to always represent a value extracted from a set of possible options, a constraint shall be defined if no code space is specified.

- - - -

Requirement 24

Identifier/req/uml-simple-components/category-enum-defined
Statement

An instance of the “Category” class shall either specify a code space or an enumerated list of allowed tokens, or both.

- -

Value

- -

The “value” attribute (or the corresponding value in out-of-band data) is a string that must be one of the items of the code space and also match the constraint.

- - - -

Requirement 25

Identifier/req/uml-simple-components/category-value-valid
Statement

When an instance of the “Category” class specifies a code space, the value of the property represented by this instance shall be equal to one of the entries of the code space.

-
- - -8.2.7.<tab/>Count Class -

The “Count” class is used to specify a scalar data component with a discrete countable representation as defined in Clause 7.2.4. It derives from “AbstractSimpleComponent” and is shown below:

- -
-Figure 12 — Count Class -
- -

Constraints

- -

The “constraint” attribute can be used to restrict the range of possible values to a list of inclusive intervals and/or single values using the “AllowedValues” class defined in Clause 8.2.18. Numbers used to define these constraints should be integers and expressed in the same scale as the count value itself. The “significantFigures” constraint allowed by the “AllowedValues” class is not applicable to the “Count” class.

- -

Value

- -

The “value” attribute (or the corresponding value in out-of-band data) is an integer that must be within one of the constraint intervals or exactly one of the enumerated values.

-
- - -8.2.8.<tab/>Quantity Class -

The “Quantity” class is used to specify a component with a continuous numerical representation as defined in Clause 7.2.3. It derives from “AbstractSimpleComponent” and is shown below:

- -
-Figure 13 — Quantity Class -
- -

Unit of Measure (UoM)

- -

In addition to attributes inherited from the “AbstractSimpleComponent” class, this class provides a unit of measure declaration through the “uom” attribute. This unit is essential for the correct interpretation of data represented as decimal numbers and is thus mandatory. Quantities with no physical unit still have a scale (such as unity, percent, per thousands, etc.) that must be specified with this property.

- -

Constraints

- -

The “constraint” attribute is used to restrict the range of possible values to a list of inclusive intervals and/or single values using the “AllowedValues” class defined in Clause 8.2.18. Numbers used to define these constraints must be expressed in the same unit as the quantity value itself. Additionally, it is possible to constrain the number of significant digits that can be added after the decimal point.

- -

Value

- -

The “value” attribute (or the corresponding value in out-of-band data) is a real value that is within one of the constraint intervals or exactly one of the enumerated values, and most importantly is expressed in the unit specified.

-
- - -8.2.9.<tab/>Time Class -

The “Time” class is used to specify a component with a date-time representation and whose value is projected along the axis of a temporal reference frame. This class is also necessary to specify that a time value is expressed in a calendar system. This class derives from “AbstractSimpleComponent” and is shown below:

- -
-Figure 14 — Time Class -
- -

Time is treated as a special type of continuous numerical quantity that can be either expressed as a scalar number with a temporal unit or a calendar date with or without a time of day. Consequently, this class has all properties of the “Quantity” class, plus some others that are specific to the treatment of time.

- -

Reference Frame

- -

As time is always expressed relative to a particular reference frame, the “referenceFrame” attribute inherited from the parent class “AbstractSimpleComponent” shall always be set on instances on this class unless the default ‘UTC’ is meant.

- - - -

Requirement 26

Identifier/req/uml-simple-components/time-ref-frame-defined
Statement

The “referenceFrame” attribute inherited from “AbstractSimple Component” shall always be set on instance of the “Time” class unless the UTC temporal reference system is used.

- -

Note that specifying the frame of reference is required even when using ISO notation because there can be ambiguities between several universal time references such as UTC, TAI, GPS, UT1, etc… Differences between these different time reference systems are indeed in the order of a few seconds (and increasing), that is to say not negligible in various situations.

- -

Example

- -

J2000 is a well known epoch in astronomy and is equal to:

- -
  • January 1, 2000, 11:59:27.816 in the TAI time reference system

    -
  • -
  • January 1, 2000, 11:58:55.816 in the UTC time reference system

    -
  • -
  • January 1, 2000, 11:59:08.816 in the GPS time reference system

    -
  • -
- -

These offsets are not always constant and depend on the irregular insertion of leap seconds in UTC.

-
- -

The “axisID” attribute inherited from the parent class does not need to be set since a time reference system always has a single dimension. However it can be set to ‘T’ for consistency with spatial axes.

- -

Reference Time

- -

The “referenceTime” attribute is used to specify a different time origin than the one sometimes implied by the “referenceFrame”. This is used to express a time relative to an arbitrary epoch (i.e. different from the origin of a well known reference frame). The new time origin specified by “referenceTime” shall be expressed with respect to the reference frame specified and is of type “DateTime”. This forces the definition of this origin as a calendar date/time combination.

- - - -

Requirement 27

Identifier/req/uml-simple-components/time-ref-time-valid
Statement

The value of the “referenceTime” attribute shall be expressed with respect to the system of reference indicated by the “referenceFrame” attribute.

- -

Example

- -

This class can be used to define a value expressed as a UNIX time (i.e. number of seconds elapsed since January 1, 1970, 00:00:00 GMT) by:

- -
  • Specifying that the reference frame is the UTC reference system

    -
  • -
  • Setting the reference time to January 1, 1970, 00:00:00 GMT.

    -
  • -
  • Setting the unit of measure to seconds

    -
  • -
- -

See definitions of some commonly accepted time standards at or .

-
- -

Local Frame

- -

The optional “localFrame” attribute allows for the definition of a local temporal frame of reference through the value of the component (i.e. we are specifying a time origin), as opposed to the referenceFrame which specifies that the value of the component is in reference to this frame.

- - - -

Requirement 28

Identifier/req/uml-simple-components/time-local-frame-valid
Statement

The “localFrame” attribute of an instance of the “Time” class shall have a different value than the “referenceFrame” attribute.

- -

This feature allows chaining several relative time positions. This is similar to what is done with spatial position in a geopositioning algorithm (and which is also supported by this standard using the “Vector” class).

- -

Example 1

- -

In the case of a whiskbroom scanner instrument, the “sampling time” is often expressed relative to the “scan start time” which is itself given relative to the “mission start time”. It is important to properly identify the chain of time reference systems at play so that the adequate process can compute the absolute time of every measurement made (Note that it is often not practical to record the absolute time of each single measurement when high sampling rates are used).

- -

Example 2

- -

A model forecast may represent its result times relative to the “run time” of the model for efficient encoding. The values of the output will be in reference to this base epoch. In this example the “referenceFrame” attribute of the model time is set to UTC and the “localFrame” set as “ModelTime”. The model result would then define its “referenceFrame” as “ModelTime”, allowing the time values to be encoded relative to the specified time origin.

-
- -

Unit of Measure (UoM)

- -

The “uom” attribute is mandatory since time is a continuous property that shall always be expressed in a well defined scale. The only units allowed are obviously time units.

- -

Constraints

- -

Similarly to the “Quantity” class, the “constraint” attribute allows further restricting the range of possible time values by using the “AllowedTimes” class defined in Clause 8.2.19.

- -

Value

- -

The “value” attribute (or the corresponding value in out-of-band data) is of type “TimePosition” (see Clause 8.2.1) and must match the constraint.

-
- - -8.2.10.<tab/>Requirements applicable to all range classes -

This UML package defines four classes “CategoryRange”, “CountRange”, “QuantityRange” and “TimeRange” that are used for representing extents of property values. These classes have common requirements that are expressed in this clause.

- -

The “value” attribute of all these classes takes a pair of values (with a datatype corresponding to the representation) that represent the inclusive minimum and maximum bounds of the extent. These values must both satisfy the constraints specified by an instance of the class, and be expressed in the unit specified when applicable.

- - - -

Requirement 29

Identifier/req/uml-simple-components/range-value-valid
Statement

Both values specified in the “value” property of an instance of a class representing a property range (i.e. “CategoryRange”, “CountRange”, “QuantityRange” and “TimeRange”) shall satisfy the same requirements as the scalar value used in the corresponding scalar classes.

- -NOTE

These classes are intentionally not derived from their scalar counterparts because they are aggregates of two values and should be treated as such by implementations (especially by encoding methods defined in this standard).

-
-
- - -8.2.11.<tab/>CategoryRange Class -

The “CategoryRange” class is used to express a value extent using the categorical representation of a property. It defines the same attributes as the “Category” class and those should be used in the same way (see Clause 8.2.6):

- -
-Figure 15 — CategoryRange Class -
- - - -

Requirement 30

Identifier/req/uml-simple-components/category-range-valid
Statement

All requirements associated to the “Category” class defined in Clause 8.2.6 apply to the “CategoryRange” class.

- -

Code Space

- -

The “CategoryRange” class also requires that the underlying code space is well-ordered (i.e. the ordering of the different categories in the code space is clearly defined) so that the range is meaningful.

- - - -

Requirement 31

Identifier/req/uml-simple-components/category-range-codespace-order
Statement

The code space specified by the “codeSpace” attribute of an instance of the “CategoryRange” class shall define a well-ordered set of categories.

- -

Example

- -

A “CategoryRange” can be used to specify the approximate time of a geological event by using names of geological eons, eras or periods such as [Archean — Proterozoic] or [Jurassic — Cretaceous].

-
- -

Value

- -

The “value” attribute of the “CategoryRange” class takes a pair of tokens representing the inclusive minimum and maximum bounds of the extent.

-
- - -8.2.12.<tab/>CountRange Class -

The “CountRange” class is used to express a value extent using the discrete countable representation of a property. It defines the same attributes as the “Count” class and those should be used in the same way (see Clause 8.2.7):

- -
-Figure 16 — CountRange Class -
- -

Value

- -

The “value” attribute of the “CountRange” class takes a pair of integer numbers representing the inclusive minimum and maximum bounds of the extent.

-
- - -8.2.13.<tab/>QuantityRange Class -

The “QuantityRange” class is used to express a value extent using the discrete countable representation of a property. It defines the same attributes as the “Quantity” class and those should be used in the same way (see Clause 8.2.8):

- -
-Figure 17 — QuantityRange Class -
- -

Value

- -

The “value” attribute of the “QuantityRange” class takes a pair of real numbers representing the inclusive minimum and maximum bounds of the extent.

-
- - -8.2.14.<tab/>TimeRange Class -

The “TimeRange” class is used to express a value extent of a time property. It defines the same attributes as the “Time” class and those should be used in the same way (see Clause 8.2.9):

- -
-Figure 18 — TimeRange Class -
- - - -

Requirement 32

Identifier/req/uml-simple-components/time-range-valid
Statement

All requirements associated to the “Time” class defined in Clause 8.2.9 apply to the “TimeRange” class.

- -

The “value” attribute of the “TimeRange” class takes a pair of values of type “TimePosition” representing the inclusive minimum and maximum bounds of the extent.

-
- - -8.2.15.<tab/>Quality Union -

The “Quality” class is a union allowing the use of different representations of quality.

- -

Quality can be indeed be specified as a decimal value, an interval, a categorical value or a textual statement. In our model, quality objects are in fact data components used in a recursive way, as shown on the following diagram:

- -
-Figure 19 — Quality Union -
- -

These different representations of quality are useful to cover most use cases where simple quality information is provided with the data.

- -

Examples

- -

“Quantity” is used to specify quality as a decimal number such as accuracy, variance and mean, or probability.

- -

“QuantityRange” is used to specify a bounded interval of variation such as a bi-directional tolerance.

- -

“Category” is used for a quality statement based on a well defined taxonomy such as certification levels.

- -

“Text” is used to include a textual quality statement such as a comment written by a field operator.

-
- -

The “definition” attribute of the chosen quality component helps to further define the type of quality information given just like any other data component, and the “uom” should be specified in the case of a decimal quality value or interval.NOTE

Reusing data components to specify quality also allows the inclusion of quality values in the data stream itself. This is useful if the quality is varying and re-estimated for each measurement. This is for example the case in a GPS receiver where both horizontal and vertical errors are given along with the geographic position. See the XML implementation clause for more information on this use case.

-

- - -
- - -8.2.16.<tab/>NilValues Class -

The “NilValues” class is used by all classes deriving from “AbstractSimpleComponent”. It allows the specification of one or more reserved values that may be included in a data stream when the normal measurement value is not available (see Clause 7.4.2). The UML model of this class is given below:

- -
-Figure 20 — NilValues Class -
- -

An instance of the “NilValues” class is composed of one to many “NilValue” objects, each of which specifies a mapping between a reserved value and a reason.

- -

The mandatory “reason” attribute indicates the reason why a measurement value is not available. It is a resolvable reference to a controlled term that provides the formal textual definition of this reason (usually agreed upon by one or more communities).

- - - -

Requirement 33

Identifier/req/uml-simple-components/nil-reason-resolvable
Statement

The “reason” attribute of an instance of the “NilValue” class shall map to the complete human readable definition of the reason associated with the NIL value.

- -

The mandatory “value” attribute specifies the data value that would be found in the stream to indicate that a measurement value is missing for the corresponding reason. The range of values allowed here is the range of values allowed by the datatype of the parent data component.

- - - -

Requirement 34

Identifier/req/uml-simple-components/nil-value-type-coherent
Statement

The value used in the “value” property of an instance of the “NilValue” class shall be compatible with the datatype of the parent data component object.

- -

This means that when specifying NIL values for a “Quantity” component, only real values are allowed (in most implementations, this includes NaN, -INF and INF) and for a “Count” component only integer values are allowed.

- -

Consequently, it is also impossible to specify NIL values for a “Boolean” data component since it allows only two possible values. In this case a “Category” component should be used.

- -

There are no restrictions on the choice of NIL values for “Category” and “Text” components since their datatype is String.

-
- - -8.2.17.<tab/>AllowedTokens Class -

The “AllowedTokens” class is used to express constraints on the value of a data component represented by a “Text” or a “Category” class. The UML class is shown below:

- -
-Figure 21 — AllowedTokens Class -
- -

This class allows defining the constraint either by enumerating a list of allowed values by using one or more “value” attributes and/or by specifying a pattern that the value must match. The value must then either be one of the enumerated tokens or match the pattern.

-
- - -8.2.18.<tab/>AllowedValues Class -

The “AllowedValues” class is used to express constraints on the value of a data component represented by a “Count” or a “Quantity” class. The UML class is shown below:

- -
-Figure 22 — AllowedValues Class -
- -

This class allows constraints to be defined either by enumerating a list of allowed values and/or a list of inclusive intervals. To be valid, the value must either be one of the enumerated values or included in one of the intervals. The numbers used in the “value” and “interval” properties shall be expressed in the same unit as the parent data component.

- - - -

Requirement 35

Identifier/req/uml-simple-components/allowed-values-unit-coherent
Statement

The scale of the numbers used in the “enumeration” and “interval” properties of an instance of the “AllowedValues” class shall be expressed in the same scale as the value(s) that the constraint applies to.

- -

If the parent data component instance is used to define a projected quantity (i.e. when the “axisID” is set), then the constraints given by this class are expressed along the same spatial reference frame axis.

- -

The number of significant digits can also be specified with the “significantFigures” property though it is only applicable when used with a decimal representation (i.e. within the “Quantity” class). This limits the total number of digits that can be included in the number represented whether a scientific notation is used or not.

- -

Examples

- -

All non-zero digits are considered significant. 123.45 has five significant figures: 1, 2, 3, 4 and 5.

- -

Zeros between two non-zero digits are significant. 101.12 has five significant figures: 1, 0, 1, 1 and 2.

- -

Leading zeros are not significant. 0.00052 has two significant figures: 5 and 2 and is equivalent to 5.2×10-4 and would be valid even if the number of significant figures is restricted to 2.

- -

Trailing zeros are significant. 12.2300 has six significant figures: 1, 2, 2, 3, 0 and 0 and would thus be invalid if the number of significant figures is restricted to 4.

-
- -NOTE

The number of significant figures and/or an interval constraint (i.e. min/max values) can help a software implementation choosing the best data type to use (i.e. ‘float’ or ‘double’, ‘short’, ‘int’ or ‘long’) to store values associated to a given data component.

-
-
- - -8.2.19.<tab/>AllowedTimes Class -

The “AllowedTimes” class is used to express constraints on the value of a data component represented by a “Time” class. The UML class is shown below:

- -
-Figure 23 — AllowedTimes Class -
- -

This class is almost identical to the “AllowedValues” class and in fact all properties are used in the same way. The only difference with this class is that the “value” and “interval” properties allow the use of time data types as defined in Clause 8.2.1.

- -

The constraints given by this class are expressed along the same time reference frame axis as the value attached to the parent data component.

-
- - -8.2.20.<tab/>Unions of simple component classes -

Several useful groups of classes are also defined in this package. These unions can be used as attribute types and they are shown on the following diagram:

- -
-Figure 24 — Simple Component Unions -
- -

The “AnyScalar” union groups all classes representing scalar components, numerical or not. The “AnyNumerical” union includes all classes corresponding to numerical scalar representations. The “AnyRange” union regroups all range components.

-
-
- - -8.3.<tab/>Requirements Class: Record Components Package - - -

Requirements class 3: Record Components UML Package

Identifier/req/uml-record-components
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.3: /conf/uml-record-components
PrerequisiteRequirements class 2: /req/uml-simple-components
- -

As detailed in the following clauses, this package defines classes modeling record style component types that can be nested to build complex structures from the simple component types introduced in Clause 8.2.

- -

The classes defined in this package are “DataRecord” and “Vector” (other aggregates are defined in the “Choice Components” and “Block Components” packages defined in Clauses 8.4 and 8.5 respectively). The UML model is exposed below:

- -
-Figure 25 — Record Data Components -
- - - -

Requirement 36

Identifier/req/uml-record-components/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Record Components” UML package.

- -

As with simple component types, all data aggregates inherit attributes from the “AbstractDataComponent” class. In this case, however, these attributes provide information about the group as a whole rather than its individual components.

- -

Examples

- -

A particular “DataRecord” might represent a standard collection of error codes coming from a GPS device.

- -

A particular “Vector” might represent the linear or angular velocity vector of an aircraft.

- -

In these two cases, the “definition” attribute should reference a semantic description in a registry, so that the data consumer knows what kind of data the aggregate represents. This semantic description can then be interpreted appropriately by consuming clients: for example to automatically decide how to style the data in visualization software.

-
- - -8.3.1.<tab/>DataRecord Class -

The “DataRecord” class is modeled on the definition of ‘Record’ from ISO 11404. In this definition, a record is a composite data type composed of one to many fields, each of which having its own name and type definition. Thus it defines some logical collection of components of any type that are grouped for a given purpose.

- -

As shown on the following figure, the “DataRecord” class in SWE Common is based on a full composite design pattern, such that each one of its “field” can be of a different type, including simple component types as well as any aggregate component type.

- -
-Figure 26 — DataRecord Class -
- -

The “DataRecord” class derives from the “AbstractDataComponent” class, which is necessary to enable the full composite pattern in which a “DataRecord” can be used to group scalar components, but also other records, arrays and choices recursively.

- -

Fields

- -

Each “field” attribute can take an instance of any concrete sub-class of “AbstractDataComponent”, which is the superset of all data component types defined in this standard. The name of each field must be unique within a given “DataRecord” instance so that it can be used as a key to uniquely identify and/or index each one of the record components.

- - - -

Requirement 37

Identifier/req/uml-record-components/record-field-name-unique
Statement

Each “field” attribute in a given instance of the “DataRecord” class shall be identified by a name that is unique to this instance.

- -

Example

- -

A “DataRecord” can group related values such as “temperature”, “pressure” and “wind speed” into a structure called “weather measurements”. This feature is often used to organize the data and present it in a clear way to the user.

- -

Similarly a “DataRecord” can be used to group values of several spectral bands in multi-spectral sensor data. However, using a “DataArray” may be easier to describe hyper spectral datasets with several hundreds of bands.

-
- -NOTE

The slightly different definition of record found in ISO 19103 provides for its schema to be specified in an associated “RecordType”. When used as a descriptor, the “DataRecord” implements the ISO 19103 “RecordType”. When used as a data container, it is self-describing: the descriptive information is then interleaved with the record values.

-
-
- - -8.3.2.<tab/>Vector Class -

The “Vector” class is used to express multi-dimensional quantities with respect to a well defined referenced frame (usually a spatial or spatio-temporal reference frame). This is done by projecting the quantity on one or several axes that define the reference frame and assigning a value to each of the axis projections.

- -

The “Vector” class is a special case of a record that takes a collection of coordinates that are restricted to a numerical representation. Coordinates of a “Vector” can thus only be of type “Quantity”, “Count” or “Time”. Its UML diagram is shown below:

- -
-Figure 27 — Vector Class -
- -

Coordinates

- -

Just like record fields, vector coordinates must have a unique name:

- - - -

Requirement 38

Identifier/req/uml-record-components/vector-coord-name-unique
Statement

Each “coordinate” attribute in a given instance of the “Vector” class shall be identified by a name that is unique to this instance.

- -

Reference Frame

- -

This class contains a mandatory “referenceFrame” attribute that identifies the frame of reference with respect to which the vector quantity is expressed. The coordinates of the vector correspond to values projected on the axes of this frame.

- -

The “referenceFrame” attribute is inherited by all components of the “Vector”, so that it shall not be redefined for each coordinate. However the “axisID” attribute shall be specified for each coordinate, in order to unambiguously indicate what axis of the reference frame it corresponds to.

- - - -

Requirement 39

Identifier/req/uml-record-components/vector-component-no-ref-frame
Statement

The “referenceFrame” attribute shall be ommited from all data components used to define coordinates of a “Vector” instance.

- - - -

Requirement 40

Identifier/req/uml-record-components/vector-component-axis-defined
Statement

The “axisID” attribute shall be specified on all data components used as children of a “Vector” instance.

- -

Local Frame

- -

The optional “localFrame” attribute allows identifying the frame of interest, that is to say the frame we are positioning with the coordinate values associated to this component (by opposition to the “referenceFrame” that specifies the frame with respect to which the values of the coordinates are expressed).

- - - -

Requirement 41

Identifier/req/uml-record-components/vector-local-frame-valid
Statement

The “localFrame” attribute of an instance of the “Vector” class shall have a different value than the “referenceFrame” attribute.

- -

Correctly identifying the local and reference frame is an important feature that allows chaining several relative positions, something that is essential to correctly compute accurate position of sensor data (especially remote sensing data).

- -

Example 1

- -

A position vector (or location vector) is used to locate the origin of a frame of interest (the local frame) relative to the origin of a frame of reference (the reference frame) through a linear translation. It is composed of three coordinates of type “Quantity”, each with a definition indicating that the coordinate represents a length expressed in the desired unit. The definition of the “Vector” itself should also indicate that it is a “location vector”.

- -
- -

Example 2

- -

An orientation vector is used to indicate the rotation of the axes of a frame of interest (the local frame) relative to a frame of reference (the reference frame). It is composed of three coordinates of type “Quantity” with a definition indicating an angular property. The “Vector” definition should indicate the type of orientation vector such as “Euler Angles” or “Quaternion”. Depending on the exact definition, the order in which the coordinates are listed in the vector may matter.

-
- -NOTE

“Vector” aggregates are most commonly used to describe position, orientation, velocity, and acceleration within temporal and spatial domains, but can also be used to express relationships between any two coordinate frames.

-
-
-
- - -8.4.<tab/>Requirements Class: Choice Components Package - - -

Requirements class 4: Choice Components UML Package

Identifier/req/uml-choice-components
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.4: /conf/uml-choice-components
PrerequisiteRequirements class 2: /req/uml-simple-components
- -

As detailed in the following clauses, this package defines a class modeling a disjoint union component type. This aggregate type can be nested with other aggregate components to build complex structures.

- - - -

Requirement 42

Identifier/req/uml-choice-components/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Choice Components” UML package.

- - -8.4.1.<tab/>DataChoice Class -

The “DataChoice” class (also called Disjoint Union) is modeled on the definition of ‘Choice’ from ISO 11404. It is a composite component that allows for a choice of child components. By opposition to records that carry all their fields simultaneously, only one item at a time can be present in the data when wrapped in a “DataChoice”. The following diagram shows the “DataChoice” class as implemented in the SWE Common Data Model:

- -
-Figure 28 — DataChoice Class -
- -

This class implements a full composite pattern, so that each “item” can be any data component, including simple and aggregate types.

- -

The “choiceValue” attribute is used to represent the token value that would be present in the data stream and that indicates the actual choice selection before the corresponding data can be given (i.e. knowing what choice item was selected ahead of time is necessary for proper decoding of encoded data streams).

- -

Items

- -

Each “item” attribute can take an instance of any concrete sub-class of “AbstractDataComponent”, which is the superset of all data component types defined in this standard. The name of each item shall be unique within a given “DataChoice” instance so that it can be used as a key to uniquely identify and/or index each one of the choice components.

- - - -

Requirement 43

Identifier/req/uml-choice-components/choice-item-name-unique
Statement

Each “item” attribute in a given instance of the “DataChoice” class shall be identified by a name that is unique to this instance.

- -

The “DataChoice” component is used to describe a data structure (or a part of the structure) that can alternatively contain different types of objects. It can also be used to define the input of a service or process that allows a choice of structures as its input.

- -

Examples

- -

NMEA 0183 compatible devices can output several types of sentences in the same data stream. Some sentences include GPS location, while some others contain heading or status data. This can be described by a “DataChoice” which items represent all the possible types of sentences output by the device.

- -

A Sensor Planning Service (SPS) can define a choice in the tasking messages that the service can accept, thus leaving more possibilities to the users.

-
-
-
- - -8.5.<tab/>Requirements Class: Block Components Package - - -

Requirements class 5: Block Components UML Package

Identifier/req/uml-block-components
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.5: /conf/uml-block-components
PrerequisitesRequirements class 2: /req/uml-simple-components
Requirements class 7: /req/uml-simple-encodings
- -

This package defines additional aggregate components for describing arrays of values that are designed to be encoded as efficient data blocks. These additional aggregate components are purposely defined in a separate requirement class because they require a more advanced implementation for handling data values as encoded blocks.

- -

The UML models for these additional aggregate components are shown below:

- -
-Figure 29 — Array Components -
- - - -

Requirement 44

Identifier/req/uml-block-components/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Block Components” UML package.

- -

The principle of these two classes is that the number and type of elements contained in the array is defined once, while the actual array values are listed separately without being redefined with each value. In order to achieve this, all array values are encoded as a single data block in the “values” attribute. Consequently, these classes are restricted to cases where all elements are homogeneous and thus can be described only once even though the array data may in fact contain many of them.

- -

This package also defines the “DataStream” class that is similar in principle to the “DataArray” class but cannot be nested within other aggregate data components. It is a top level class that encapsulates the description of a full data stream.

- - -8.5.1.<tab/>DataArray Class -

The “DataArray” class is modeled on the corresponding definition of ISO 11404. This definition states that an array is a collection of elements of the same type (as opposed to a record where each field can have a different type), with a defined size. This class is shown on the following UML diagram:

- -
-Figure 30 — DataArray Class -
- -

This class implements a full composite pattern, so that the “elementType” can be any data component, including simple and aggregate types. It can be used to group identical scalar components as well as records, choices and arrays in a recursive manner.

- -

Element Count

- -

The “elementCount” attribute is used to indicate the size of the array, that is to say the number of elements of the given type in the array. Note that each element is not necessarily scalar but can be a record, another array, etc.

- -

Element Type

- -

The content of the “elementType” attribute defines the exact structure of each element in the array. The data component used and all of its children shall not include any inline values, as these will be block encoded in the “values” attribute of the parent “DataArray”.

- - - -

Requirement 45

Identifier/req/uml-block-components/array-component-no-value
Statement

Data components that are children of an instance of a block component shall be used solely as data descriptors. Their values shall be block encoded in the “values” attribute of the block component rather than included inline.

- -

However, the “DataArray” class itself, like any other data component can be used either as a data descriptor or as a data container. To use it as a data descriptor the “encoding” and “values” attributes are not set. To use it as a data container, these attributes are both set as described below.

- -

Encoding and Values

- -

The “encoding” and “values” fields are there to provide array data as an efficient block which can be encoded in several ways. The different encoding methods are described in Clauses 8.7 and 8.8. The “encoding” field shall have a value if the “values” field is present, and the data shall be encoded using the specified encoding.

- - - -

Requirement 46

Identifier/req/uml-block-components/array-values-properly-encoded
Statement

Whenever an instance of a block component contains values, an encoding method shall be specified by the “encoding” property and array values shall be encoded as specified by this method.

- -

The choice of simple encodings (defined in the “Simple Encodings” package) allows encoding data as text using a delimiter separated values (DSV, a variant of CSV) format or as XML tagged values. The “Advanced Encodings” package defines binary encodings that can be used to efficiently package large datasets.

- -

Nested Components

- -

By combining instances of “DataArray”, “DataRecord” and scalar components, one can obtain the complex data structures that are necessary to fully describe any kind of sensor data. In particular, the possibility of nesting a “DataRecord” or “Vector” inside a “DataArray” allows defining structures such as trajectories, profiles, multi-band images, etc.

- -

Example 1

- -

The “DataArray” class can be used to describe a simple 1D array of measurements such as radiance values obtained using a 12000 cells (1 row) CCD strip for instance. This can be done by using the “Quantity” class as the element type. In such a case, describing the dataset as a “DataRecord” would be a very repetitive task given the number of elements (12000 in this case!).

- -
- -

Example 2

- -

The “DataArray” class can be used as a descriptor for a trajectory dataset by using a vector of [latitude, longitude] coordinates as its element type. Note that this can also be considered as a 1D coverage in a 2D CRS.

- -
-
- -

Multi-dimensional Arrays

- -

Since the “DataArray” class alone can only represent 1-dimensional arrays, the construction of multi-dimensional arrays is done by nesting “DataArray” objects inside each other.

- -

Example

- -

The structure of panchromatic imagery data can be described with two nested arrays, which sizes indicate the two dimensions of the image. A “Quantity” is used as the element type of the nested array in order to indicate that the repeated element of the 2D array is of type infrared radiance with a given unit.

- -
- -

In this example, the image is described as an array of rows, each row being an array of samples. It is also possible to describe an image as an array of columns by reversing the two dimensions. Note that this would change the order in which the data values would appear in a stream (by rows vs. by columns).

-
- -

Array Size

- -

One powerful feature of the “DataArray” model is that it allows for the element count to be either fixed or variable, thus allowing the description of data streams with variable number of repetitive elements as is often the case with many kinds of sensor.

- -

In a fixed size array, the number of elements can be provided in the descriptor as an instance of the “Count” class with an inline value. This value is only present in the data description and not in the encoded block of array values. The definition of the “Count” instance is not required.

- -

In a variable size array, the “elementCount” attribute either contains an instance of the “Count” class with no value or references an instance of a “Count” class in a parent or sibling data component. The value giving the actual array size is then included in the stream, before the array values themselves, so that the block can be properly decoded. One obvious implementation constraint is that the value representing the array size must be received before the array values. This is detailed further in the XML implementation section.

- -

Examples

- -

Argo profiling floats can measure ocean salinity and temperature profiles of variable lengths by diving at different depths and depending on the conditions. A variable size “DataArray” could be used to describe their output data as well as a dataset aggregating data from several Argo floats.

- -

Variable size arrays can often be used to avoid unnecessary padding of fixed size array data. However for efficiency reasons (usually to enable fast random access w/o preliminary indexation), padding can also be specified in SWE Common when using the binary encoding.

-
- -

Array Semantics

- -

As with any other data component, the “name” and “description” can be used to better describe the array and more importantly the “definition” attribute can be used to formally indicate the semantics behind the array.

- -

Example

- -

When a “DataArray” is used to package data relative to the spectral response of a sensor, the array “definition” attribute can be used to point to the formal out-of-band definition of the “spectral response” concept.

- -

Similarly a “DataArray” used to describe the output data of an Argo float would have its “definition” attribute reference the formal definition of a “profile”.

-
- -

The value of the “definition” attribute of the “Count” instance used as the “elementCount” is also especially important, since it is used to define the meaning of the array dimension. Thanks to this, it is possible to tag the dimension of an array as spatial, temporal, spectral, or any other kind. However it is not mandatory as it is on other simple components.

- -

Examples

- -

In the CCD strip example described as a 1D array, the array index is the cell number in the strip.

- -

In the 2D image example, the outer array index is the row number, while the inner array index is the column (or sample) number.

- -

In a 1D array representing a time series, the array index is along the temporal dimension.

- -

In a 2D array representing a spatial coverage, the two array indices are along spatial dimensions.

- -

In a 3D array representing hyper-spectral imagery, the two first arrays have indices along spatial dimension while the most inner array is indexed along the spectral dimension.

-
- -

This extra information can be used by software to make decisions (or at least ask the user by providing him this information) about how to represent or even interpolate the data.

-
- - -8.5.2.<tab/>Matrix Class -

The “Matrix” extends the “DataArray” class by providing a reference frame within which the matrix elements are expressed and a local frame of interest. The UML diagram of this class is shown below:

- -
-Figure 31 — Matrix Class -
- -

The “Matrix” class is usually used to represent a position matrix or a tensor quantity of second or higher order. Each matrix element is expressed along the axis of a well defined reference frame.

- -

Element Type

- -

The “elementType” attribute inherited from the “DataArray” class can only take a nested “Matrix” instance or a scalar numerical component. Nested matrix objects allow the full description of N-dimensional matrices.

- - - -

Requirement 47

Identifier/req/uml-block-components/matrix-element-type-valid
Statement

The “elementType” attribute of an instance of the “Matrix” class can only be an instance of “Matrix” or of the classes listed in the “AnyNumerical” union.

- -

Reference Frame

- -

The “referenceFrame” attribute is used in the same way as with the “Vector” class to specify the frame of reference with respect to which the matrix element values are expressed. It is inherited by all child components.

- -

Local Frame

- -

The “localFrame” attribute is used to identify the frame of interest, that is to say the frame whose orientation or position is given with the matrix in the case where it is a position matrix. If the matrix does not specify position, “localFrame” should not be used. Whether an instance of the “Matrix” class represents a position matrix or not should be disambiguated by setting the value of its “definition” attribute.

- -

Examples

- -

The “Matrix” class can be used to represent for instance: -- A 3D 3×3 stress tensor -- A 4D 4×4 homogeneous affine transformation matrix

- -

In particular it is often used to specify the orientation of an object relative to another one, like for instance the attitude of a plane relative to the earth.

-
-
- - -8.5.3.<tab/>DataStream Class -

The “DataStream” class has a structure similar than the “DataArray” class but is not a data component (i.e. it does not derive from “AbstractDataComponent”) and thus cannot be used as a child of other aggregate components. Below is its UML diagram:

- -
-Figure 32 — DataStream Class -
- -

This class should be used as the wrapper object to define a complete data stream. It defines a data stream as containing a list of elements with an arbitrary complex structure. An important feature is that the data stream can be open ended (i.e. the number of elements is not known in advance) and is thus designed to support real time streaming of data.

- -

Element Count

- -

The “elementCount” attribute is optional and can be used to indicate the number of elements in the stream if it is known. This is done by instantiating an instance of the “Count” class whose “value” attribute would be set to the number of elements.

- -

Element Type

- -

The “elementType” attribute is used to define the structure of each element in the stream. The data component used as the element type and all of its children shall be used solely as data descriptors, meaning that they shall not include any inline values. These values will instead be block encoded in the “values” attribute of the parent “DataStream”.

- -

Encoding and Values

- -

The “encoding” and “values” fields are there to provide the stream values as an efficient block which can be encoded in several ways. The same encoding methods as for the “DataArray” class are available and are described in Clauses 8.7 and 8.8. The “values” attribute is optional as the DataStream class can be used as a simple descriptor.

- - - -

Requirement 48

Identifier/req/uml-block-components/datastream-array-valid
Statement

Data components that are children of an instance of the ”DataStream” class shall be used solely used as data descriptors. Their values shall never be included inline since they will be block encoded in the stream described by the ”DataStream”.

-
-
- - -8.6.<tab/>Requirements Class: Geometry Components Package - - -

Requirements class 6: Geometry Components UML Package

Identifier/req/uml-geom-components
Target typeSoftware Implementation or Encoding of the Conceptual Models
PrerequisiteRequirements class 2: /req/uml-simple-components
- -

This package defines an additional component for representing simple feature geometries, as defined by OGC 06-103r4, within an encoded SWE Common data block or stream.

- - - -

Requirement 49

Identifier/req/uml-geom-components/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Geometry Components” UML package.

- - -8.6.1.<tab/>Geometry Class -

The “Geometry” class extends the “AbstractDataComponent” class with a value of type geometry and a constraint that can be used to limit the types of allowed geometries. This class is shown on the following UML diagram:

- -
-Figure 33 — Geometry Class -
- -

Coordinate Reference System

- -

The “crs” attribute provides the URI of the coordinate reference system w.r.t which the geometry coordinates are expressed. The unit of the coordinates is also provided by the coordinate reference system.

- - - -

Requirement 50

Identifier/req/uml-geom-components/srs-valid
Statement

The “srs” attribute shall reference the definition of a valid 2D or 3D spatial reference system.

- -

Constraints

- -

The “constraint” attribute is used to restrict the possible geometries that can be provided using this component when it is used as a descriptor. The constraint is provided using the “AllowedGeometries” class that includes a list of allowed geometry types.

- -

Value

- -

The value of this component must be a geometry instance, whether it’s provided inline using the “value” attribute, or as part of a datastream.

- - - -

Requirement 51

Identifier/req/uml-geom-components/geom-value-valid
Statement

The “value” attribute shall be one of the concrete geometry value classes defined in OGC 06-103r4: “Point”, “MultiPoint”, “LineString”, “MultiLineString”, “Polygon”, or “MultiPolygon”.

- -NOTE

Encoding sections in this standard define how the geometry value is encoded:

- -
  • GML in the XML implementation and XML encoding rules

    -
  • -
  • GeoJSON in the JSON implementation and JSON encoding rules

    -
  • -
  • WKT in the Text encoding rules

    -
  • -
  • WKB in the Binary encoding rules

    -
  • -
-
-
-
- - -8.7.<tab/>Requirements Class: Simple Encodings Package - - -

Requirements class 7: Simple Encodings UML Package

Identifier/req/uml-simple-encodings
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.6: /conf/uml-simple-encodings
PrerequisiteRequirements class 1: /req/core
- -

Encoding methods describe how structured array and stream data is encoded into a low level byte stream (see related concepts in Clause 7.6). Once encoded as a sequence of bytes, the data can then be transmitted using various digital means such as files on a disk or network connections.

- -

This package includes two classes that provide definitions of simple encoding methods. They are used as descriptors of the method used to encode data component values wrapped by aggregate classes defined in the “Block Components” package. There model is shown on the diagram below:

- -
-Figure 34 — Simple Encodings -
- - - -

Requirement 52

Identifier/req/uml-simple-encodings/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Simple Encodings” UML package.

- -

All classes defining encoding methods derive from a common abstract class called “AbstractEncoding”. Extensions to this standard that define new encoding methods shall derive encoding classes from this abstract class.

- -

The intent of this standard is to provide a set of core encodings covering most common needs. Each encoding has specific benefits that match the needs of different applications. Sometimes several encodings of the same dataset can be offered in order to satisfy several types of consumers and/or use cases.

- -

In the model provided in this standard, the encoding specification is provided separately from the data component tree describing the dataset structure, thus enabling several encodings to be applied to the same data structure without changing it.

- - -8.7.1.<tab/>TextEncoding Class -

The “TextEncoding” class defines a method allowing encoding arbitrarily complex data using a text based delimiter separated values (DSV) format. The class used to specify this encoding method is shown below:

- -
-Figure 35 — TextEncoding Class -
- -

The “tokenSeparator” attribute specifies the characters to use for separating each scalar value from one another. Scalar values appear sequentially in the stream alternatively with the token separator characters, in an order unambiguously defined by the data component structure. The detailed rules are given in the implementation Clause 10.3.

- -

The “blockSeparator” attribute specifies characters used to mark the end of a “block”, corresponding to the complete structure defined by the data component tree (in a “DataArray”, “Matrix” or “DataStream” one block corresponds to one element, that is to say the structure defined by the “elementType” property). Stream or array data can then be composed of several blocks of the same type separated by block separator characters.

- -

The “decimalSeparator” attribute specifies the character used as the decimal point in decimal number. This attribute is optional and the default is a period (‘.’).

- -

Example

- -

In the case of a “DataStream” with an element type that is a “DataRecord” containing three fields – one of type “Category” and two of type “Quantity” — a data stream encoded using the Text method would look like the following:

- -

STATUS_OK,24.5,1022.5¶
-STATUS_OK,24.5,1022.5¶
-STATUS_OK,24.5,1022.5¶

- -

Where , (comma) is the token separator and (carriage return) is the block separator (i.e. this is the CSV format). -Note that there could be many more values in a single block if the data set has a large number of fields, or if it contains an array of values.

-
- -

The “collapseWhiteSpaces” attribute is a boolean flag used to specify if extra white spaces (including line feeds, tabs, spaces and carriage returns) surrounding the token and block separators should be ignored (skipped) when processing the stream. This is useful for encoded blocks of data that are embedded in an XML document, since formatting (indenting with spaces or tabs especially) is often done in XML content.

- -

This type of encoding is used when compactness is important but balanced by a desire of human readability. This type of encoding is easily readable (for debugging or manual usage) as well as easily imported in various spreadsheet, charting or scientific software.

- -

The main drawback of such an encoding is the impossibility of locating an error in the stream with certitude. Secondly, if only one expected value is missing, the whole block is usually lost since the parser cannot resynchronize correctly before the next block separator. This last issue can however be solved by transmitting this type of encoded stream using error resilient protocols when needed.

-
-
- - -8.8.<tab/>Requirements Class: Advanced Encodings Package - - -

Requirements class 8: Advanced Encodings UML Package

Identifier/req/uml-advanced-encodings
Target typeSoftware Implementation or Encoding of the Conceptual Models
Conformance classConformance class A.7: /conf/uml-advanced-encodings
PrerequisiteRequirements class 7: /req/uml-simple-encodings
- -

This package defines an additional encoding method for packaging sensor data as raw or base 64 binary blocks. When this package is implemented, the binary encoding method is usable, as any other encoding method, within the “DataArray” and “DataStream” classes.

- - - -

Requirement 53

Identifier/req/uml-advanced-encodings/package-fully-implemented
Statement

The encoding or software shall correctly implement all classes defined in the “Advanced Encodings” UML package.

- - -8.8.1.<tab/>BinaryEncoding Class -

The “BinaryEncoding” class defines a method that allows encoding complex structured data using primitive data types encoded directly at the byte level, in the same way that they are usually represented in memory.

- -

The binary encoding method can lead to very compact streams that can be optimized for efficient parsing and fast random access. However this comes with the lack of human readability of the data and sometimes lack of compatibility with other software (i.e. software that is not SWE Common enabled).

- -

More information is needed to fully define a binary encoding, so the model is more complex than the other encodings. It is shown below:

- -
-Figure 36 — BinaryEncoding Class -
- -

The main class “BinaryEncoding” specifies overall characteristics of the encoded byte stream such as the byte order (big endian or little endian) and the byte encoding (raw or base64). The two corresponding attributes, respectively “byteOrder” and “byteEncoding” are mandatory. Base64 encoding is usually chosen to insert binary content within an XML document.

- -

The “byteLength” attribute is optional and can be used to specify the overall length of the encoded data as a total number of bytes. This should be indicated whenever possible if the data size is known in advance as it can be useful for efficient memory allocation.

- -

The “BinaryEncoding” class also has several “member” attributes that contain detailed information about parts of the data stream. This attribute can take a choice of instance of two classes: “Component” or “Block”.

- -

The “Component” class is used to specify binary encoding details of a given scalar component in the stream. The following information can be provided for each scalar field:

- -
  • The “ref” attribute allows identifying the data component in the dataset structure for which we’re specifying the encoding parameters. Soft-typed property names are used to uniquely identify a given component in the tree.

    -
  • -
  • The “dataType” attribute allows selecting a data type among commonly accepted ones such as ‘byte’, ‘short’, ‘int’, ‘long’, ‘double’, ‘float’, ‘string’, etc…

    -
  • -
  • The “byteLength” or “bitLength” attributes are mutually exclusive and used to further specify the length of the data type in the case where it is not a standard length (i.e. to encode integer numbers on more than 8 bytes or less than 8 bits for instance).

    -
  • -
  • The “significantBits” can be used to signal that only some of the bits of the data type are actually used to carry the value (i.e. a value may be encoded as a byte but only use 4 bits to encode a value between 0 and 15). This is mostly informational.

    -
  • -
  • The “encryption” attribute can be used to select the method with which the value is encrypted before being written to the stream.

    -
  • -
- -

The “Block” class is used to specify binary encoding details of a given aggregate component representing a block of values in the data stream. This is used either to specify padding before and/or after a block of data or to enable compression or encryption of all or part of a dataset.

- -
  • The “ref” attribute allows identifying the data component in the dataset structure for which we’re specifying the encoding parameters. Soft-typed property names are used to uniquely identify a given component in the tree.

    -
  • -
  • The optional “byteLength” attribute allows indicating the overall length of the encoded block to facilitate memory allocation.

    -
  • -
  • The “paddingBytes-before” and “paddingBytes-after” are used to specify the number of empty bytes (i.e. usually 0 bytes) that are inserted in the stream respectively before and after data for the referenced component. This is sometimes used to align data on N-bytes block for faster access.

    -
  • -
  • The “encryption” attribute identifies the encryption method that is used to encrypt the block of data before it is inserted in the stream.

    -
  • -
  • The “compression” attribute identifies the compression method that is used to compress the block of data before it is inserted in the stream.

    -
  • -
- -

This standard does not define any concrete encryption and compression methods, so that software implementations of this requirement class are not required to support any value in the “encryption” and “compression” attributes of the “Component” and “Block” classes. Extensions of this standard that define binary encryption and compression methods shall describe how the encrypted or compressed data is inserted in the SWE Common data stream.

-
-
-
- - -9.<tab/>JSON Implementation (normative) -

This standard defines a normative JSON implementation of the conceptual models presented in Clause 8. The standardization target type for all requirements classes in this clause is a JSON instance document that seeks compliance with this JSON encoding model.

- -

JSON schemas defined in this section are a direct implementation of the UML conceptual models described in Clause 8. They have been generated from these models by strictly following well-defined encoding rules. All attributes and composition/aggregation associations contained in the UML models are encoded as JSON object members.

- -

All JSON examples given in this section are informative and are used solely for illustrating features of the normative model. Many of these examples reference semantic information by using URLs that resolve to the following online ontologies:

- -
  • The OGC online registry at .

    -
  • -
  • The QUDT quantity kinds ontology at .

    -
  • -
  • The SWEET ontology maintained by ESIP at .

    -
  • -
  • The MMI ontology registry and repository at .

    -
  • -
- -

Some of the JSON examples contain inline values while others don’t. This is meant to illustrate that the component objects defined by the JSON implementation can be used as value objects for properties of larger metadata objects (e.g. SensorML system descriptions), but can also be used as descriptors to describe, for instance, the content of a datastream or the rangeset of a coverage.

- - -9.1.<tab/>Requirements Class: Basic Types and Simple Components JSON Schemas - - -

Requirements class 9: Basic Types and Simple Components JSON Schemas

Identifier/req/json-simple-components
Target typeJSON Document
PrerequisiteRequirements class 2: /req/uml-simple-components
- -

Validation patterns that implement all classes defined respectively in the “Basic Types” and “Simple Components” UML packages are provided as JSON schema files at .

- -

The entry point schema used for validation is “sweCommon.json”.

- - - -

Requirement 54

Identifier/req/json-simple-components/schema-valid
Statement

The JSON document instance shall be valid with respect to the JSON schema “sweCommon.json”.

- - -9.1.1.<tab/>General JSON Principles -

The following rules were used when generating the JSON schemas:

- -
  • Classes are implemented as JSON Objects;

    -
  • -
  • Any property with a multiplicty greater than one is implemented as a JSON Array and its name is converted to plural form;

    -
  • -
  • Textual fields are implemented as a JSON String;

    -
  • -
  • Decimal fields are implemented as a union of JSON Number and JSON String value types (the string value allowing for special values, see Clause 9.1.2);

    -
  • -
  • ISO8601 date/time fields are implemented as a JSON String with a union of date/time formats.

    -
  • -
-
- - -9.1.2.<tab/>Special Numerical Values -

JSON does not define special decimal values for ‘Not a Number’, positive infinity and negative infinity. It is thus necessary to encode them as strings.

- - - -

Requirement 55

Identifier/req/json-simple-components/special-numerical-values
Statement

The special JSON Strings NaN, -Infinity and +Infinity shall be allowed as the inline or out-of-band value for Quantity and Time (and Count?) components (except when the Time component uses the ISO 8601 format).

- -NOTE

These special value strings have been chosen because they are supported natively by Javascript/ECMA Script implementations. The + unary operator can be used to transparently parse one of these strings to a Number type (see ).

- -

These values also correspond to infinities and NaN values defined in IEEE 754-2008.

-
-
- - -9.1.3.<tab/>Abstract Base Classes -

The three abstract base classes defined in the UML models are implemented by the following JSON schemas:

- -
  • AbstractSweIdentifiable.json

    -
  • -
  • AbstractDataComponent.json

    -
  • -
  • AbstractSimpleComponent.json

    -
  • -
- - - -

Requirement 56

Identifier/req/json-simple-components/definition-resolvable
Statement

The “definition” object member defined in the “AbstractDataComponent.json” schema shall contain a URI that can be resolved to the complete human readable definition of the property that is represented by the data component.

- - - -

Requirement 57

Identifier/req/json-simple-components/inline-value-constraint-valid
Statement

The inline value included in a JSON instance validating against the “AbstractSimpleComponent.json” schema shall satisfy the constraints specified by this instance.

-
- - -9.1.4.<tab/>Boolean Object -

The “Boolean” object is the JSON schema implementation of the “Boolean” UML class defined in Clause 8.2.4. The schema for this class is provided in Boolean.json.

- -

The following snippet shows an example boolean component with an inline value:

- -{ - "type": "Boolean", - "definition": "http://sweet.jpl.nasa.gov/2.0/physDynamics.owl#Motion", - "label": "Motion Detected", - "description": "True when motion was detected in the room", - "value": true -} - - -

The next snippet is an example of boolean component used as data descriptor, hence with no value:

- -{ - "type": "Boolean", - "definition": "http://mmisw.org/ont/q2o/test/timeContinuityTest", - "label": "Time Continuity Test", - "description": "Set to true to enable time continuity test" -} - -
- - -9.1.5.<tab/>Text Object -

The “Text” object is the JSON schema implementation of the “Text” UML class defined in Clause 8.2.5. The schema for this class is provided in Text.json.

- -

Constraints on a “Text” representation are expressed using the AllowedTokens Object.

- -

The following snippets show how the “Text” component can be used to define human readable text fields, as well as any other alpha-numerical properties:

- -{ - "type": "Text", - "definition": "http://sensorml.com/ont/swe/property/Manufacturer", - "label": "Manufacturer", - "value": "Ocean Devices, Inc." -} - - -{ - "type": "Text", - "definition": "http://sensorml.com/ont/x-swe/property/VehicleRegistrationNumber", - "label": "License Plate", - "value": "45ER-EJK-235" -} - - -

Constraints can also be used — typically when the component is used as a descriptor — to limit the possible text values, either by enumeration or a regular expression pattern:

- -{ - "type": "Text", - "definition": "http://sensorml.com/ont/x-swe/property/VehicleRegistrationNumber", - "label": "License Plate", - "constraint": { - "pattern": "^[0-9][A-Z]{4}-[A-Z]{3}-[0-9]{3}$" - } -} - - -NOTE

This standard does not define any limit on the size of the text data than can be included as the value of a “Text” component, either inline or as part of a datastream. Implementations are responsible for documenting this upper limit.

-
-
- - -9.1.6.<tab/>Category Object -

The “Category” object is the JSON schema implementation of the “Category” UML class defined in Clause 8.2.6. The schema for this class is provided in Category.json.

- -

Constraints on a “Category” representation are expressed using the AllowedTokens Object.

- -

The following examples illustrate how the “Category” component is used to define various fields with categorical representations. The categorical scale is defined either via a code space, an enumeration constraint, or both (in which case the enumeration constraint defines a subset of possible values from a code space):

- -{ - "type": "Category", - "definition": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#GeologicTime", - "label": "Geological Period", - "description": "Name of the geological period according to the nomenclature of the International Commission on Stratigraphy", - "codeSpace": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#Period", - "value": "Jurassic" -} - - -{ - "type": "Category", - "definition": "http://sweet.jpl.nasa.gov/2.0/biol.owl#Species", - "label": "Bird Species", - "description": "Bird species according to the classification of the World Bird Database", - "codeSpace": "http://www.birdlife.org/datazone/species/index.html" -} - -
- - -9.1.7.<tab/>Count Object -

The “Count” object is the JSON schema implementation of the “Count” UML class defined in Clause 8.2.7. The schema for this class is provided in Count.json.

- -

Constraints on a “Count” representation are expressed using the AllowedValues Object.

- -

The following snippet shows a “Count” component used to define the size of a row in a raster dataset:

- -{ - "type": "Count", - "definition": "http://www.opengis.net/def/property/OGC/0/NumberOfPixels", - "label": "Row Size", - "description": "Number of pixels in each row of the image", - "value": 1024 -} - -
- - -9.1.8.<tab/>Quantity Object -

The “Quantity” object is the JSON schema implementation of the “Quantity” UML class defined in Clause 8.2.8. The schema for this class is provided in Quantity.json.

- -

Constraints on a “Quantity” representation are expressed using the AllowedValues Object.

- -

The unit of measure is defined using either a URI or a code expressed using the Unified Code for Units of Measure (UCUM) standard.

- - - -

Requirement 58

Identifier/req/json-simple-components/ucum-code-used
Statement

Whenever it can be constructed using the UCUM specification, the unit of measure shall be specified using a UCUM code as the value of the “uom/code” property. Otherwise the “uom/href” property shall be used to reference an external unit definition.

- -

The following snippets show how “Quantity” components are used to define various (observable or controllable) properties with continuous decimal representations:

- -{ - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Temperature", - "label": "Outside Temperature", - "description": "Outside temperature taken at the top of the antenna", - "uom": { "code": "Cel" }, - "value": 21.5 -} - - -{ - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/SpectralRadiance", - "label": "Radiance", - "description": "Radiance measured on band1", - "uom": { "code": "W.m-2.Sr-1.um-1" }, - "value": 2.83e-2 -} - - -{ - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/HeightAboveMSL", - "referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/5714", - "axisID": "H", - "label": "MSL Height", - "description": "Height above mean sea level", - "uom": { "code": "m" } -} - -
- - -9.1.9.<tab/>Time Object -

The “Time” object is the JSON schema implementation of the “Time” UML class defined in Clause 8.2.9. The schema for this class is provided in Time.json.

- -

Constraints on a “Time” representation are expressed using the AllowedTimes Object.

- -

The unit of measure is defined using either a URI or a code expressed using the Unified Code for Units of Measure (UCUM) standard. When the temporal property is provided in the ISO 8601:2019 format, this is indicated by using a specific URI.

- - - -

Requirement 59

Identifier/req/json-simple-components/iso8601-uom-used
Statement

When ISO 8601 notation is used to express the value associated to a “Time” element, the URI “http://www.opengis.net/def/uom/ISO-8601/0/Gregorian” shall be used as the value of the “uom/href” property.

- -

The following snippets show how “Time” components are used to define various temporal properties, with different time scales:

- -

ISO8601 formatted time stamp based on the UTC time standard:

- -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC-EO/0/MissionStartTime", - "referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC", - "localFrame": "urn:org:systems:001#MISSION-START-TIME", - "label": "Flight Time", - "description": "Time at take-off in UTC", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - }, - "value": "2009-01-26T10:21:45+01:00" -} - - -

ISO8601 formatted time stamp based on the GPS time standard:

- -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/USNO/0/GPS", - "label": "Sampling Time", - "description": "Time at which the measurement was made", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - }, - "value": "2009-11-05T16:29:26Z" -} - - -

Time stamp in seconds past the Unix epoch:

- -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/RunTime", - "referenceTime": "1970-01-01T00:00:00Z", - "label": "Model Run Time", - "description": "Run time of the model expressed as a Unix time", - "uom": {"code": "s" }, - "value": 1257415633 -} - - -

Time stamp in seconds past a custom time reference called MISSION_START_TIME:

- -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC-EO/0/ScanStartTime", - "referenceFrame": "urn:org:systems:001#MISSION-START-TIME", - "localFrame": "urn:org:systems:001#SCAN-START-TIME", - "label": "Scanline Time", - "description": "Acquisition time of the scan line", - "uom": { "code": "s" } -} - -
- - -9.1.10.<tab/>CategoryRange Object -

The “CategoryRange” object is the JSON schema implementation of the “CategoryRange” UML class defined in Clause 8.2.11. The schema for this class is provided in CategoryRange.json.

- -

“CategoryRange” objects share most properties with “Category” object, as shown on the following snippet:

- -{ - "type": "CategoryRange", - "definition": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#GeologicTime", - "label": "Approximate Dating", - "description": "Approximate geological dating expressed as a range of geological eras", - "codeSpace": "http://sweet.jpl.nasa.gov/2.0/timeGeologic.owl#Era", - "value": ["Paleozoic", "Mesozoic"] -} - -
- - -9.1.11.<tab/>CountRange Object -

The “CountRange” object is the JSON schema implementation of the “CountRange” UML class defined in Clause 8.2.12. The schema for this class is provided in CountRange.json.

- -

“CountRange” objects share most properties with “Count” object, as shown on the following snippet:

- -{ - "type": "CountRange", - "definition": "http://www.opengis.net/def/property/OGC/0/ArrayIndex", - "label": "Index Range", - "value": [0, 3000] -} - -
- - -9.1.12.<tab/>QuantityRange Object -

The “QuantityRange” object is the JSON schema implementation of the “QuantityRange” UML class defined in Clause 8.2.13. The schema for this class is provided in QuantityRange.json.

- -

“QuantityRange” objects share most properties with the “Quantity” object, as shown on the following snippet:

- -{ - "type": "QuantityRange", - "definition": "http://mmisw.org/ont/mmi/device/OperationalRange", - "label": "Operational Range", - "description": "Operational temperature range of the cryogenic thermometer", - "uom": { "code": "K" }, - "value": [10, 300] -} - -
- - -9.1.13.<tab/>TimeRange Object -

The “TimeRange” object is the JSON schema implementation of the “TimeRange” UML class defined in Clause 8.2.14. The schema for this class is provided in TimeRange.json.

- -

“TimeRange” objects share most properties with the “Time” object, as shown on the following snippet:

- -{ - "type": "TimeRange", - "definition": "http://www.opengis.net/def/property/EO/0/SurveyPeriod", - "referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC", - "label": "Survey Period", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - }, - "value": ["2008-01-05T11:02:54Z", "2009-11-05T16:29:26Z"] -} - -
- - -9.1.14.<tab/>NilValues Object -

The “NilValues” object is the JSON schema implementation of the “NilValues” UML class defined in Clause 8.2.16. Schema patterns for this class are provided in basicTypes.json. Several sub-patterns are defined for the decimal, integer and text cases.

- -

Examples of NIL values definitions are provided below, in the case of numerical, countable and textual representations:

- -{ - "type": "Quantity", - "definition": "http://sweet.jpl.nasa.gov/2.0/physRadiation.owl#IonizingRadiation", - "label": "Radiation Dose", - "description": "Radiation dose measured by Gamma detector", - "uom": { "code": "uR" }, - "nilValues": [ - { "reason": "http://www.opengis.net/def/nil/OGC/0/BelowDetectionRange", "value": "-Infinity" }, - { "reason": "http://www.opengis.net/def/nil/OGC/0/AboveDetectionRange", "value": "Infinity" } - ] -} - - -{ - "type": "Count", - "definition": "http://sweet.jpl.nasa.gov/2.0/physRadiation.owl#Radiance", - "label": "Band 1", - "nilValues": [ - { "reason": "http://www.opengis.net/def/nil/OGC/0/BelowDetectionRange", "value": 0 }, - { "reason": "http://www.opengis.net/def/nil/OGC/0/AboveDetectionRange", "value": 255 } - ] -} - - -{ - "type": "Text", - "definition": "http://sensorml.com/ont/x-swe/property/VehicleRegistrationNumber", - "label": "License Plate", - "nilValues": [ - { "reason": "http://www.opengis.net/def/nil/OGC/0/Missing", "value": "Missing" }, - { "reason": "http://www.opengis.net/def/nil/OGC/0/Unknown", "value": "Unknown" } - ] -} - -
- - -9.1.15.<tab/>AllowedTokens Object -

The “AllowedTokens” object is the JSON schema implementation of the “AllowedTokens” UML class defined in Clause 8.2.17. The schema for this class is provided in basicTypes.json (see #definitions/AllowedTokens).

- -

Examples of constraints for textual or categorical properties are provided below:

- -{ - "type": "Text", - "definition": "http://sensorml.com/ont/swe/property/ModelNumber", - "label": "Model Number", - "constraint": { - "pattern": "^[0-9][A-Z]{3}[0-9]{2}S1$" - } -} - - -{ - "type": "Category", - "definition": "http://www.opengis.net/def/property/OGC/0/SensorStatus", - "label": "Sensor Status", - "description": "Current connection status of the sensor", - "constraint": { - "values": [ "Off", "Stand-by", "Ready", "Busy" ] - } -} - -
- - -9.1.16.<tab/>AllowedValues Object -

The “AllowedValues” object is the JSON schema implementation of the “AllowedValues” UML class defined in Clause 8.2.18. The schema for this class is provided in basicTypes.json (see #definitions/AllowedValues).

- -

Examples of constraints for various numerical properties are provided below:

- -{ - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Angle", - "label": "Planar Angle", - "uom": { "code": "deg" }, - "constraint": { - "intervals": [[-180, 180]] - } -} - - -{ - "type": "Count", - "definition": "http://www.opengis.net/def/property/OGC/0/NumberOfPixels", - "label": "Image Width", - "constraint": { - "values": [256, 512, 1024] - } -} - - -{ - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude", - "label": "Latitude", - "uom": { "code": "deg" }, - "constraint": { - "intervals": [[-90, 90]], - "significantFigures": 6 - } -} - - -

Numerical constraints can also be unbounded:

- -{ - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/RadialDistance", - "label": "Radial Distance", - "description": "Radial distance is always positive", - "uom": { "code": "m" }, - "constraint": { - "intervals": [[0, "+Infinity"]] - } -} - -
- - -9.1.17.<tab/>AllowedTimes Object -

The “AllowedTimes” object is the JSON schema implementation of the “AllowedTimes” UML class defined in Clause 8.2.19. The schema for this class is provided in basicTypes.json (see #definitions/AllowedTimes).

- -

Examples of constraints for various temporal properties, expressed as ISO-8601 or decimal values, are provided below:

- -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/USNO/0/GPS", - "label": "Acquisition Time", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - }, - "constraint": { - "intervals": [["2009-01-01T00:00:00Z", "+Infinity"]] - } -} - - -{ - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "urn:org:systems:001#SCAN-START-TIME", - "label": "Lidar Pulse Time", - "description": "Time stamp of LiDAR pulse relative to start of scan", - "uom": { "code": "ms" }, - "constraint": { - "intervals": [[0, 1e6]] - } -} - -
-
- - -9.2.<tab/>Requirements Class: Record Components JSON Schema - - -

Requirements class 10: Record Components JSON Schema

Identifier/req/json-record-components
Target typeJSON Document
PrerequisitesRequirements class 3: /req/uml-record-components
Requirements class 9: /req/json-simple-components
- - -9.2.1.<tab/>DataRecord Object -

The “DataRecord” object is the JSON schema implementation of the “DataRecord” UML class defined in Clause 8.3.1. The schema for this class is provided in DataRecord.json.

- -

The example below describes a record composed of weather data fields. In this case the “DataRecord” element is used as a descriptor for records of data that are provided as part of a datastream:

- -{ - "type": "DataRecord", - "label": "Weather Data Record", - "fields": [ - { - "name": "time", - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC", - "label": "Sampling Time", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - } - }, - { - "name": "temperature", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/air_temperature", - "label": "Air Temperature", - "uom": { "code": "Cel" } - }, - { - "name": "pressure", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/air_pressure_at_mean_sea_level", - "label": "Air Pressure", - "uom": { "code": "mbar" } - }, - { - "name": "windSpeed", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/wind_speed", - "label": "Wind Speed", - "uom": { "code": "km/h" } - }, - { - "name": "windDirection", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/wind_to_direction", - "label": "Wind Direction", - "uom": { "code": "deg" } - } - ] -} - - -{ - "type": "DataRecord", - "definition": "urn:x-ogc:def:property:CSM::RadialDistortionCoefficients", - "label": "Radial Distortion Coefficients", - "fields": [ - { - "name": "k1", - "type": "Quantity", - "definition": "urn:x-ogc:def:property:CSM::DISTOR_RAD1", - "label": "Coef k1", - "uom": { "code": "mm-2" }, - "value": 1.92709e-5 - }, - { - "name": "k2", - "type": "Quantity", - "definition": "urn:x-ogc:def:property:CSM::DISTOR_RAD2", - "label": "Coef k2", - "uom": { "code": "mm-2" }, - "value": -5.14206e-10 - }, - { - "name": "k3", - "type": "Quantity", - "definition": "urn:x-ogc:def:property:CSM::DISTOR_RAD3", - "label": "Coef k3", - "uom": { "code": "mm-2" }, - "value": -3.33356e-12 - } - ] -} - -
- - -9.2.2.<tab/>Vector Object -

The “Vector” object is the JSON schema implementation of the “Vector” UML class defined in Clause 8.3.2. The schema for this class is provided in Vector.json.

- -{ - "type": "Vector", - "definition": "http://www.opengis.net/def/property/OGC/0/PlatformLocation", - "referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/4326", - "label": "Platform Location", - "coordinates": [ - { - "name": "lat", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude", - "label": "Latitude", - "axisID": "Lat", - "uom": { "code": "deg" }, - "value": 45.36 - }, - { - "name": "lon", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Longitude", - "label": "Longitude", - "axisID": "Lon", - "uom": { "code": "deg" }, - "value": 5.2 - } - ] -} - - -{ - "type": "Vector", - "definition": "http://qudt.org/vocab/quantitykind/LinearVelocity", - "referenceFrame": "http://www.opengis.net/def/crs/OGC/0/ECI_J2000", - "label": "Platform Velocity", - "coordinates": [ - { - "name": "vx", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Speed", - "label": "Velocity X", - "uom": { "code": "m/s" } - }, - { - "name": "vy", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Speed", - "label": "Velocity Y", - "uom": { "code": "m/s" } - }, - { - "name": "vz", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Speed", - "label": "Velocity Z", - "uom": { "code": "m/s" } - } - ] -} - - -{ - "type": "Vector", - "definition": "http://sensorml.com/ont/swe/property/RotationQuaternion", - "referenceFrame": "http://www.opengis.net/def/crs/OGC/0/ECI_J2000", - "localFrame": "urn:org:systems:001#PLATFORM_FRAME", - "label": "Platform Orientation", - "coordinates": [ - { - "name": "qx", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Coordinate", - "label": "QX", - "uom": { "code": "1" } - }, - { - "name": "qy", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Coordinate", - "label": "QY", - "uom": { "code": "1" } - }, - { - "name": "qz", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Coordinate", - "label": "QZ", - "uom": { "code": "1" } - }, - { - "name": "qw", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Coordinate", - "label": "QW", - "uom": { "code": "1" } - } - ] -} - -
-
- - -9.3.<tab/>Requirements Class: Choice Components JSON Schema - - -

Requirements class 11: Choice Components JSON Schema

Identifier/req/json-choice-components
Target typeJSON Document
PrerequisitesRequirements class 4: /req/uml-choice-components
Requirements class 9: /req/json-simple-components
- - -9.3.1.<tab/>DataChoice Object -

The “DataChoice” object is the JSON schema implementation of the “DataChoice” UML class defined in Clause 8.4.1. The schema for this class is provided in DataChoice.json.

- -{ - "type": "DataChoice", - "label": "Weather Data Message", - "items": [ - { - "name": "TEMP", - "type": "DataRecord", - "label": "Temperature Measurement", - "fields": [ - { - "name": "time", - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC", - "label": "Sampling Time", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - } - }, - { - "name": "temp", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/air_temperature", - "label": "Air Temperature", - "uom": { "code": "Cel" } - } - ] - }, - { - "name": "PRESS", - "type": "DataRecord", - "label": "Pressure Measurement", - "fields": [ - { - "name": "time", - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/BIPM/0/UTC", - "label": "Sampling Time", - "uom": { - "href": "http://www.opengis.net/def/uom/ISO-8601/0/Gregorian" - } - }, - { - "name": "press", - "type": "Quantity", - "definition": "http://mmisw.org/ont/cf/parameter/air_pressure_at_mean_sea_level", - "label": "Air Pressure", - "uom": { "code": "HPa" } - } - ] - } - ] -} - -
-
- - -9.4.<tab/>Requirements Class: Block Components JSON Schema - - -

Requirements class 12: Block Components JSON Schema

Identifier/req/json-block-components
Target typeJSON Document
PrerequisitesRequirements class 5: /req/uml-block-components
Requirements class 9: /req/json-simple-components
- - -9.4.1.<tab/>DataArray Object -

The “DataArray” element is the JSON schema implementation of the “DataArray” UML class defined in Clause 8.5.1. The schema for this class is provided in DataArray.json.

- -{ - "type": "DataArray", - "label": "Calibration Table", - "elementType": { - "name": "point", - "type": "DataRecord", - "label": "Data Point", - "fields": [ - { - "name": "t", - "type": "Quantity", - "definition": "https://qudt.org/vocab/quantitykind/Temperature", - "label": "Temperature", - "uom": { "code": "Cel" } - }, - { - "name": "r", - "type": "Quantity", - "definition": "https://qudt.org/vocab/quantitykind/Resistance", - "label": "Resistance", - "uom": { "code": "KOhm" } - } - ] - }, - "values": [ - {"t": 12, "r": 3.03}, - {"t": 30.1, "r": 1.68}, - {"t": 40.0, "r": 1.16}, - {"t": 50.1, "r": 0.85}, - {"t": 59.8, "r": 0.62} - ] -} - - -

When provided inline, “DataArray” values are encoded using the method defined in Clause 9.4.4.

- -

The following example shows how to define a 1D variable size array whose data is provided separately.

- -{ - "type": "DataArray", - "definition": "http://sensorml.com/ont/swe/property/Trajectory", - "label": "Mobile Trajectory", - "elementCount": { - "definition": "http://www.opengis.net/def/property/OGC/0/NumberOfPoints", - "label": "Implicit Size" - }, - "elementType": { - "name": "point", - "type": "Vector", - "definition": "http://www.opengis.net/def/property/OGC/0/PlatformLocation", - "referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/4326", - "label": "Location Point", - "coordinates": [ - { - "name": "lat", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude", - "label": "Latitude", - "axisID": "Lat", - "uom": { "code": "deg" } - }, - { - "name": "lon", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Longitude", - "label": "Longitude", - "axisID": "Lon", - "uom": { "code": "deg" } - } - ] - } -} - - -

“DataArray” components can also be nested to form multi-dimensional arrays, as shown in the following example of a 2D array:

- -{ - "type": "DataArray", - "definition": "http://sensorml.com/ont/swe/property/RasterImage", - "label": "Satellite Image", - "elementCount": { - "definition": "http://www.opengis.net/def/property/OGC/0/NumberOfRows", - "value": 3000 - }, - "elementType": { - "name": "row", - "type": "DataArray", - "definition": "http://sensorml.com/ont/swe/property/RasterImage", - "elementCount": { - "definition": "http://www.opengis.net/def/property/OGC/0/NumberOfSamples", - "value": 3000 - }, - "elementType": { - "name": "pixel", - "type": "DataRecord", - "definition": "http://sensorml.com/ont/swe/property/GridCell", - "fields": [ - { - "name": "band1", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Radiance", - "label": "Radiance", - "description": "Radiance measured on band1", - "uom": { "code": "W.m-2.Sr-1" } - }, - { - "name": "band2", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Radiance", - "label": "Radiance", - "description": "Radiance measured on band2", - "uom": { "code": "W.m-2.Sr-1" } - }, - { - "name": "band3", - "type": "Quantity", - "definition": "http://qudt.org/vocab/quantitykind/Radiance", - "label": "Radiance", - "description": "Radiance measured on band3", - "uom": { "code": "W.m-2.Sr-1" } - } - ] - } - } -} - -
- - -9.4.2.<tab/>Matrix Object -

The “Matrix” object is the JSON schema implementation of the “Matrix” UML class defined in Clause 8.5.2. The schema for this class is provided in Matrix.json.

- -{ - "type": "Matrix", - "definition": "http://sensorml.com/ont/swe/property/RotationMatrix", - "referenceFrame": "http://www.opengis.net/def/crs/OGC/0/ECI_J2000", - "label": "3D Orientation Matrix", - "elementType": { - "name": "row", - "type": "Matrix", - "elementType": { - "name": "coef", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Coordinate", - "label": "Matrix Coef", - "uom": { "code": "1" } - } - }, - "values": [ - [0.36,0.48,-0.8], - [-0.8,0.6,0], - [0.48,0.64,0.6] - ] -} - - -

When provided inline, “Matrix” values are encoded using the method defined in Clause 9.4.4.

-
- - -9.4.3.<tab/>DataStream Object -

The “DataStream” object is the JSON schema implementation of the “DataStream” UML class defined in Clause 8.5.3. The schema for this class is provided in DataStream.json.

- -{ - "type": "DataStream", - "label": "Aircraft Navigation", - "elementType": { - "name": "navData", - "type": "DataRecord", - "fields": [ - { - "type": "Time", - "definition": "http://www.opengis.net/def/property/OGC/0/SamplingTime", - "referenceFrame": "http://www.opengis.net/def/trs/USNO/0/GPS", - "referenceTime": "1970-01-01T00:00:00Z", - "label": "Sampling Time", - "uom": { "code": "s" } - }, - { - "name": "location", - "type": "Vector", - "definition": "http://www.opengis.net/def/property/OGC/0/PlatformLocation", - "referenceFrame": "http://www.opengis.net/def/crs/EPSG/0/4979", - "label": "Platform Location", - "coordinates": [ - { - "name": "lat", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/GeodeticLatitude", - "label": "Latitude", - "axisID": "Lat", - "uom": { "code": "deg" } - }, - { - "name": "lon", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/Longitude", - "label": "Longitude", - "axisID": "Lon", - "uom": { "code": "deg" } - }, - { - "name": "alt", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/HeightAboveEllipsoid", - "label": "Altitude", - "axisID": "h", - "uom": { "code": "m" } - } - ] - }, - { - "name": "attitude", - "type": "Vector", - "definition": "http://www.opengis.net/def/property/OGC/0/PlatformOrientation", - "referenceFrame": "http://www.opengis.net/def/cs/OGC/0/ENU", - "label": "Platform Attitude", - "coordinates": [ - { - "name": "heading", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/TrueHeading", - "label": "Heading", - "axisID": "Z", - "uom": { "code": "deg" } - }, - { - "name": "pitch", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/PitchAngle", - "label": "Pitch", - "axisID": "X", - "uom": { "code": "deg" } - }, - { - "name": "roll", - "type": "Quantity", - "definition": "http://sensorml.com/ont/swe/property/RollAngle", - "label": "Roll", - "axisID": "Y", - "uom": { "code": "deg" } - } - ] - } - ] - }, - "encoding": { - "type": "TextEncoding", - "tokenSeparator": ",", - "blockSeparator": "\n", - "decimalSeparator": "." - } -} - - -

When provided inline, “DataStream” values are encoded using the method defined in Clause 9.4.4.

-
- - -9.4.4.<tab/>Inline Value Blocks -

This clause specifies how inline vaues for “DataArray”, “Matrix” and “DataStream” components shall be encoded when provided within a JSON document. No other method is allowed within a JSON document compliant with this standard.

- -

However, when values are provided separately from the component description (e.g. when datastream values are provided separately), any encoding methods defined in Clause 10 can be used.

- -

Inline block component values shall always be wrapped using JSON Arrays.

-
-
- - -9.5.<tab/>Requirements Class: Geometry Components JSON Schema - - -

Requirements class 13: Geometry Components JSON Schema

Identifier/req/json-geom-components
Target typeJSON Document
PrerequisitesRequirements class 6: /req/uml-geom-components
Requirements class 9: /req/json-simple-components
- - -9.5.1.<tab/>Geometry Object -

The “Geometry” object is the XML schema implementation of the “Geometry” UML class defined in Clause 8.6.1. The schema for this class is provided in Geometry.json.

- -{ - "type": "Geometry", - "definition": "http://sensorml.com/ont/swe/property/TargetLocation", - "srs": "http://www.opengis.net/def/crs/EPSG/0/4326", - "label": "Target Location", - "description": "A point geometry", - "value": { - "type": "Point", - "coordinates": [12.34, 56.36] - } -} - -{ - "type": "Geometry", - "definition": "http://sensorml.com/ont/swe/property/Trajectory", - "srs": "http://www.opengis.net/def/crs/EPSG/0/4326", - "label": "Desired Trajectory", - "description": "Desired UxS trajectory defined as a line string", - "value": { - "type": "LineString", - "coordinates": [[12.34, 56.36], [12.45, 56.37], [12.45, 56.39], [12.34, 56.36]] - } -} - -{ - "type": "Geometry", - "definition": "http://sensorml.com/ont/x-swe/property/SurveillanceArea", - "srs": "http://www.opengis.net/def/crs/EPSG/0/4326", - "label": "Surveillance Area", - "description": "Desired UxS surveillance area defined as a polygon", - "value": { - "type": "Polygon", - "coordinates": [ - [[12.34, 56.36], [12.45, 56.37], [12.45, 56.39], [12.34, 56.36]] - ] - } -} - -
-
- - -9.6.<tab/>Requirements Class: Simple Encodings JSON Schema - - -

Requirements class 14: Simple Encodings JSON Schema

Identifier/req/json-simple-encodings
Target typeJSON Document
PrerequisitesRequirements class 14: /req/json-simple-encodings
Requirements class 18: /req/text-encoding-rules
Requirements class 17: /req/json-encoding-rules
- -

Validation patterns that implement classes defined respectively in the “Simple Encodings” UML packages are provided in the JSON schema encodings.json.

- -

When datastream or data array values are provided out-of-band (i.e. not inline in the “DataArray”, “Matrix” or “DataStream” description), a different encoding than JSON can be selected. This is specified by using one of the following classes.

- - -9.6.1.<tab/>TextEncoding Object -

The “TextEncoding” object is the JSON schema implementation of the “TextEncoding” UML class defined in Clause 8.7.1. The schema for this class is provided in encodings.json#/definitions/TextEncoding.

- -{ - "type": "TextEncoding", - "tokenSeparator": ",", - "blockSeparator": "\n", - "decimalSeparator": "." -} - -
-
- - -9.7.<tab/>Requirements Class: Advanced Encodings JSON Schema - - -

Requirements class 15: Advanced Encodings JSON Schema

Identifier/req/json-advanced-encodings
Target typeJSON Document
PrerequisitesRequirements class 8: /req/uml-advanced-encodings
Requirements class 14: /req/json-simple-encodings
Requirements class 19: /req/binary-encoding-rules
- -

This requirement class defines an additional encoding method that can be used to encode data values as raw or base64 binary blocks.

- - -9.7.1.<tab/>BinaryEncoding Object -

The “BinaryEncoding” object is the JSON schema implementation of the “BinaryEncoding” UML class defined in Clause 8.8.1. The schema for this class is provided in encondings.json#/definitions/BinaryEncoding.

- - - -

These elements allow for the detailed specification of the encoding parameters associated to components of the data description tree as discussed in Clause 8.8.1. The “ref” attribute takes a value of a particular syntax that allows pointing to any data component. The syntax is a ‘/’ separated list of component names, starting with the name of the root component and listed hierarchically. Each of these component names shall match the value of the “name” attribute defined in the data definition tree.

- - - -

Requirement 60

Identifier/req/xsd-advanced-encodings/ref-syntax-valid
Statement

The “ref” attribute of the “Component” and “Block” elements shall contain a hierarchical ‘/’ separated list of data component names.

- -

The “ref” attribute used on the “Component” element shall point exclusively to a scalar component.

- - - -

Requirement 61

Identifier/req/xsd-advanced-encodings/scalar-ref-component-valid
Statement

The “ref” attribute of a “Component” element shall reference a scalar or range component.

- -

This standard defines the list of data types that are allowed for scalar values when encoded with the binary encoding method. The corresponding URIs listed below shall be used as the value of the datatype attribute of an instance of the “Component” element.

- - - -

Requirement 62

Identifier/req/xsd-advanced-encodings/datatype-valid
Statement

The value of the “dataType” XML attribute of the “Component” element shall be one of the URIs listed in Table 1.

- -

These data types are specified in the normative table below:

- - -Table 1 — Allowed Binary Data Types - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Common NameURI to use in “dataType” attributeDescription
Signed Byte8-bits signed binary integer.
- Range: −128 to +127
Unsigned Byte8-bits unsigned binary integer.
- Range: 0 to +255
Signed Short16-bits signed binary integer.
- Range: −32,768 to +32,767
Unsigned Short16-bits unsigned binary integer.
- Range: 0 to +65,535
Signed Int32-bits signed binary integer.
- Range: −2,147,483,648 to +2,147,483,647
Unsigned Int32-bits unsigned binary integer.
- Range: 0 to +4,294,967,295
Signed Long64-bits signed binary integer.
- Range: −263 to +263 — 1
Unsigned Long64-bits unsigned binary integer.
- Range: 0 to +264 — 1
Half Precision - Float16-bits single precision floating point number as defined in IEEE 754.
Float32-bits single precision floating point number as defined in IEEE 754.
Double or
-
64-bits double precision floating point number as defined in IEEE 754.
Long Double128-bits quadruple precision floating point number as defined in IEEE 754.
UTF-8 String
- (Variable Length)

- “byteLength” attribute is not set.
Variable length string composed of a 2-bytes unsigned short value indicating its length followed by a sequence of UTF-8 encoded characters as specified by the Unicode Standard (2.5).
UTF-8 String*
- (Fixed Length)

- “byteLength” attribute is set.
Fixed length string composed of a sequence of UTF-8 encoded characters as specified by the Unicode Standard (2.5), and padded with 0 characters.
- -

The data type should be chosen so that its range allows the encoding of all possible values for a field (i.e. compatible with the field representation and constraints) including NIL values. This means that certain combinations of data type and components are not allowed. If a scalar component does not specify any constraint, any data type compatible with its representation can be used and it is the responsibility of the implementation to insure that all future values for the component will “fit” in the data type.

- - - -

Requirement 63

Identifier/req/xsd-advanced-encodings/datatype-compatible
Statement

The chosen data type shall be compatible with the scalar component representation, constraints and NIL values.

- -

Only data types marked with an asterisk allow the usage of the “byteLength” or “bitLength” attribute to customize their size. Usage of these attributes is forbidden on all other data types since their size is fixed and already specified in this standard (in the case of a variable length string, the size is included in the stream). This is enforced by a Schematron pattern.

- - - -

Requirement 64

Identifier/req/xsd-advanced-encodings/no-datatype-length
Statement

The “bitLength” and “byteLength” XML attributes shall not be set when a fixed size data type is used.

- -

The value of the “byteEncoding” XML attribute allows the selection of either the ‘raw’ or ‘base64’ encoding methods. When ‘base64’ is selected each byte is converted to its base 64 representation before it is included in encoded block, making it possible to include the values directly inline in the XML instance.

- -

The following binary encoded image data illustrates how the BinaryEncoding element is used to specify encoding options to each scalar value in the dataset:

-
-
-
- - -10.<tab/>Data Blocks and Streams Encoding Rules (normative) - -10.1.<tab/>Requirements Class: General Encoding Rules - - -

Requirements class 16: General Encoding Rules

Identifier/req/general-encoding-rules
Target typeEncoded Values Instance
Conformance classConformance class A.8: /conf/general-encoding-rules
Indirect prerequisiteRequirements class 7: /req/uml-simple-encodings
- -

All encodings defined in this standard follow general principles so that it is possible to implement them in a similar way.

- -

The way values are encoded is linked to the data structure specified using a hierarchy of data components. The values are included sequentially in the data stream by recursively processing all data components composing the dataset definition tree.

- - -10.1.1.<tab/>Rules for Scalar Components -

The value of each scalar component is encoded as a single scalar value. The actual binary representation of this scalar value depends on the encoding method. For example, in “TextEncoding”, a numerical value is represented by its string representation that usually span several bytes (e.g. ‘1.2345’ spans 6 bytes), why with the “BinaryEncoding” encode a similar value would likely be encoded as an IEEE 754 single precision floating-point format.

- -

The value of a “Time” component is encoded either as a decimal value or as a string in the case where a calendar representation or indeterminate value is used.

- -

When the value of a scalar component is NIL, the appropriate nil value is used in the stream and replaces the actual measurement value. This is always possible because nil values are required to be expressed with a data type that is compatible with the representation of the corresponding field.

-
- - -10.1.2.<tab/>Rules for Range Components -

The values of range components are encoded as a sequence of two successive values, first the lower bound of the range, then the upper bound. Each of these values is encoded exactly like the values of scalar components.

-
- - -10.1.3.<tab/>Rules for DataRecord and Vector -

Both “DataRecord” and “Vector” components are aggregates consisting of an ordered sequence of child components. The values contained in these aggregates are encoded by successively encoding each child component in the order in which they are listed in the XML description and including the resulting values sequentially in the stream.

- -

The definition of a “DataRecord” (or “Vector”) structure composed of N fields (or coordinates for vectors) can be represented in the following way:

- -
- -

The data block corresponding to such a structure would sequentially include all values for field 1, then all values for field 2, etc. until the last field is reached. Each field may consist of a single value if it is a scalar but may also consist of multiple values if it is itself an aggregate or a range component.

- - - -

Requirement 65

Identifier/req/general-encoding-rules/record-encoding-rule
Statement

“DataRecord” fields or “Vector” coordinates shall be encoded sequentially in a data block in the order in which these fields or coordinates are listed in the data descriptor.

-
- - -10.1.4.<tab/>Rules for DataChoice -

The “DataChoice” is an aggregate consisting of a choice of several child components called items. When values of a data choice are encoded, the resulting data block consists of two things: A token identifying the selecting item and the item values themselves. Only values of a single item can be encoded in each instance of a choice.

- -
- -

The data block corresponding to such a structure would then sequentially include the item identifier (i.e. the choice value) and then the value(s) for the selected item. The item may consist of a single value if it is a scalar or multiple values if it is itself an aggregate or a range component.

- - - -

Requirement 66

Identifier/req/general-encoding-rules/choice-encoding-rule
Statement

Encoded values for the selected item of a “DataChoice” shall be provided along with information that unambiguously identifies the selected item.

-
- - -10.1.5.<tab/>Rules for DataArray and Matrix -

The “DataArray” is an aggregate consisting of a number of repeated elements, all of the same type as defined by the element type. Values contained by a “DataArray” are encoded by sequentially including the values of each element.

- -

The definition of a “DataArray” (“Matrix”) structure composed of the array dimension and size and the element type definition. This can be represented in the following way:

- -
- -

The data block corresponding to such a structure would sequentially include the number representing the array size (only if it is variable) followed by one or more values corresponding to each array element. The number of values encoded for each element depends only on the array element definition, and the total number of values also depends on the array size.

- - - -

Requirement 67

Identifier/req/general-encoding-rules/array-encoding-rule
Statement

“DataArray” elements shall be encoded sequentially in a data block in the order of their index in the array (i.e. from low to high index).

- - - -

Requirement 68

Identifier/req/general-encoding-rules/array-size-encoding-rule
Statement

Encoded data for a variable size “DataArray” shall include a number specifying the array size whatever the encoding method used.

-
-
- - -10.2.<tab/>Requirements Class: JSON Encoding Rules - - -

Requirements class 17: JSON Encoding Rules

Identifier/req/json-encoding-rules
Target typeEncoded Values Instance
PrerequisiteRequirements class 16: /req/general-encoding-rules
Indirect prerequisiteRequirements class 7: /req/uml-simple-encodings
- -

The “JSON Encoding” method encodes field values by their JSON representation.

- - - -

Requirement 69

Identifier/req/json-encodings-rules/json-valid
Statement

Data blocks and datastreams encoded using the JSON Encoding rules shall be valid JSON documents as defined by IETF RFC 8259.

- -

The encoding rules defined in this document refer to JSON data types defined by IETF RFC 8259. Their definitions are recalled below:

- -

JSON Object: An object structure is represented as a pair of curly brackets surrounding zero or more name/value pairs (or members). Members are separated by commas. Each member must have a distinct name.

- -

JSON Array: An array structure is represented as square brackets surrounding zero or more values (or elements). Elements are separated by commas.

- -

JSON Number: A decimal or integer number represented in base 10, with a sign and optional exponent.

- -

JSON String: A string of Unicode characters that begins and ends with quotation marks.

- - -10.2.1.<tab/>Rules for Scalar Components -

Scalar components are encoded as specified in Table 2. Special numerical values allowed for “Quantity” and “Time” components are defined in Clause 9.1.2.

- - - -

Requirement 70

Identifier/req/json-encoding-rules/scalar-value-valid
Statement

The value of a scalar component shall be represented using a JSON Number, a JSON String, or a boolean literal value, as defined in Table 2.

- - -Table 2 — Simple Component to JSON Value Types Mapping - - - - - - - - - - - - - - - - - - - - - - - -
Component TypeJSON Value TypeExamples
BooleanBoolean literaltrue
- false
TextJSON String"word"
- "a full sentence"
- "BYC-589-AA"
CategoryJSON String"ON"
- "Paleozoic"
- "diesel"
CountJSON Number12
- 0
QuantityJSON Number, or
- JSON String with special numerical value.
12
- 23.1
- "NaN"
- "-Infinity"
- "+Infinity"
TimeJSON String with a ISO8601 date/time string, or - JSON Number, or
- JSON String with special numerical value.
"2023-03-15T12:45:56Z"
- -23.1
- 12
- "NaN"
- "-Infinity"
- "+Infinity"
-
- - -10.2.2.<tab/>Rules for Range Components -

A range component is encoded using a JSON array of two values.

- - - -

Requirement 71

Identifier/req/json-encoding-rules/range-value-valid
A

Values of range components shall be wrapped in a JSON Array with exactly 2 scalar values.

-
B

Each value is encoded in the same manner as the corresponding scalar component as defined in Table 2.

-
- - -Table 3 — Range Component to JSON Mapping - - - - - - - - - - - - -
Component TypeExamples
CategoryRange["Cenozoic", "Paleozoic"]
CountRange[0, 12]
QuantityRange[-12, 35]
- [-180.0, 180.0]
- ["-Infinity", 0.0]
- [10.0, "+Infinity"]
- ["NaN", "NaN"]
TimeRange["2023-01-01T00:00:00Z", "2023-03-15T12:45:56Z"]
- ["2023-01-01T00:00:00Z", "+Infinity"]
- ["-Infinity", "2023-01-01T00:00:00Z"]
- ["2023-01-01T00:00:00Z", "+Infinity"]
- ["NaN", "NaN"]
-
- - -10.2.3.<tab/>Rules for DataRecord and Vector -

“DataRecord” components are encoded using a JSON Object whose members are named like the record fields.

- - - -

Requirement 72

Identifier/req/json-encoding-rules/record-object-valid
A

“DataRecord” values shall be wrapped in a JSON Object.

-
B

The name of the JSON object members shall be the same as the “DataRecord” field names.

-
C

The value of each JSON Object member shall be chosen by following the encoding rules of the data component used as the record field with the same name.

-
D

If a record field is marked as ‘optional’, the corresponding JSON object member can be omitted or its JSON value can be set to null.

-
- - - -

Requirement 73

Identifier/req/json-encoding-rules/vector-object-valid
A

“Vector” values shall be wrapped in a JSON Object.

-
B

The name of the JSON object members shall be the same as the “Vector” coordinate names.

-
C

The value of each JSON Object member shall be chosen by following the encoding rules of the data component used as the vector coordinate field with the same name.

-
- -

When a field has its ‘optional’ flag set to true, its value can be either omitted or set to the literal value null.

- -

See the following examples:

- -
  • DataArray with inline values (curve)

    -
  • -
  • Datastream with records (weather data)

    -
  • -
  • Datastream with records and optional fields (navigation data)

    -
  • -
-
- - -10.2.4.<tab/>Rules for DataChoice -

Values of “DataChoice” components are encoded using a JSON Object with a single member whose name is the name of the selected choice item.

- - - -

Requirement 74

Identifier/req/json-encoding-rules/choice-object-valid
A

“DataChoice” values shall be encapsulated in a JSON Object.

-
B

The JSON object shall contain a single member whose name is the same as the selected choice item.

-
C

The JSON value of this unique member shall be chosen according to the encoding rules of the data component corresponding to the selected item.

-
- -

See example: Datastream with choice (navigation data)

-
- - -10.2.5.<tab/>Rules for DataArray and Matrix -

Values of “DataArray” and “Matrix” components are encoded using a JSON Array, containing as many elements as there are elements in the Array component.

- - - -

Requirement 75

Identifier/req/json-encoding-rules/array-values-valid
A

“DataArray” and “Matrix” values shall be encapsulated in a JSON Array.

-
B

Each array element shall be encoded using the rules corresponding to the data component used as the array element type.

-
- -

See the following examples:

- -
  • Fixed size 2D array (stress matrix)

    -
  • -
  • Datastream of variable size 1D arrays (profile series)

    -
  • -
-
- - -10.2.6.<tab/>Rules for Geometry -

The value of a “Geometry” component is encoded using a GeoJSON Geometry object.

- - - -

Requirement 76

Identifier/req/json-encodings-rules/geometry-valid
A

The value of a “Geometry” component shall be encoded as a GeoJSON Geometry Object, following rules defined by IETF RFC 7946.

-
B

The allowed GeoJSON geometry types shall be restricted to: Point, LineString, Polygon, MultiPoint, MultiLineString, and MultiPolygon

-
C

The number of dimensions of the GeoJSON geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component.

-
- -

See example: Datastream with geometry (feature detection)

-
- - -10.2.7.<tab/>JSON Schema -

In order to maximize compatibility with existing tools, A JSON Schema can be easily auto-generated from the Datastream description.

-
- - -10.2.8.<tab/>Media Types -

When array or datastream values are encoded with the JSON encoding method and provided standalone (i.e. outside of any wrapper format), one of the following media type identifiers shall be used:

- -
  1. One of application/json or application/swe+json shall be used as the content-type for files and HTTP reponses.

    -
  2. -
  3. application/swe+json shall be used for format negotiation between server and client (e.g. when the format is advertised by an API or web service). In particular, this media type shall be used in HTTP Accept and Link headers and in any server response used to advertise support or link to a resource encoded with this format.

    -
  4. -
- -

alternative would be application/vnd.ogc.swe+json

-
-
- - -10.3.<tab/>Requirements Class: Text Encoding Rules - - -

Requirements class 18: Text Encoding Rules

Identifier/req/text-encoding-rules
Target typeEncoded Values Instance
Conformance classConformance class A.9: /conf/text-encoding-rules
PrerequisiteRequirements class 16: /req/general-encoding-rules
Indirect prerequisiteRequirements class 7: /req/uml-simple-encodings
- -

The “TextEncoding” method encodes field values (especially numbers) by their text representation. Special characters provide a way to separate successive values and successive blocks. The ABNF syntax defined in IETF RFC 5234 is used to formalize the encoding rules, and thus all ABNF snippets provided in this section are normative.

- - - -

Requirement 77

Identifier/req/text-encodings-rules/abnf-syntax-valid
Statement

The encoded values block shall be formatted as defined by the ABNF grammar defined in this clause.

- - -10.3.1.<tab/>Separators -

Token separators are used between single values and the block separator is used at the end of each block. The block corresponds to one element of the “DataArray” or “DataStream” carrying the “values” element in which the values are encoded. There are no special separators to delimitate nested records, arrays and choices.

- -

Separators shall be chosen so that nothing in the dataset contains the exact same character sequence as the one chosen for token or block separator.

- - - -

Requirement 78

Identifier/req/text-encodings-rules/separators-valid
Statement

Block and token separators used in the “TextEncoding” method shall be chosen as a sequence of characters that never occur in the data values themselves.

- -

When the attribute “collapseWhiteSpaces” is set to true (its default value), all white space characters surrounding the token and block separators shall be ignored. The BNF grammar for separators is given below:

- -white-space = %d9 / %d10 / %d13 / %d32 ; TAB, LF, CR or SPACE - -token-separator-chars = < Value of the tokenSeparator attribute > - -block-separator-chars = < Value of the blockSeparator attribute > - -token-separator = [white-space] token-separator-chars [white-space] - -block-separator = [white-space] block-separator-chars [white-space] - - -

White spaces around separators are in fact only allowed when the “collapseWhiteSpaces” attribute is set to ‘true’ (which is the default).

-
- - -10.3.2.<tab/>Rules for Scalar Components -

The value for a scalar component is encoded as its text representation, following XML schema datatypes conventions.

- -scalar-value = xs:bool / xs:string / xs:double / xs:int / xs:date / xs:dateTime - - -

Nil values are included in the stream just like normal scalar values. Since their data type has to match the field data type, there is no special treatment necessary for a decoder or encoder. It is the responsibility of the application to match the data value against the list of registered nil values for a given field in order to detect if it is associated to a nil reason or if it is an actual measurement value.

-
- - -10.3.3.<tab/>Rules for Range Components -

Range components are encoded as a sequence of two tokens (each one representing a scalar value) separated by a token separator:

- -min-value = scalar-value - -max-value = scalar-value - -range-values = min-value token-separator max-value - -
- - -10.3.4.<tab/>Rules for DataRecord and Vector -

Values of fields of a “DataRecord” are recursively encoded following rules associated to the type of component used for the field’s description (i.e. scalar, record, array, etc.) and separated by token separators as expressed by the following grammar:

- -field-count = < Number of fields in the record minus one. Greater or equal to 0 > - -any-field-value = scalar-value / range-values / record-values / choice-values / array-values - -mandatory-field-value = any-field-value - -optional-field-value = (“Y” token-separator any-field-value) / “N” - -field-value = mandatory-field-value / optional-field-value - -record-values = field-value <field-count>*(token-separator field-value) - - -

When a field is marked as optional in the definition, the token ‘Y’ or ‘N’ shall be inserted in the data block. When the field value is omitted, the token ‘N’ is inserted alone. When it is included, the token ‘Y’ is inserted followed by the actual field value.

- - - -

Requirement 79

Identifier/req/text-encodings-rules/optional-field-marker-present
Statement

The ‘Y’ or ‘N’ token shall be inserted in a text encoded data block for all fields that have the “optional” attribute set to ‘true’.

- -

Coordinate values of “Vector” components are encoded with a similar syntax, but a coordinate value can only be scalar and cannot be omitted:

- -coord-count = < Number of coordinates in the vector minus one. Greater or equal to 0 > - -vector-values = scalar-value <coord-count>*(token-separator scalar-value) - - -

See the following examples:

- -
  • DataArray with inline values (curve)

    -
  • -
  • Datastream with records (weather data)

    -
  • -
  • Datastream with records and optional fields (navigation data)

    -
  • -
-
- - -10.3.5.<tab/>Rules for DataChoice -

A “DataChoice” is encoded with the text method by providing the name of the selected item before the item values themselves. The name used shall correspond to the “name” attribute of the “item” property element that describes the structure of the selected item.

- -selected-item-name = < Value of the “name” attribute of the item selected > -selected-item-values = scalar-value / range-values / record-values / choice-values / array-values -choice-values = selected-item-name token-separator selected-item-values - - - - -

Requirement 80

Identifier/req/text-encodings-rules/choice-selection-marker-valid
Statement

The selected-item-name token shall correspond to the value of the “name” attribute of the “item” property element that represents the selected item.

- -

See example: Datastream with choice (navigation data).

-
- - -10.3.6.<tab/>Rules for DataArray and Matrix -

Values of each “DataArray” or “Matrix” element are recursively encoded following rules associated to the type of component used for the element type (i.e. scalar, record, array, etc.). Groups of values (or single value in the case of a scalar element type) corresponding to each element are sequentially appended to the data block and separated by token or block separators, depending on the context: When the “DataArray” is the root of the component tree that is being encoded, its elements are separated by block separators, otherwise its elements are separated by token separators.

- -

A “DataArray” or “Matrix” can have a fixed or variable size, which leads to two slightly different syntaxes for encoding values: -array-separator = token-separator / block-separator ; block-separator is only used when the array is the root of the component tree whose values are being encoded.

- -array-values = fixed-size-array-values / variable-size-array-values - - -

Fixed size arrays have a size of at least one, and are encoded as defined below:

- -fixed-element-count = < Number of elements in a fixed size array minus one. Greater or equal to 0 since fixed size is always at least one > - -element-values = scalar-value / range-values / record-values / choice-values / array-values - -fixed-size-array-values = element-values <fixed-element-count>*(array-separator element-values) - - -

When a “DataArray” (“Matrix”) is defined as variable size, its size can be 0 and the array size is included as a token in the data block, before the actual array elements values are listed:

- -variable-element-count = < Number of elements in a variable size array. Greater or equal to 0 since variable size can be 0 for an empty array > - -variable-size-array-values = variable-element-count <variable-element-count>*(array-separator element-values) - - -

See the following examples:

- -
  • DataArray with inline values (curve)

    -
  • -
  • Fixed size 2D array (stress matrix)

    -
  • -
  • Datastream of variable size 1D arrays (profile series)

    -
  • -
-
- - -10.3.7.<tab/>Rules for DataStream -

Values of “DataStream” elements are encoded as a sequence of tokens in a way similar to how “DataArray” values are encoded. Groups of encoded values corresponding to one element of a “DataStream” are always separated by block separators, while all values within these groups are separated by token separators:

- -stream-element-count = < Number of elements in a data stream minus one. Greater or equal to 0 since the number of elements in a data stream is always at least one > - -stream-values = element-values <stream-element-count>*(block-separator element-values); - - -

Examples of “DataStream” with “TextEncoding” have already been given in previous sections.

-
- - -10.3.8.<tab/>Rules for Geometry -

The value of a “Geometry” component is encoded using the WKT format defined in the Simple Feature Access Standard (OGC 06-103r4).

- - - -

Requirement 81

Identifier/req/text-encodings-rules/geometry-valid
A

The value of a “Geometry” component shall be encoded using the WKT format defined in OGC 06-103r4, clause 7.

-
B

The WKT representation shall be either a “Two-Dimension Geometry WKT” (clause 7.2.2 of OGC 06-103r4) or a “Three-Dimension Geometry WKT” (clause 7.2.3 of OGC 06-103r4). The ‘M’ coordinate shall not be used.

-
C

The number of dimensions of the WKT geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component.

-
D

When a geometry value is included in a text-encoded datastream, the token separator shall not be the comma character (ASCII code 44) to avoid conflicting with commas used inside the WKT representation.

-
- -

See example: Datastream with geometry (feature detection)

-
- - -10.3.9.<tab/>Media Types -

When array or datastream values are encoded with the Text encoding method and provided standalone (i.e. outside of any wrapper format such as an XML document), one of the following media type identifiers shall be used:

- -
  1. One of text/plain, text/csv, or application/swe+text shall be used as the content-type for files and HTTP reponses.

    -
    • text/csv can be used only when the token separator is set to a single comma ‘,’ and the block separator is set to ‘CRLF’.

      -
    • -
    • text/plain and application/swe+text can be used for any combination of separators.

      -
    • -
    -
  2. -
  3. application/swe+text shall be used for format negotiation between server and client (e.g. when the format is advertised by an API or web service). In particular, this media type shall be used in HTTP Accept and Link headers and in any server response used to advertise support or link to a resource encoded with this format.

    -
  4. -NOTE

    It is recommended that the character set code be correctly appended to these media types if it differs from US-ASCII or UTF-8.

    -
- - - -

alternative would be application/vnd.ogc.swe+text

-
-
- - -10.4.<tab/>Requirements Class: Binary Encoding Rules - - -

Requirements class 19: Binary Encoding Rules

Identifier/req/binary-encoding-rules
Target typeEncoded Values Instance
Conformance classConformance class A.10: /conf/binary-encoding-rules
PrerequisiteRequirements class 16: /req/general-encoding-rules
Indirect prerequisiteRequirements class 8: /req/uml-advanced-encodings
- -

The “BinaryEncoding” method encodes field values by their binary representation. The ABNF syntax defined in IETF RFC 5234 is used to formalize the encoding rules, and thus all ABNF snippets provided in this section are normative.

- - - -

Requirement 82

Identifier/req/binary-encoding-rules/abnf-syntax-valid
Statement

The encoded values block shall be formatted as defined by the ABNF grammar defined in this clause.

- -

The encoding rules are similar to those of the “TextEncoding” method except that numerical values are encoded directly as their binary representation and that no separators are used. Separators are not needed because data types have either a fixed size or contain length information (See String encoding).

- - -10.4.1.<tab/>Rules for Scalar Components -

The value for a scalar component is encoded as its binary representation. This especially applies to numerical values that are encoded directly in binary form in accordance to the selected data type and the value of the “byteOrder” attribute.

- -scalar-value = < binary value encoded according to data type, byte encoding and byte order specifications > - - -

The last column of Table 1 in [xsd_binarycomponent_elt] indicates how each data type shall be binary encoded into a low level byte sequence. The actual order of bytes composing a multi-bytes data type depends on the value of the “byteOrder” attribute. The ‘bigEndian’ option indicates that muti-bytes data types are encoded with the most significant byte (MSB) first, while selecting ‘littleEndian’ signifies that encoding is done with the less significant byte (LSB) first. A UTF-8 string is not considered as a multi-byte data type and is always encoded in the same order, as specified by the Unicode Standard.

- - - -

Requirement 83

Identifier/req/binary-encoding-rules/type-encoding-valid
Statement

Binary data types in Table 1 shall be encoded according to their definition in the description column and the value of the “byteOrder” attribute.

- -

Nil values are included in the stream just like normal scalar values. Since their data type has to match the field data type, there is no special treatment necessary for a decoder or encoder. It is the responsibility of the application to match the data value against the list of registered nil values for a given field in order to detect if it is associated to a nil reason or if it is an actual measurement value.

- -

When the ‘raw’ byte encoding option is selected, bytes resulting from the data type encoding process defined above are inserted in the binary stream directly. This is refered to as ‘raw binary’ encoding. When the ‘base64’ option is selected, each byte resulting from the binary encoding process is also encoded in Base64 before being included in the stream. Scalar values can be Base 64 encoded one by one or by blocks as long as the resulting stream is compatible with requirements of IETF RFC 2045.

- - - -

Requirement 84

Identifier/req/binary-encoding-rules/base64-translation-applied
Statement

When the ‘base64’ encoding option is selected, binary data shall be encoded with the Base64 technique defined in IETF RFC 2045 Section 6.8: Base64 Content-Transfer-Encoding.

-
- - -10.4.2.<tab/>Rules for Range Components -

Range components are encoded as a sequence of two binary values (each one representing a scalar value):

- -min-value = scalar-value - -max-value = scalar-value - -range-values = min-value max-value - - -

Values are always included in the same order: The lower bound of the range first, followed by the upper bound.

-
- - -10.4.3.<tab/>Rules for DataRecord and Vector -

Values of fields of a “DataRecord” are recursively encoded following rules associated to the type of component used as the field’s description (i.e. scalar, record, array, etc.) and appended to the binary block:

- -field-count = < Number of fields in the record. Greater or equal to 1 > - -any-field-value = scalar-value / range-values / record-values / choice-values / array-values / block_values - -mandatory-field-value = any-field-value - -optional-field-value = (“Y” any-field-value) / “N” - -field-value = mandatory-field-value / optional-field-value - -record-values = <field-count>*field-values - - -

When a field is marked as optional in the definition, the 1-byte value ‘Y’ (ASCII code 89) or ‘N’ (ASCII code 78) shall be inserted in the data block. When the field value is omitted, the token ‘N’ is inserted alone. When it is included, the token ‘Y’ is inserted followed by the actual field value.

- - - -

Requirement 85

Identifier/req/binary-encoding-rules/optional-field-marker-present
Statement

The one byte ASCII character ‘Y’ or ‘N’ shall be inserted in a binary encoded data block for all “DataRecord” fields that have the “optional” attribute set to ‘true’.

- -

Coordinate values of “Vector” components are encoded with a similar syntax, but a coordinate value can only be scalar and cannot be omitted:

- -coord-count = < Number of coordinates in the vector. Greater or equal to 1 > - -vector-values = <coord-count>*scalar-value - - -

Vector coordinates cannot be optional.

-
- - -10.4.4.<tab/>Rules for DataChoice -

A “DataChoice” is encoded with the binary method by providing the zero-based index of the selected item before the item values themselves. The index value ranges from 0 for the first choice item to (number_of_items - 1) for the last item.

- -selected-item-idx = < Index of the item selected > - -selected-item-value = scalar-value / range-values / record-values / choice-values / array-values - -choice-values = selected-item-idx selected-item-value - - - - -

Requirement 86

Identifier/req/binary-encoding-rules/choice-selection-marker-valid
Statement

The value of the selected-item-idx flag shall be the zero-based index of the selected item (within the ordered list of items provided by the choice descriptor) and be encoded on a single unsigned byte.

-
- - -10.4.5.<tab/>Rules for DataArray and Matrix -

Values of each “DataArray” or “Matrix” element are recursively encoded following rules associated to the type of component used for the element type (i.e. scalar, record, array, etc.). Groups of values (or single value in the case of a scalar element type) corresponding to each element are sequentially appended to the data block. Since a “DataArray” or “Matrix” can have a fixed or variable size, two slightly different syntaxes for encoding values are possible:

- -array-values = fixed-size-array-values / variable-size-array-values - -element-value = scalar-value / range-values / record-values / choice-values / array-values / block_values - - -

Fixed size arrays have a size of at least one, and are encoded as defined below:

- -fixed-element-count = < Number of elements in a fixed size array > - -fixed-size-array-values = <fixed-element-count>*element-value - - -

When a “DataArray” (“Matrix”) is defined as variable size, its size can be 0 and the array size is included as a token in the data block, before the actual array elements values are listed:

- -variable-element-count = < Number of elements in a variable size array > - -variable-size-array-values = variable-element-count <variable-element-count>*element-value - - -

When the array size is 0, only this number is encoded and no element values are included in the data block.

-
- - -10.4.6.<tab/>Rules for DataStream -

Values of “DataStream” elements are encoded exactly as elements of an array:

- -stream-element-count = < Number of elements in a data stream > - -stream-values = <stream-element-count>*element-value - - -

A data stream usually contains at least one value but could be empty.

-
- - -10.4.7.<tab/>Rules for Geometry -

The value of “Geometry” is encoded using the WKB format defined in the Simple Feature Access Standard (OGC 06-103r4).

- - - -

Requirement 87

Identifier/req/binary-encodings-rules/geometry-valid
A

The value of a “Geometry” component shall be encoded using the WKB format defined in OGC 06-103r4, clause 8.

-
B

The WKB geometry type shall be one of the following types listed in OGC 06-103r4, clause 8.2.3, table 7: Point, LineString, Polygon, MultiPoint, MultiLineString, MultiPolygon, Point Z, LineString Z, Polygon Z, MultiPoint Z, MultiLineString Z, MultiPolygon Z. Other geometry type codes shall not be used.

-
C

The number of dimensions of the WKB geometry shall match the number of dimensions of the coordinate reference system identified by the “srs” attribute of the component.

-
- -

No specific marker or length information needs to be pre-pended to the binary representation since the WKB format is self descriptive and parsable without knowing the total length ahead of time.

-
- - -10.4.8.<tab/>Block encoded components -

When block encoding characteristics are also specified in the encoding description, the encryption and/or compression algorithm shall be applied after the binary encoding process described above is completed for the block. Extensions of this standard can define compression and encryption methods that fit the needs of particular communities.

- -

In order to maximize compatibility with existing software, when compressing a binary encoded data stream results in a well known binary format, the corresponding mime type can be used instead of application/octet-stream. For instance video/h264 can be used when the entirety of the dataset (presumably a video stream) is compressed using the H264 video codec.

-
- - -10.4.9.<tab/>Media Types -

When array or stream values are encoded with the Binary encoding method and provided standalone (i.e. outside of any wrapper format), one of the following media type identifiers shall be used:

- -
  1. One of application/octet-stream or application/swe-binary shall be used as the content-type for files and HTTP responses.

    -
  2. -
  3. application/swe+binary shall be used for format negotiation between server and client (e.g. when the format is advertised by an API or web service). In particular, this media type shall be used in HTTP Accept and Link headers and in any server response used to advertise support or link to a resource encoded with this format.

    -
  4. -
- -

alternative would be application/vnd.ogc.swe-binary

-
-
-
- - - - - - - - - - - -3.<tab/>Normative references

The following documents are referred to in the text in such a way that some or all of their content constitutes requirements of this document. For dated references, only the edition cited applies. For undated references, the latest edition of the referenced document (including any amendments) applies.

- - - - -Policy SWG: OGC 08-131r3, The Specification Model — Standard for Modular specifications. Open Geospatial Consortium (2009).https://portal.ogc.org/files/?artifact_id=34762&version=2OGC 08-131r3 -John Herring: OGC 06-103r4, OpenGIS Implementation Specification for Geographic information — Simple feature access — Part 1: Common architecture. Open Geospatial Consortium (2011). http://www.opengis.net/doc/is/sfa/1.2.1.http://www.opengis.net/doc/is/sfa/1.2.1https://portal.ogc.org/files/?artifact_id=25355OGC 06-103r4 -Linda van den Brink, Clemens Portele, Panagiotis (Peter) A. Vretanos: OGC 10-100r3, Geography Markup Language (GML) simple features profile (with Corrigendum). Open Geospatial Consortium (2011).https://portal.ogc.org/files/?artifact_id=42729OGC 10-100r3 -ISO: ISO 8601:2019, Date and time — Representations for information interchange — Part 1: Basic rules. International Organization for Standardization, Geneva (2019). .. ISO (2019).ISO 8601:2019 -ISO: ISO 8601:2019, Date and time — Representations for information interchange — Part 2: Extensions. International Organization for Standardization, Geneva (2019). .. ISO (2019).ISO 8601:2019 -ISO/IEC: ISO/IEC 11404:2007, Information technology. International Organization for Standardization, International Electrotechnical Commission, Geneva (2007). https://www.iso.org/standard/39479.html.https://www.iso.org/standard/39479.htmlhttps://www.iso.org/contents/data/standard/03/94/39479.detail.rsshttps://standards.iso.org/ittf/PubliclyAvailableStandards/index.htmlISO/IEC 11404:2007iso-reference ISO/IEC 11404:2007(E)URN urn:iso:std:iso-iec:11404:stage-90.92:ed-2 90 92 -ISO: ISO 19101-1:2014, Geographic information. International Organization for Standardization, Geneva (2014). https://www.iso.org/standard/59164.html.https://www.iso.org/standard/59164.htmlhttps://www.iso.org/contents/data/standard/05/91/59164.detail.rssISO 19101-1:2014iso-reference ISO 19101-1:2014(E)URN urn:iso:std:iso:19101:-1:stage-90.93:ed-1 90 93 -ISO: ISO 19103:2005, Conceptual Schema Language. ISO (2005).ISO 19103:2005 -ISO: ISO 19107:2003, Spatial Schema. ISO (2003).ISO 19107:2003 -ISO: ISO 19108:2002, Geographic information. International Organization for Standardization, Geneva (2002). https://www.iso.org/standard/26013.html.https://www.iso.org/standard/26013.htmlhttps://www.iso.org/contents/data/standard/02/60/26013.detail.rssISO 19108:2002iso-reference ISO 19108:2002(E)URN urn:iso:std:iso:19108:stage-90.93:ed-1 90 93 -ISO: ISO 19111:2007, Spatial Referencing by Coordinates. ISO (2007).ISO 19111:2007 -Unified Code for Units of Measure (UCUM), Version 2.1, November 2017, UCUM -Unicode Technical Std #18, Unicode Regular Expressions, Version 13, Aug. 2009Unicode -The Unicode Standard, Version 5.2, October 2009Unicode - -T. Bray (ed.): IETF RFC 8259, The JavaScript Object Notation (JSON) Data Interchange Format. RFC Publisher (2017). https://www.rfc-editor.org/info/rfc8259.https://www.rfc-editor.org/info/rfc8259IETF RFC 8259DOI 10.17487/RFC8259 -H. Butler, M. Daly, A. Doyle, S. Gillies, S. Hagen, T. Schaub: IETF RFC 7946, The GeoJSON Format. RFC Publisher (2016). https://www.rfc-editor.org/info/rfc7946.https://www.rfc-editor.org/info/rfc7946IETF RFC 7946DOI 10.17487/RFC7946 -M. Nottingham: IETF RFC 8288, Web Linking. RFC Publisher (2017). https://www.rfc-editor.org/info/rfc8288.https://www.rfc-editor.org/info/rfc8288IETF RFC 8288DOI 10.17487/RFC8288 -JSON Schema Validation: A Vocabulary for Structural Validation of JSON, Version 2020-12, IETF JSON Schema -N. Freed, N. Borenstein: IETF RFC 2045, Multipurpose Internet Mail Extensions (MIME) Part One: Format of Internet Message Bodies. RFC Publisher (1996). https://www.rfc-editor.org/info/rfc2045.https://www.rfc-editor.org/info/rfc2045IETF RFC 2045DOI 10.17487/RFC2045 -P. Overell: IETF RFC 5234, Augmented BNF for Syntax Specifications: ABNF. RFC Publisher (2008). https://www.rfc-editor.org/info/rfc5234.https://www.rfc-editor.org/info/rfc5234IETF RFC 5234DOI 10.17487/RFC5234 -IEEE: IEEE 754-2008, IEEE Standard for Floating-Point Arithmetic. Institute of Electrical and Electronics Engineers (2013). https://ieeexplore.ieee.org/document/4610935.https://ieeexplore.ieee.org/document/4610935IEEE 754-2008IEEE 754™-2008ISBN 978-0-7381-5752-8DOI 10.1109/IEEESTD.2008.4610935 -
-<strong>Annex A</strong><br/>(normative)<br/><strong>Conformance Class Abstract Test Suite</strong> - -A.1.<tab/>Core Conformance Classes - -A.1.1.<tab/>Conformance Class: Core Concepts - - -

Conformance class A.1

Identifier/conf/core
Requirements classRequirements class 1: /req/core
Target TypeDerived Models and Software Implementations
- - - -

Abstract test A.1: Core concepts are the base of all derived models

Identifier/conf/core/core-concepts-used
RequirementRequirement 1: /req/core/core-concepts-used
Test purpose

Verify that the target implementation correctly implements the core concepts.

-
DescriptionExample 1

Inspect the target implementation.

-
- - - -

Abstract test A.2: A boolean representation consists of a boolean value

Identifier/conf/core/boolean-rep-valid
RequirementRequirement 2: /req/core/boolean-rep-valid
Test purpose

Verify that the target implementation correctly implements the Boolean representation.

-
DescriptionExample 2

Inspect the target implementation.

-
- - - -

Abstract test A.3: A categorical representation consists of a token with a code space

Identifier/conf/core/categorical-rep-valid
RequirementRequirement 3: /req/core/categorical-rep-valid
Test purpose

Verify that the target implementation correctly implements the Categorical representation.

-
DescriptionExample 3

Inspect the target implementation.

-
- - - -

Abstract test A.4: A continuous numerical representation consists of a number with a scale

Identifier/conf/core/numerical-rep-valid
RequirementRequirement 4: /req/core/numerical-rep-valid
Test purpose

Verify that the target implementation correctly implements the Numerical representation.

-
DescriptionExample 4

Inspect the target implementation.

-
- - - -

Abstract test A.5: A countable representation consists of an integer number

Identifier/conf/core/countable-rep-valid
RequirementRequirement 5: /req/core/countable-rep-valid
Test purpose

Verify that the target implementation correctly implements the Countable representation.

-
DescriptionExample 5

Inspect the target implementation.

-
- - - -

Abstract test A.6: A textual representation is implemented as a character string

Identifier/conf/core/textual-rep-valid
RequirementRequirement 6: /req/core/textual-rep-valid
Test purpose

Verify that the target implementation correctly implements the Textual representation.

-
DescriptionExample 6

Inspect the target implementation.

-
- - - -

Abstract test A.7: A semantic definition of each property shall be provided

Identifier/conf/core/semantics-defined
RequirementRequirement 7: /req/core/semantics-defined
Test purpose

Verify that the target implementation allows attaching a semantic definition to all property representations.

-
DescriptionExample 7

Inspect the target implementation.

-
- - - -

Abstract test A.8: References to semantical information shall be resolvable

Identifier/conf/core/semantics-resolvable
RequirementRequirement 8: /req/core/semantics-resolvable
Test purpose

Verify that the target implementation encodes the semantic links in a way that they can be resolved to an actual concept definition.

-
DescriptionExample 8

Inspect the target implementation.

-
- - - -

Abstract test A.9: A temporal quantity is associated to a temporal reference frame

Identifier/conf/core/temporal-frame-defined
RequirementRequirement 9: /req/core/temporal-frame-defined
Test purpose

Verify that the target implementation allows providing a temporal reference frame along with any date/time quantity.

-
DescriptionExample 9

Inspect the target implementation.

-
- - - -

Abstract test A.10: A spatial quantity is associated to an axis of a spatial reference frame

Identifier/conf/core/spatial-frame-defined
RequirementRequirement 10: /req/core/spatial-frame-defined
Test purpose

Verify that the target implementation allows providing a spatial reference frame and axis along with any quantity that is projected along a spatial dimension.

-
DescriptionExample 10

Inspect the target implementation.

-
- - - -

Abstract test A.11: A NIL value maps a reserved value to a reason

Identifier/conf/core/nil-reasons-defined
RequirementRequirement 11: /req/core/nil-reasons-defined
Test purpose

Verify that the target implementation allows providing a reason along with each NIL (reserved) value.

-
DescriptionExample 11

Inspect the target implementation.

-
- - - -

Abstract test A.12: Aggregate data types are modeled according to ISO 11404

Identifier/conf/core/aggregates-model-valid
RequirementRequirement 12: /req/core/aggregates-model-valid
Test purpose

Verify that the target implementation models aggregate data types according to ISO 11404 definitions.

-
DescriptionExample 12

Inspect the target implementation.

-
- - - -

Abstract test A.13: Encoding methods shall be defined for all possible data structures

Identifier/conf/core/encoding-method-valid
RequirementRequirement 13: /req/core/encoding-method-valid
Test purpose

Verify that the target implementation provides encoding methods for all representations and all implemented data structures.

-
DescriptionExample 13

Inspect the target implementation.

-
-
-
- - -A.2.<tab/>UML Conformance Classes - -A.2.1.<tab/>Conformance Class: Basic Types and Simple Components UML Packages - - -

Conformance class A.2: Basic Types and Simple Components UML Packages

Identifier/conf/uml-simple-components
Requirements classRequirements class 2: /req/uml-simple-components
PrerequisiteConformance class A.1: /conf/core
Target TypeDerived Models and Software Implementations
- - - -

Abstract test A.14: Compliance with UML models defined in this package

Identifier/conf/uml-simple-components/package-fully-implemented
RequirementRequirement 14: /req/uml-simple-components/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
DescriptionExample 1

Inspect the model or software implementation.

-
- - - -

Abstract test A.15: Compliance with UML models defined in ISO 19103

Identifier/conf/uml-simple-components/iso19103-implemented
RequirementRequirement 15: /req/uml-simple-components/iso19103-implemented
Test purpose

Verify that the target implements all classes imported from ISO 19103 UML packages.

-
DescriptionExample 2

Inspect the model or software implementation.

-
- - - -

Abstract test A.16: Compliance with UML models defined in ISO 19108

Identifier/conf/uml-simple-components/iso19108-implemented
RequirementRequirement 16: /req/uml-simple-components/iso19108-implemented
Test purpose

Verify that the target implements all classes imported from ISO 19108 UML packages.

-
DescriptionExample 3

Inspect the model or software implementation.

-
- - - -

Abstract test A.17: A definition URI is mandatory on all simple components

Identifier/conf/uml-simple-components/definition-present
RequirementRequirement 17: /req/uml-simple-components/definition-present
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 4

Inspect the model or software implementation.

-
- - - -

Abstract test A.18: The value of the axisID and axisAbbrev attributes match

Identifier/conf/uml-simple-components/axis-valid
RequirementRequirement 18: /req/uml-simple-components/axis-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 5

Inspect the model or software implementation.

-
- - - -

Abstract test A.19: The axis ID is always specified on scalar spatial properties

Identifier/conf/uml-simple-components/axis-defined
RequirementRequirement 19: /req/uml-simple-components/axis-defined
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 6

Inspect the model or software implementation.

-
- - - -

Abstract test A.20: The reference frame is specified on scalar spatial properties not part of a vector

Identifier/conf/uml-simple-components/ref-frame-defined
RequirementRequirement 20: /req/uml-simple-components/ref-frame-defined
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 7

Inspect the model or software implementation.

-
- - - -

Abstract test A.21: The value of a component satisfies the constraints

Identifier/conf/uml-simple-components/value-constraint-valid
RequirementRequirement 21: /req/uml-simple-components/value-constraint-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 8

Inspect the model or software implementation.

-
- - - -

Abstract test A.22: All derived simple components have an optional value attribute

Identifier/conf/uml-simple-components/value-attribute-present
RequirementRequirement 22: /req/uml-simple-components/value-attribute-present
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 9

Inspect the model or software implementation.

-
- - - -

Abstract test A.23: The list of values allowed in a Category component is a subset of the code space

Identifier/conf/uml-simple-components/category-constraint-valid
RequirementRequirement 23: /req/uml-simple-components/category-constraint-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 10

Inspect the model or software implementation.

-
- - - -

Abstract test A.24: A Category component always specifies a list of possible values

Identifier/conf/uml-simple-components/category-enum-defined
RequirementRequirement 24: /req/uml-simple-components/category-enum-defined
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 11

Inspect the model or software implementation.

-
- - - -

Abstract test A.25: The value of a Category component is one defined in the code space

Identifier/conf/uml-simple-components/category-value-valid
RequirementRequirement 25: /req/uml-simple-components/category-value-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 12

Inspect the model or software implementation.

-
- - - -

Abstract test A.26: The temporal reference frame is defined

Identifier/conf/uml-simple-components/time-ref-frame-defined
RequirementRequirement 26: /req/uml-simple-components/time-ref-frame-defined
Test purpose

Verify that the implementation correctly assumes the default value when the attribute is not set.

-
DescriptionExample 13

Inspect the model or software implementation.

-
- - - -

Abstract test A.27: The time of reference is expressed relative to the origin of the reference frame

Identifier/conf/uml-simple-components/time-ref-time-valid
RequirementRequirement 27: /req/uml-simple-components/time-ref-time-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 14

Inspect the model or software implementation.

-
- - - -

Abstract test A.28: The local and reference frames of a Time component are different

Identifier/conf/uml-simple-components/time-local-frame-valid
RequirementRequirement 28: /req/uml-simple-components/time-local-frame-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 15

Inspect the model or software implementation.

-
- - - -

Abstract test A.29: Values of range components satisfy the same requirements as scalar values

Identifier/conf/uml-simple-components/range-value-valid
RequirementRequirement 29: /req/uml-simple-components/range-value-valid
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 16

Inspect the model or software implementation.

-
- - - -

Abstract test A.30: CategoryRange components satisfy all requirements of a Category component

Identifier/conf/uml-simple-components/category-range-valid
RequirementRequirement 30: /req/uml-simple-components/category-range-valid
Test purpose

Verify that the target implementation has constraints that enforce the requirement.

-
DescriptionExample 17

Inspect the model or software implementation. -Apply the following conformance tests to the “CategoryRange” class:

- -
  • Abstract test A.23: /conf/uml-simple-components/category-constraint-valid

    -
  • -
  • Abstract test A.24: /conf/uml-simple-components/category-enum-defined

    -
  • -
  • Abstract test A.25: /conf/uml-simple-components/category-value-valid

    -
  • -
-
- - - -

Abstract test A.31: The code space of a CategoryRange component is well-ordered

Identifier/conf/uml-simple-components/category-range-codespace-order
RequirementRequirement 31: /req/uml-simple-components/category-range-codespace-order
Test purpose

Verify that the code space contains elements that have a specific order (either implied or defined).

-
DescriptionExample 18

Inspect instances generated by the implementation of the “CategoryRange” class, including a codepace, to verify the requirement.

-
- - - -

Abstract test A.32: TimeRange components satisfy all requirements of the Time class

Identifier/conf/uml-simple-components/time-range-valid
RequirementRequirement 32: /req/uml-simple-components/time-range-valid
Test purpose

Verify that the target implementation has constraints that enforce the requirement.

-
DescriptionExample 19

Inspect the model or software implementation. -Apply the following conformance tests to the “TimeRange” class:

- -
  • Abstract test A.26: /conf/uml-simple-components/time-ref-frame-defined

    -
  • -
  • Abstract test A.27: /conf/uml-simple-components/time-ref-time-valid

    -
  • -
  • Abstract test A.28: /conf/uml-simple-components/time-local-frame-valid

    -
  • -
-
- - - -

Abstract test A.33: The reason attribute is a URI that is resolvable to a definition

Identifier/conf/uml-simple-components/nil-reason-resolvable
RequirementRequirement 33: /req/uml-simple-components/nil-reason-resolvable
Test purpose

Verify that the target implementation allows the value of a NIL reason identifier to be either:

-
  • a well known reason code defined by OGC

    -
  • -
  • a URI that can be resolved to the textual description of a custom reason.

    -
  • -
-
DescriptionExample 20

Inspect the model or software implementation.

-
- - - -

Abstract test A.34: Values reserved for NIL reasons are compatible with the component data type

Identifier/conf/uml-simple-components/nil-value-type-coherent
RequirementRequirement 34: /req/uml-simple-components/nil-value-type-coherent
Test purpose

Verify that the target implementation has a constraint that enforces the requirement.

-
DescriptionExample 21

Inspect the model or software implementation.

-
- - - -

Abstract test A.35: The scale of constraints is the same as the scale of the component value

Identifier/conf/uml-simple-components/allowed-values-unit-coherent
RequirementRequirement 35: /req/uml-simple-components/allowed-values-unit-coherent
Test purpose

Verify that numerical constraints are expressed with the correct scale.

-
DescriptionExample 22

Inspect instances generated by the implementation of the “Quantity”, “Count” and “Time” classes, including an “AllowedValues” constraint, to verify the requirement.

-
-
- - -A.2.2.<tab/>Conformance Class: Record Components UML Package - - -

Conformance class A.3: Record Components UML Package

Identifier/conf/uml-record-components
Requirements classRequirements class 3: /req/uml-record-components
PrerequisiteConformance class A.2: /conf/uml-simple-components
Target TypeDerived Models and Software Implementations
- - - -

Abstract test A.36: Compliance with UML models defined in this package

Identifier/conf/uml-record-components/package-fully-implemented
RequirementRequirement 36: /req/uml-record-components/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
DescriptionExample 1

Inspect the model or software implementation.

-
- - - -

Abstract test A.37: Each DataRecord field has a unique name

Identifier/conf/uml-record-components/record-field-name-unique
RequirementRequirement 37: /req/uml-record-components/record-field-name-unique
Test purpose

Verify that the implementation of the “DataRecord” class has a constraint that enforces the requirement.

-
DescriptionExample 2

Inspect the model or software implementation.

-
- - - -

Abstract test A.38: Each Vector coordinate has a unique name

Identifier/conf/uml-record-components/vector-coord-name-unique
RequirementRequirement 38: /req/uml-record-components/vector-coord-name-unique
Test purpose

Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.

-
DescriptionExample 3

Inspect the model or software implementation.

-
- - - -

Abstract test A.39: The reference frame is not specified on individual coordinates of a Vector

Identifier/conf/uml-record-components/vector-component-no-ref-frame
RequirementRequirement 39: /req/uml-record-components/vector-component-no-ref-frame
Test purpose

Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.

-
DescriptionExample 4

Inspect the model or software implementation. -The “referenceFrame” attribute shall be ommited from all data components used to define coordinates of a “Vector” instance.

-
- - - -

Abstract test A.40: The axis ID is specified on all coordinates of a Vector

Identifier/conf/uml-record-components/vector-component-axis-defined
RequirementRequirement 40: /req/uml-record-components/vector-component-axis-defined
Test purpose

Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.

-
DescriptionExample 5

Inspect the model or software implementation. -The “axisID” attribute shall be present on all data components used to define coordinates of a “Vector” instance.

-
- - - -

Abstract test A.41: The local and reference frames of a Vector component are different

Identifier/conf/uml-record-components/vector-local-frame-valid
RequirementRequirement 41: /req/uml-record-components/vector-local-frame-valid
Test purpose

Verify that the implementation of the “Vector” class has a constraint that enforces the requirement.

-
DescriptionExample 6

Inspect the model or software implementation.

-
-
- - -A.2.3.<tab/>Conformance Class: Choice Components UML Package - - -

Conformance class A.4: Choice Components UML Package

Identifier/conf/uml-choice-components
Requirements classRequirements class 4: /req/uml-choice-components
PrerequisiteConformance class A.2: /conf/uml-simple-components
Target TypeDerived Models and Software Implementations
- - - -

Abstract test A.42: Compliance with UML models defined in this package

Identifier/conf/uml-choice-components/package-fully-implemented
RequirementRequirement 42: /req/uml-choice-components/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
DescriptionExample 1

Inspect the model or software implementation.

-
- - - -

Abstract test A.43: Each DataChoice item has a unique name

Identifier/conf/uml-choice-components/choice-item-name-unique
RequirementRequirement 43: /req/uml-choice-components/choice-item-name-unique
Test purpose

Verify that the implementation of the “DataChoice” class has a constraint that enforces the requirement.

-
DescriptionExample 2

Inspect the model or software implementation.

-
-
- - -A.2.4.<tab/>Conformance Class: Block Components UML Package - - -

Conformance class A.5: Block Components UML Package

Identifier/conf/uml-block-components
Requirements classRequirements class 5: /req/uml-block-components
PrerequisiteConformance class A.2: /conf/uml-simple-components
Target TypeDerived Models and Software Implementations
- - - -

Abstract test A.44: Compliance with UML models defined in this package

Identifier/conf/uml-block-components/package-fully-implemented
RequirementRequirement 44: /req/uml-block-components/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
DescriptionExample 1

Inspect the model or software implementation.

-
- - - -

Abstract test A.45: Components nested in a block component are data descriptors

Identifier/conf/uml-block-components/array-component-no-value
RequirementRequirement 45: /req/uml-block-components/array-component-no-value
Test purpose

Verify that implementations of the block component classes have a constraint that enforces the requirement.

-
DescriptionExample 2

Inspect the model or software implementation. -Check that the “DataArray”, “Matrix” and “DataStream” classes have the constraint.

-
- - - -

Abstract test A.46: An encoding method is specified whenever an encoded data block is included

Identifier/conf/uml-block-components/array-values-properly-encoded
RequirementsRequirement 46: /req/uml-block-components/array-values-properly-encoded
Requirement 48: /req/uml-block-components/datastream-array-valid
Test purpose

Verify that the implementation of block component classes have a constraint that enforces the requirement.

-
DescriptionExample 3

Inspect the model or software implementation. -Check that the “DataArray”, “Matrix” and “DataStream” classes have the constraint. -Inspect instances of these classes generated by the implementation to verify that an encoding method is specified whenever there are encoded values present.

-
- - - -

Abstract test A.47: Elements of a matrix are of scalar types or nested matrices

Identifier/conf/uml-block-components/matrix-element-type-valid
RequirementRequirement 47: /req/uml-block-components/matrix-element-type-valid
Test purpose

Verify that the implementation of the “Matrix” class has a constraint that enforces the requirement.

-
DescriptionExample 4

Inspect the model or software implementation.

-
-
- - -A.2.5.<tab/>Conformance Class: Simple Encodings UML Package - - -

Conformance class A.6: Simple Encodings UML Package

Identifier/conf/uml-simple-encodings
Requirements classRequirements class 7: /req/uml-simple-encodings
PrerequisiteConformance class A.1: /conf/core
Target TypeDerived Models and Software Implementations
- - - -

Abstract test A.48: Compliance with UML models defined in this package

Identifier/conf/uml-simple-encodings/package-fully-implemented
RequirementRequirement 52: /req/uml-simple-encodings/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
DescriptionExample

Inspect the model or software implementation.

-
-
- - -A.2.6.<tab/>Conformance Class: Advanced Encodings UML Package - - -

Conformance class A.7: Advanced Encodings UML Package

Identifier/conf/uml-advanced-encodings
Requirements classRequirements class 8: /req/uml-advanced-encodings
PrerequisiteConformance class A.6: /conf/uml-simple-encodings
Target TypeDerived Models and Software Implementations
- - - -

Abstract test A.49: Compliance with UML models defined in this package

Identifier/conf/uml-advanced-encodings/package-fully-implemented
RequirementRequirement 53: /req/uml-advanced-encodings/package-fully-implemented
Test purpose

Verify that the target implements all classes in the UML package.

-
DescriptionExample

Inspect the model or software implementation.

-
-
-
- - -A.3.<tab/>Datastream Encoding Conformance Classes - -A.3.1.<tab/>Conformance Class: General Encoding Rules - - -

Conformance class A.8: General Encoding Rules

Identifier/conf/general-encoding-rules
Requirements classRequirements class 16: /req/general-encoding-rules
Target TypeEncoded Values Instance
- - - -

Abstract test A.50: DataRecord fields and Vector coordinates are encoded recursively

Identifier/conf/general-encoding-rules/record-encoding-rule
RequirementRequirement 65: /req/general-encoding-rules/record-encoding-rule
DescriptionExample 1

Verify that the sequence of scalar values (obtained after decoding the section of the encoded data block corresponding to the “DataRecord” or “Vector”) includes values for the successive fields/coordinates in the right order.

-
- - - -

Abstract test A.51: DataChoice selected item is properly encoded

Identifier/conf/general-encoding-rules/choice-encoding-rule
RequirementRequirement 66: /req/general-encoding-rules/choice-encoding-rule
DescriptionExample 2

Verify that the sequence of scalar values (obtained after decoding the section of the encoded data block corresponding to the “DataChoice”) includes a value identifying the selected item as well as values for the item itself.

-
- - - -

Abstract test A.52: DataArray elements are encoded recursively

Identifier/conf/general-encoding-rules/array-encoding-rule
RequirementRequirement 67: /req/general-encoding-rules/array-encoding-rule
DescriptionExample 3

Verify that the sequence of scalar values obtained after decoding the section of the encoded data block corresponding to the “DataArray” includes values for the successive elements of the array.

-
- - - -

Abstract test A.53: The length of variable size arrays is encoded in the data block

Identifier/conf/general-encoding-rules/array-size-encoding-rule
RequirementRequirement 68: /req/general-encoding-rules/array-size-encoding-rule
DescriptionExample 4

Verify that the sequence of values obtained after decoding the section of the encoded data block corresponding to a variable size “DataArray” includes a value specifying the size of the array.

-
-
- - -A.3.2.<tab/>Conformance Class: Text Encoding Rules - - -

Conformance class A.9: Text Encoding Rules

Identifier/conf/text-encoding-rules
Requirements classRequirements class 18: /req/text-encoding-rules
PrerequisiteConformance class A.8: /conf/general-encoding-rules
Target TypeEncoded Values Instance
- - - -

Abstract test A.54: Compliance with ABNF grammar

Identifier/conf/text-encoding-rules/abnf-syntax-valid
Requirement/req/text-encoding-rules/abnf-syntax-valid
DescriptionExample 1

Verify that the text encoded data block is correct with respect to the ABNF grammar corresponding to the particular dataset (The complete ABNF grammar of the dataset should be dynamically constructed from the ABNF snippets provided in the specification).

-
- - - -

Abstract test A.55: Separator characters are well chosen

Identifier/conf/text-encoding-rules/separators-valid
Requirement/req/text-encoding-rules/separators-valid
DescriptionExample 2

Verify that the values encoded in the data block never include the reserved separator characters. This can be detected by looking for invalid or superfluous values.

-
- - - -

Abstract test A.56: Special flags are inserted before optional component values

Identifier/conf/text-encoding-rules/optional-field-marker-present
Requirement/req/text-encoding-rules/optional-field-marker-present
DescriptionExample 3

Verify that the sequence of values corresponding to the optional field starts with the ‘Y’ or ‘N’ flag.

-
- - - -

Abstract test A.57: The name of a selected choice item is inserted in the stream

Identifier/conf/text-encoding-rules/choice-selection-marker-valid
Requirement/req/text-encoding-rules/choice-selection-marker-valid
DescriptionExample 4

Verify that the sequence of values corresponding to the “DataChoice” starts with a character string matching the name of one item of the choice descriptor.

-
-
- - -A.3.3.<tab/>Conformance Class: Binary Encoding Rules - - -

Conformance class A.10: Binary Encoding Rules

Identifier/conf/binary-encoding-rules
Requirements classRequirements class 19: /req/binary-encoding-rules
PrerequisiteConformance class A.8: /conf/general-encoding-rules
Target TypeEncoded Values Instance
- - - -

Abstract test A.58: Compliance with ABNF grammar

Identifier/conf/binary-encoding-rules/abnf-syntax-valid
RequirementRequirement 82: /req/binary-encoding-rules/abnf-syntax-valid
DescriptionExample 1

Verify that the binary encoded data block is correct with respect to the ABNF grammar of the particular dataset (The complete ABNF grammar of the dataset should be dynamically constructed from the ABNF snippets provided in the specification).

-
- - - -

Abstract test A.59: Data types are encoded as specified in this standard

Identifier/conf/binary-encoding-rules/type-encoding-valid
RequirementRequirement 83: /req/binary-encoding-rules/type-encoding-valid
DescriptionExample 2

Verify that valid and realistic scalar values are obtained when the binary data block is parsed by extracting the number of bits specified in the table and decoding the resulting bytes in the order specified by the “byteOrder” attribute. When the encoded data and the encoding parameters are not consistent, abberant values (such as -65502 for a temperature field, etc…) are usually obtained, which can be easily detected.

-
- - - -

Abstract test A.60: Base64 encoding is implemented as defined by IETF

Identifier/conf/binary-encoding-rules/base64-translation-applied
RequirementRequirement 84: /req/binary-encoding-rules/base64-translation-applied
DescriptionExample 3
  • Verify that only characters allowed by base64 encoding are used in the encoded data content.

    -
  • -
  • Verify that the data block can be properly parsed after the base64 data is decoded into a raw binary data stream.

    -
  • -
-
- - - -

Abstract test A.61: Special flags are inserted before optional component values

Identifier/conf/binary-encoding-rules/optional-field-marker-present
RequirementRequirement 85: /req/binary-encoding-rules/optional-field-marker-present
DescriptionExample 4
  • Verify that any optional field is preceded by the a 1-byte ASCII character with value ‘Y’ or ‘N’.

    -
  • -
  • Verify that the actual field value is only present if the flag has the ‘Y’ value.

    -
  • -
-
- - - -

Abstract test A.62: The name of a selected choice item is inserted in the stream

Identifier/conf/binary-encoding-rules/choice-selection-marker-valid
RequirementRequirement 86: /req/binary-encoding-rules/choice-selection-marker-valid
DescriptionExample 5
  • Verify that the sequence of bytes corresponding to the “DataChoice” starts with a byte value that is greater or equal to 0 and less than the total number of items defined in the choice descriptor.

    -
  • -
  • Verify that the parsed index value corresponds to the proper item in the choice descriptor.

    -
  • -
-
-
-
-
-<strong>Annex B</strong><br/>(informative)<br/><strong>Examples</strong> - -B.1.<tab/>Text Encoding Rules Examples - -B.1.1.<tab/>DataArray with inline values (curve) -

The following example shows how elements of an array defined as a “DataRecord” can be encoded inline with the text method:

- -<swe:DataArray definition="http://sweet.jpl.nasa.gov/2.0/mathFunction.owl#Function"> - <swe:description>Measurement error vs. temperature</swe:description> - <swe:elementCount> - <swe:Count> - <swe:value>5</swe:value> - </swe:Count> - </swe:elementCount> - <swe:elementType name="point"> - <swe:DataRecord> - <swe:label>Error vs. Temperature</swe:label> - <swe:field name="temp"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/physThermo.owl#Temperature"> - <swe:label>Temperature</swe:label> - <swe:uom code="Cel"/> - </swe:Quantity> - </swe:field> - <swe:field name="error"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/sciUncertainty.owl#Error"> - <swe:label>Relative Error</swe:label> - <swe:uom code="%"/> - </swe:Quantity> - </swe:field> - </swe:DataRecord> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator=" " tokenSeparator=","/> - </swe:encoding> - <swe:values>0,5 10,2 50,2 80,5 100,15</swe:values> -</swe:DataArray> - - -

In this example, each element consists of a record of two values. The array element structure also corresponds to one block so that tuples are separated by block separators (here the ‘,’ character). Since the array is of size 5, there are 5 tuples listed sequentially in the data block, each one composed of the two values of the data record separated by the token separator. The pattern is “temp,error temp,error …” since values have to be listed in the same order as the fields.

-
- - -B.1.2.<tab/>Datastream with records (weather data) -

The following snippet defines a datastream with an element of type record:

- -<swe:DataStream> - <swe:label>Weather Data</swe:label> - <swe:elementType name="weatherData"> - <swe:DataRecord> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime" - referenceFrame="http://www.opengis.net/def/trs/BIPM/0/UTC"> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="temp"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/air_temperature"> - <swe:label>Air Temperature</swe:label> - <swe:uom code="Cel"/> - </swe:Quantity > - </swe:field> - <swe:field name="press"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/air_pressure_at_mean_sea_level"> - <swe:label>Atmospheric Pressure</swe:label> - <swe:uom code="HPa"/> - </swe:Quantity > - </swe:field> - <swe:field name="windSpeed"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_speed"> - <swe:label>Wind Speed</swe:label> - <swe:uom code="km/h"/> - </swe:Quantity> - </swe:field> - <swe:field name="windDir"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_to_direction"> - <swe:label>Wind Direction</swe:label> - <swe:uom code="deg"/> - </swe:Quantity> - </swe:field> - </swe:DataRecord> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=","/> - </swe:encoding> -</swe:DataStream> - - -

The datastream records are encoded using the Text encoding method as shown below:

- -2023-03-20T15:40:00Z,15.3,1014,3.5,56.0 -2023-03-20T15:45:00Z,15.4,1015,5.6,123.0 -2023-03-20T15:50:00Z,15.8,1014,13.2,34.0 -... - -
- - -B.1.3.<tab/>Datastream with records and optional fields (navigation data) -

The following snippet defines a datastream with an element of type record that contains optional fields:

- -<swe:DataStream> - <swe:label>Aircraft Navigation</swe:label> - <swe:elementType name="navData"> - <swe:DataRecord> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime" - referenceFrame="http://www.opengis.net/def/trs/OGC/0/GPS"> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="speed"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/humanTransportAir.owl#GroundSpeed"> - <swe:uom code="m/s"/> - </swe:Quantity > - </swe:field> - <swe:field name="location"> - <swe:Vector optional="true" referenceFrame="http://www.opengis.net/def/crs/EPSG/0/4979"> - <swe:coordinate name="lat"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/spaceCoordinates.owl#Latitude" axisID="Lat"> - <swe:uom code="deg"/> - </swe:Quantity> - </swe:coordinate> - <swe:coordinate name="lon"> - <swe:Quantity definition=" http://sweet.jpl.nasa.gov/2.0/spaceCoordinates.owl#Longitude" axisID="Long"> - <swe:uom code="deg"/> - </swe:Quantity> - </swe:coordinate> - <swe:coordinate name="alt"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/spaceExtent.owl#Altitude" axisID="h"> - <swe:uom code="m"/> - </swe:Quantity> - </swe:coordinate> - </swe:Vector> - </swe:field> - </swe:DataRecord> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=","/> - </swe:encoding> -</swe:DataStream> - - -

The datastream records are encoded using the Text encoding method as shown below:

- -2007-10-23T15:46:12Z,15.3,Y,45.3,-90.5,311 -2007-10-23T15:46:22Z,25.3,N -2007-10-23T15:46:32Z,20.6,Y,45.3,-90.6,312 -2007-10-23T15:46:52Z,18.9,Y,45.4,-90.6,315 -2007-10-23T15:47:02Z,22.3,N -... - - -

In this example, the whole location “Vector” is marked as optional and thus the coordinate values are only included when the optional flag is set to ‘Y’ in the stream. Field values in each block have to be listed in the same order as the field properties in the record definition thus following the “time,speed,Y,lat,lon,alt” or “time,speed,N” pattern depending on whether or not the location is omitted.

-
- - -B.1.4.<tab/>Datastream with choice (navigation data) -

This is illustrated by the following example:

- -<swe:DataStream> - <swe:elementType name="message"> - <swe:DataChoice> - <swe:item name="TEMP"> - <swe:DataRecord> - <swe:label>Temperature Measurement</swe:label> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime"> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="temp"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/air_temperature"> - <swe:uom code="Cel"/> - </swe:Quantity> - </swe:field> - </swe:DataRecord> - </swe:item> - <swe:item name="WIND"> - <swe:DataRecord> - <swe:label>Wind Measurement</swe:label> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime"> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="wind_speed"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_speed"> - <swe:uom code="km/h"/> - </swe:Quantity> - </swe:field> - <swe:field name="wind_dir"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/wind_to_direction"> - <swe:uom code="deg"/> - </swe:Quantity> - </swe:field> - </swe:DataRecord> - </swe:item> - </swe:DataChoice> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=","/> - </swe:encoding> -</swe:DataStream> - - -

The datastream records are encoded using the Text encoding method as shown below:

- -TEMP,2009-05-23T19:36:15Z,25.5 -TEMP,2009-05-23T19:37:15Z,25.6 -WIND,2009-05-23T19:37:17Z,56.3,226.3 -TEMP,2009-05-23T19:38:15Z,25.5 -... - - -

This datastream interleaves different types of messages separated by the block separator character. The element type is a “DataChoice” which means that each encoded block is composed of the item name ‘TEMP’ or ‘WIND’, followed by values of the item. This example also demonstrates that items of a choice can be of different types and length.

-
- - -B.1.5.<tab/>Fixed size 2D array (stress matrix) -

The following example illustrates how values of a fixed size 3×3 stress matrix can be text encoded inline:

- -<swe:Matrix definition="http://sweet.jpl.nasa.gov/2.0/physPressure.owl#Stress"> - <swe:elementCount> - <swe:Count> - <swe:value>3</swe:value> - </swe:Count> - </swe:elementCount> - <swe:elementType name="row"> - <swe:Matrix definition="http://sweet.jpl.nasa.gov/2.0/info.owl#Row"> - <swe:elementCount> - <swe:Count> - <swe:value>3</swe:value> - </swe:Count> - </swe:elementCount> - <swe:elementType name="coef"> - <swe:Quantity definition="http://sweet.jpl.nasa.gov/2.0/mathVector.owl#Coordinate"> - <swe:uom code="MPa"/> - </swe:Quantity> - </swe:elementType> - </swe:Matrix> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator=" " tokenSeparator=","/> - </swe:encoding> - <swe:values>0.36,0.48,-0.8 -0.8,0.6,0.0 0.48,0.64,0.6</swe:values> -</swe:Matrix> - - -

Note that elements of the outer array (i.e. a matrix is a special kind of array) are separated by block separators (i.e. each block surrounded by spaces corresponds to one row of the matrix) while the inner array elements are separated by token separators.

-
- - -B.1.6.<tab/>Datastream of variable size 1D arrays (profile series) -

The following example shows how SWE Common can be used to encode a series of irregular length profiles by using a variable size array:

- -<swe:DataStream> - <swe:elementType name="profileData"> - <swe:DataRecord> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime"> - <swe:label>Sampling Time</swe:label> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="profilePoints"> - <swe:DataArray definition="http://sweet.jpl.nasa.gov/2.0/info.owl#Profile"> - <swe:elementCount> - <swe:Count/> - </swe:elementCount> - <swe:elementType name="point"> - <swe:DataRecord> - <swe:field name="depth"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter/depth"> - <swe:label>Sampling Point Vertical Location</swe:label> - <swe:uom code="m"/> - </swe:Quantity> - </swe:field> - <swe:field name="salinity"> - <swe:Quantity definition="http://mmisw.org/ont/cf/parameter#sea_water_salinity"> - <swe:label>Salinity</swe:label> - <swe:uom code="[ppth]"/> - </swe:Quantity> - </swe:field> - </swe:DataRecord> - </swe:elementType> - </swe:DataArray> - </swe:field> - </swe:DataRecord> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator="@@&#10;" tokenSeparator=","/> - </swe:encoding> -</swe:DataStream> - - -

The datastream records are encoded using the Text encoding method as shown below:

- -2005-05-16T21:47:12Z,5,0,45,10,20,20,30,30,35,40,40@@ -2005-05-16T22:43:05Z,4,0,45,10,20,20,30,30,35@@ -2005-05-16T23:40:52Z,5,0,45,10,20,20,30,30,35,40,40 -... - - -

The example shows data for 3 profiles with a variable number of measurements along the vertical dimension. The number of measurements is indicated in the encoded data block by a number inserted after the timestamp, and before the measurements themselves. Since the array is itself the element of a “DataStream”, elements of the array are separated by token separators.

-
- - -B.1.7.<tab/>Datastream with geometry (feature detection) -

The following snippet is an example of datastream that contains a geometry. Here, each datastream record represents a feature detected in a video stream, and is composed of a timestamp, a scalar field and the geometry of the geolocated feature.

- -<swe:DataStream> - <swe:label>Feature Detections</swe:label> - <swe:elementType name="detection"> - <swe:DataRecord> - <swe:field name="time"> - <swe:Time definition="http://www.opengis.net/def/property/OGC/0/SamplingTime" - referenceFrame="http://www.opengis.net/def/trs/OGC/0/GPS"> - <swe:uom xlink:href="http://www.opengis.net/def/uom/ISO-8601/0/Gregorian"/> - </swe:Time> - </swe:field> - <swe:field name="type"> - <swe:Category definition="http://www.opengis.net/def/featureType"> - <swe:codeSpace xlink:href="http://x-myorg.net/def/VehicleTypes"/> - </swe:Category> - </swe:field> - <swe:field name="geom"> - <swe:Geometry definition="http://www.opengis.net/def/property/OGC/0/SamplingTime" srs="http://www.opengis.net/def/crs/EPSG/0/4326"> - <swe:constraint> - <swe:AllowedGeometries> - <swe:geomType>Point</swe:geomType> - <swe:geomType>Polygon</swe:geomType> - </swe:AllowedGeometries> - </swe:constraint> - </swe:Geometry> - </swe:field> - </swe:DataRecord> - </swe:elementType> - <swe:encoding> - <swe:TextEncoding blockSeparator="&#10;" tokenSeparator=";"/> - </swe:encoding> -</swe:DataStream> - - -

The datastream records are encoded using the Text encoding method as shown below:

- -2007-10-23T15:46:12Z;Car;POINT(-86.3254 35.4812) -2007-10-23T15:49:03Z;Truck;POLYGON((-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812)) -2007-10-23T15:56:45Z;Bus;POLYGON((-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812)) -... - -
-
- - -B.2.<tab/>XML Encoding Rules Examples -

The following examples build on the ones provided in the Text Encoding Rules Examples section. The datastream descriptions are kept the same, except that the encoding method would have to be changed to:

- -<swe:encoding> - <swe:XMLEncoding/> -</swe:encoding> - - -

In the following sections, encoded values were kept identical to the ones used in the text encoding section, in order to facilitate comparison.

- - -B.2.1.<tab/>Datastream with records (weather data) -

This example is based on the same datastream description as the one provided in Annex B.1.2.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -<swe:values xmlns:ns="http://www.myorg.com/datasets/id"> - <ns:weatherData> - <ns:time>2023-03-20T15:40:00Z</ns:time> - <ns:temp>15.3</ns:temp> - <ns:press>1014</ns:press> - <ns:windSpeed>3.5</ns:windSpeed> - <ns:windDir>56.0</ns:windDir> - </ns:weatherData> - <ns:weatherData> - <ns:time>2023-03-20T15:45:00Z</ns:time> - <ns:temp>15.4</ns:temp> - <ns:press>1015</ns:press> - <ns:windSpeed>5.6</ns:windSpeed> - <ns:windDir>123.0</ns:windDir> - </ns:weatherData> - <ns:weatherData> - <ns:time>2023-03-20T15:50:00Z</ns:time> - <ns:temp>15.8</ns:temp> - <ns:press>1014</ns:press> - <ns:windSpeed>13.2</ns:windSpeed> - <ns:windDir>34.0</ns:windDir> - </ns:weatherData> - ... -</swe:values> - -
- - -B.2.2.<tab/>Datastream with records and optional fields (navigation data) -

This example is based on the same datastream description as the one provided in Annex B.1.3.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -<swe:values xmlns:ns="urn:myorg:dataset:X156822"> - <ns:navData> - <ns:time>2007-10-23T15:46:12Z</ns:time> - <ns:speed>15.3</ns:speed> - <ns:location> - <ns:lat>45.3</ns:lat> - <ns:lon>-90.5</ns:lon> - <ns:alt>311</ns:alt> - </ns:location> - </ns:navData> - <ns:navData> - <ns:time>2007-10-23T15:46:22Z</ns:time> - <ns:speed>25.3</ns:speed> - </ns:navData> - <ns:navData> - <ns:time>2007-10-23T15:46:32Z</ns:time> - <ns:speed>20.6</ns:speed> - <ns:location> - <ns:lat>45.3</ns:lat> - <ns:lon>-90.6</ns:lon> - <ns:alt>312</ns:alt> - </ns:location> - </ns:navData> - ... -</swe:values> - - -

Notice that the optional ‘location’ field in the second stream element has been completely omitted.

-
- - -B.2.3.<tab/>Datastream with choice (navigation data) -

This example is based on the same datastream description as the one provided in Annex B.1.4.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -<swe:values xmlns:ns="urn:myorg:dataset:DC4578"> - <ns:message> - <ns:TEMP> - <ns:time>2009-05-23T19:36:15Z</ns:time> - <ns:temp>25.5</ns:temp> - </ns:TEMP> - </ns:message> - <ns:message> - <ns:TEMP> - <ns:time>2009-05-23T19:37:15Z</ns:time> - <ns:temp>25.6</ns:temp> - </ns:TEMP> - </ns:message> - <ns:message> - <ns:WIND> - <ns:time>2009-05-23T19:37:17Z</ns:time> - <ns:wind_speed>56.3</ns:wind_speed> - <ns:wind_dir>226.3</ns:wind_dir> - </ns:WIND> - </ns:message> - <ns:message> - <ns:TEMP> - <ns:time>2009-05-23T19:38:15Z</ns:time> - <ns:temp>25.5</ns:temp> - </ns:TEMP> - </ns:message> - ... -</swe:values> - -
- - -B.2.4.<tab/>Datastream of variable size 1D arrays (profile series) -

This example is based on the same datastream description as the one provided in Annex B.1.6.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -<swe:values xmlns:ns="urn:myorg:dataset:PS3658"> - <ns:profileData> - <ns:time>2005-05-16T21:47:12Z</ns:time> - <ns:profilePoints elementCount="5"> - <ns:point> - <ns:depth>0</ns:depth> - <ns:salinity>45</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>10</ns:depth> - <ns:salinity>20</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>20</ns:depth> - <ns:salinity>30</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>30</ns:depth> - <ns:salinity>35</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>40</ns:depth> - <ns:salinity>40</ns:salinity> - </ns:point> - </ns:profilePoints> - </ns:profileData> - <ns:profileData> - <ns:time>2005-05-16T22:43:05Z</ns:time> - <ns:profilePoints elementCount="4"> - <ns:point> - <ns:depth>0</ns:depth> - <ns:salinity>45</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>10</ns:depth> - <ns:salinity>20</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>20</ns:depth> - <ns:salinity>30</ns:salinity> - </ns:point> - <ns:point> - <ns:depth>30</ns:depth> - <ns:salinity>35</ns:salinity> - </ns:point> - </ns:profilePoints> - </ns:profileData> - ... -</swe:values> - - -

This example shows how the array size is specified on the ‘profilePoints’ element corresponding to each nested array, and how element local names correspond to the “name” attributes of each component’s parent property.

-
- - -B.2.5.<tab/>Datastream with geometry (feature detection) -

This example is based on the same datastream description as the one provided in Annex B.1.7.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -<swe:values xmlns:ns="urn:myorg:dataset:X151451" xmlns:gml="http://www.opengis.net/gml/3.2"> - <ns:detection> - <ns:time>2007-10-23T15:46:12Z</ns:time> - <ns:type>Car</ns:type> - <ns:geom> - <gml:Polygon srsName="http://www.opengis.net/def/crs/EPSG/0/4326"> - <gml:exterior> - <gml:LinearRing> - <gml:posList srsDimension="2">-86.3254 35.4812 -86.3253 35.4812 -86.3253 35.4811 -86.3254 35.4811 -86.3254 35.4812</gml:posList> - </gml:LinearRing> - </gml:exterior> - </gml:Polygon> - </ns:geom> - </ns:detection> - <ns:detection> - <ns:time>2007-10-23T15:49:03Z</ns:time> - <ns:type>Truck</ns:type> - <ns:geom> - <gml:Polygon srsName="http://www.opengis.net/def/crs/EPSG/0/4326" > - <gml:exterior> - <gml:LinearRing> - <gml:posList srsDimension="2">-86.3254 35.4812 -86.3253 35.4812 -86.3253 35.4811 -86.3254 35.4811 -86.3254 35.4812</gml:posList> - </gml:LinearRing> - </gml:exterior> - </gml:Polygon> - </ns:geom> - </ns:detection> - <ns:detection> - <ns:time>2007-10-23T15:56:45Z</ns:time> - <ns:type>Bus</ns:type> - <ns:geom> - <gml:Polygon srsName="http://www.opengis.net/def/crs/EPSG/0/4326"> - <gml:exterior> - <gml:LinearRing> - <gml:posList srsDimension="2">-86.3254 35.4812 -86.3253 35.4812 -86.3253 35.4811 -86.3254 35.4811 -86.3254 35.4812</gml:posList> - </gml:LinearRing> - </gml:exterior> - </gml:Polygon> - </ns:geom> - </ns:detection> - ... -</swe:values> - -
-
- - -B.3.<tab/>JSON Encoding Rules Examples -

The following examples build on the ones provided in the Text Encoding Rules Examples section. The datastream descriptions are kept the same, except that the encoding method would have to be changed to:

- -<swe:encoding> - <swe:JSONEncoding/> -</swe:encoding> - - -

In the following sections, encoded values were kept identical to the ones used in the text encoding section, in order to facilitate comparison.

- - -B.3.1.<tab/>DataArray with inline values (curve) -

This example is based on the same “DataArray” description as the one provided in Annex B.1.1.

- -

The equivalent JSON description for this “DataArray” is provided below:

- -{ - "type": "DataArray", - "definition": "http://sweet.jpl.nasa.gov/2.0/mathFunction.owl#Function" - "description": "Measurement error vs. temperature", - "elementCount": { - "type": "Count", - "value": 5 - }, - "elementType": { - "name": "point", - "type": "DataRecord", - "label": "Error vs. Temperature", - "fields": [ - { - "name": "temp", - "type": "Quantity", - "definition": "http://sweet.jpl.nasa.gov/2.0/physThermo.owl#Temperature", - "label": "Temperature", - "uom": { "code": "Cel" } - }, - { - "name": "error", - "type": "Quantity", - "definition": "http://sweet.jpl.nasa.gov/2.0/sciUncertainty.owl#Error", - "label": "Relative Error", - "uom": { "code": "%" } - } - ] - }, - "values": [[0,5], [10,2], [50,2], [80,5], [100,15]] -} - -
- - -B.3.2.<tab/>Datastream with records (weather data) -

This example is based on the same datastream description as the one provided in Annex B.1.2.

- -

The following snippet shows how this datastream records are encoded using the JSON encoding method:

- -[ - { - "time": "2023-03-20T15:40:00Z", - "temp": 15.3, - "press": 1014, - "windSpeed": 3.5, - "windDir": 56.0 - }, - { - "time": "2023-03-20T15:45:00Z", - "temp": 15.4, - "press": 1015, - "windSpeed": 5.6, - "windDir": 123.0 - }, - { - "time": "2023-03-20T15:50:00Z", - "temp": 15.8, - "press": 1014, - "windSpeed": 13.2, - "windDir": 34.0 - }, - ... -] - -
- - -B.3.3.<tab/>Datastream with records and optional fields (navigation data) -

This example is based on the same datastream description as the one provided in Annex B.1.3.

- -

The following snippet shows how this datastream records are encoded using the XML encoding method:

- -[ - { - "time": "2007-10-23T15:46:12Z", - "speed": 15.3, - "location": { - "lat": 45.3, - "lon": -90.5, - "alt": 311 - } - }, - { - "time": "2007-10-23T15:46:22Z", - "speed": 25.3, - "location": null - }, - { - "time": "2007-10-23T15:46:32Z", - "speed": 20.6, - "location": { - "lat": 45.3, - "lon": -90.6, - "alt": 312 - } - }, - ... -] - -
- - -B.3.4.<tab/>Datastream with choice (navigation data) -

This example is based on the same datastream description as the one provided in Annex B.1.4.

- -

The following snippet shows how this datastream records are encoded using the JSON encoding method:

- -[ - { - "TEMP": { - "time": "2009-05-23T19:36:15Z", - "temp": 25.5 - } - }, - { - "TEMP": { - "time": "2009-05-23T19:37:15Z", - "temp": 25.6 - } - }, - { - "WIND": { - "time": "2009-05-23T19:37:17Z", - "wind_speed": 56.3, - "wind_dir": 226.3 - } - }, - { - "TEMP": { - "time": "2009-05-23T19:38:15Z", - "temp": 25.5 - } - }, - ... -] - -
- - -B.3.5.<tab/>Fixed size 2D array (stress matrix) -

This example is based on the same “Matrix” description as the one provided in Annex B.1.5.

- -

The equivalent JSON description for this “Matrix” is provided below:

- -{ - "type": "Matrix", - "definition": "http://sweet.jpl.nasa.gov/2.0/physPressure.owl#Stress" - "elementCount": { - "type": "Count", - "value": 3 - }, - "elementType": { - "name": "row", - "type": "Matrix", - "elementCount": { - "type": "Count", - "value": 3 - }, - "elementType": { - "name": "coef", - "type": "Quantity", - "definition": "http://sweet.jpl.nasa.gov/2.0/mathVector.owl#Coordinate", - "uom": { "code": "MPa" } - } - }, - "values": [[0.36,0.48,-0.8], [-0.8,0.6,0.0], [0.48,0.64,0.6]] -} - -
- - -B.3.6.<tab/>Datastream of variable size 1D arrays (profile series) -

This example is based on the same datastream description as the one provided in Annex B.1.6.

- -

The following snippet shows how this datastream records are encoded using the JSON encoding method:

- -[ - { - "time": "2005-05-16T21:47:12Z", - "profilePoints": [ - { "depth": 0, "salinity": 45 }, - { "depth": 10, "salinity": 20 }, - { "depth": 20, "salinity": 30 }, - { "depth": 30, "salinity": 35 }, - { "depth": 40, "salinity": 40 } - ] - }, - { - "time": "2005-05-16T22:43:05Z", - "profilePoints": [ - { "depth": 0, "salinity": 45 }, - { "depth": 10, "salinity": 20 }, - { "depth": 20, "salinity": 30 }, - { "depth": 30, "salinity": 35 } - ] - }, - { - "time": "2005-05-16T23:40:52Z", - "profilePoints": [ - { "depth": 0, "salinity": 45 }, - { "depth": 10, "salinity": 20 }, - { "depth": 20, "salinity": 30 }, - { "depth": 30, "salinity": 35 }, - { "depth": 40, "salinity": 40 } - ] - }, - ... -] - -
- - -B.3.7.<tab/>Datastream with geometry (feature detection) -

This example is based on the same datastream description as the one provided in Annex B.1.7.

- -

The following snippet shows how this datastream records are encoded using the JSON encoding method:

- -[ - { - "time": "2007-10-23T15:46:12Z", - "type": "Car", - "geom": { - "type": "Point", - "coordinates": [-86.3254, 35.4812] - } - }, - { - "time": "2007-10-23T15:49:03Z", - "type": "Truck", - "geom": { - "type": "Polygon", - "coordinates": [ - [-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812] - ] - } - }, - { - "time": "2007-10-23T15:56:45Z", - "type": "Bus", - "geom": { - "type": "Polygon", - "coordinates": [ - [-86.3254 35.4812,-86.3253 35.4812,-86.3253 35.4811,-86.3254 35.4811,-86.3254 35.4812] - ] - } - }, - ... -] - -
-
-
-<strong>Annex C</strong><br/>(informative)<br/><strong>Relationship with other ISO models</strong> - -C.1.<tab/>Feature model -

SWE “Records” can sometimes be seen as feature data from which GML feature representations could be derived. Even if it is true that a SWE “Record” contains values of feature properties, it does not always represent an object like a “Feature” does. The “Record” is simply a logical collection of fields that may be grouped together for a different reason than the fact that they all represent properties of the same object.

- -

The “Feature” model is a higher level model that is used to regroup property values inside the objects that they correspond to, as well as associate a meaning to the object itself.

- -

A good example is a set of weather observations obtained from different sensors that may be grouped into a single “Record” in SWE Common, but which does not constitute a feature in the GIS sense.

-
- - -C.2.<tab/>Coverage model -

SWE “Arrays” can sometimes be interpreted as coverage range data or grid data. However, SWE data arrays are lower level data types and don’t constitute a “Coverage” in themselves. The “Coverage” model described in OGC Abstract Topic 6 (OGC 07-011) can be used on top of the SWE “Array” model (which only provides means for describing and encoding the data), in order to provide a stronger link between range data and domain definition.

- -

Additionally, sensor descriptions given in SensorML (and thus using the SWE Common model) can be used to define a geo-referencing transformation that can be associated with a coverage via the same model.

-
-
-<strong>Annex D</strong><br/>(informative)<br/><strong>Revision History</strong> - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
DateReleaseEditorPrimary clauses modifiedDescription
2008-08-202.0 draftAlexandre RobinAllInitial draft version
2008-10-302.0 draftIngo SimonisAllGeneral revision
2009-10-302.0 draftAlexandre RobinAllDraft candidate standard
2009-11-042.0 draftPeter TaylorClauses 6 and 7Additional examples, minor edits
2009-11-102.0 draftAlexandre RobinAllGeneral revision, added section 8
2010-01-152.0 draftAlexandre RobinAllClarifications in requirements
2010-03-102.0 finalAlexandre RobinAllCorrections following RFC comments
2023-03-072.1 draftAlexandre RobinAllConversion to AsciiDoc / Metanorma
2023-03-082.1 draftAlexandre RobinClauses 7,8,9Removed requirements that were redundant with dependencies
2023-03-162.1 draftAlexandre RobinClause 7,8,9Added Geometry class
2023-03-212.1 draftAlexandre RobinClause 9Added JSON datastream encoding rules
2023-03-212.1 draftAlexandre RobinClause 9Clarified use of media types
2024-04-293.0 draftAlexandre RobinAllRefactored to v3.0, removed XML encoding sections
-
-Bibliography -

TODONOTE

The TC has approved Springer LNCS as the official document citation type.

- -

Springer LNCS is widely used in technical and computer science journals and other publications

- - -

– Actual References:

- -

[n] Journal: Author Surname, A.: Title. Publication Title. Volume number, Issue number, Pages Used (Year Published)

-

- OGC: OGC Testbed 12 Annex B: Architecture (2015).[1] - OGCTB12 - 12 -[1] - - - - -
-