Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 5 Next »

Definitions

IdentifierCondition expressionMeaning
D_NounDescendNouns

(Feature / Object) (has / has-descendant) (quantity)? propertyPath

A child or descendant element of an AIXM feature/object is present in the data set. 

Examples: AirspaceTimeSlice has type ; AirspaceTimeSlice has at-least 2 annotation

DV_NounDescendNounsValue

(Feature / Object)  (has / has-descendant) (quantity)? propertyPath value (unspecified)?

A child or descendant element of an AIXM feature/object is present in the data set and either has an assigned value or it is an empty element).

Examples: AirspaceTimeSlice has type value ; AirspaceTimeSlice has name value unspecified

DVT_NounDescendNounsTest(Feature / Object)  (has / has-descendant) (quantity) propertyPath value  (compareWith 'valueOrList' / #free test#)

A child or descendant element of an AIXM feature/object is present in the data set and it has an assigned value that complies with a test. The test is either a comparison with a value or a list of allowable values or it is a free test.

Examples: AirspaceTimeSlice has type value equal-to 'TMA' ; AirspaceTimeSlice has name value #that includes the word 'Brussels'#

Where propertyPath = property ("." Object "." property)*

Mapping to AIXM XML structure

This group of elementary conditions test the existence or the value of the child or descendant nodes of an AIXM XML element. They have the following particularities:

  • the "entry node' is an AIXM XML element that corresponds to an AIXM class with stereotype <<feature>> or <<object>>, such as Airspace, Runway, City, ElevatedPoint, etc, This includes FetaureTimeSlice classes, such as AirspaceTimeSlice, RunwayTimeSlice, etc.
  • has is used when the element that is tested is a direct child element (in the XML sense) of the feature/object or when the full path, starting with the child element is provided.
  • has-descendant is used when the element that is tested is a deeper descendant (in the XML sense) of the feature/object. In principle, child elements are also descendants. However, for editorial clarity, 'descendant' should not be used for direct child elements.

The following diagram shows how has and has-descendant are interpreted in the AIXM XML structure.

Special situation - multiple descendants

Many properties in AIXM can be multi-occurring. For example, an AirspaceTimeSlice can have several geometryComponent.AirspaceVolume child/descendant elements. This has two main consequences on the interpretation of the rules:

  • all occurrences of the child/descendant needs to be considered in the evaluation of the rule. This does not mean that they all need to be tested! For example, if an elementary condition is formulated with "at-least one" and a first occurrence is found, the remaining ones might not need to be effectively tested, However, in other circumstances, all occurrences need to effectively be tested against the rule.
  • the same occurrence need to be used in all elementary conditions, unless there is an explicit "[1]", "[2]", etc. suffix after the noun that indicates that different instances are referenced.

For example, considering the (fictitious) rule: It is prohibited that AirspaceTimeSlice has-descendant AirspaceVolume.upperLimit value lower-than AirspaceVolume.lowerLimit value, the two interpretation aspects highlighted above mean that:

  • if the AirspaceTimeSlice has several AirspaceVolume descendants, the rule needs to be tested for each of them;
  • the lowerLimit value needs to be compared with the upperLimit value of the same AirspaceVolume ;
    • Note: if it was necessary to compare the upper limit of one airspace volume with the lower limit of (all) another airspace volume, then the rule would be written differently: It is prohibited that AirspaceTimeSlice has-descendant AirspaceVolume[1].upperLimit value lower-than AirspaceVolume[2].lowerLimit value, The suffixes "[1]" and "[2]" are used in order to indicate that two different AirspaceVolume are concerned.


  • No labels