True usability of INSPIRE datasets: 'voidable' is not optional.

Among the things INSPIRE implementers can do to increase the quality of their INSPIRE datasets, the correct use of voidable elements deserves a special mention. The concept of voidable could generate confusion in the INSPIRE implementer, who could be tempted by the erroneous equivalence ‘voidable = optional to provide’.  

With reference to the relevant definition in the ‘D2.5: Generic Conceptual Model’, the «voidable» stereotype does not give any information on whether or not a characteristic exists in the real world (this is  expressed using multiplicity) but conversely it is used to state that no corresponding value is contained in the source spatial data set maintained by the data provider or that no corresponding value can be derived from existing values at reasonable costs.  

Both mandatory and optional elements of a spatial object may be <voidable>.

Let’s consider the different cases:

  • element is mandatory and voidable:

at least one value for this characteristic of the spatial object exists in the real world (i.e. minimum multiplicity =1), therefore a value has to be provided – either the corresponding value (if available in the data set maintained by the data provider) or the value of void.

  • element is optional and voidable:

this characteristic of the spatial object may or may not exist in the real world (minOccurs="0") . An empty value implies that the characteristic is not present in the real world, while a value of void could be used to state that the characteristic may exist but that no corresponding value is contained in the source spatial data.

 

The reason for a ‘void’ value should be provided in the nilReason attribute choosing a value from the VoidReasonValue code list:

i.e.

nilReason=http://inspire.ec.europa.eu/codelist/VoidReasonValue/Unpopulated

or

nilReason=http://inspire.ec.europa.eu/codelist/VoidReasonValue/Unknown

or

nilReason= http://inspire.ec.europa.eu/codelist/VoidReasonValue/Withheld