Item A
The item A shall be generated according to the general production rules for item A using the Event.concernedAirportHeliport.
Q code
The following mapping shall be used:
Declared Distance | Corresponding Q code |
---|---|
Declared Distance Change | QMDCH |
Scope
Insert the value ‘A’.
Lower limit / Upper limit
Use “000/999”
Geographical reference
Insert the coordinate of the ARP (BL.ARP.ElevatedPoint) of the airport, formatted as follows:
the set of coordinates comprises 11 characters rounded up or down to the nearest minute; i.e. Latitude (N/S) in 5 characters; Longitude (E/W) in 6 characters;
the radius value is “005”.
Items B, C and D
Items B and C shall be decoded following the common production rules.
item D shall be left empty. Note: If the declared distances are associated with a schedule, this information will be provided in item E, next to the group of declared distances concerned. This is a different approach from the current NOTAM practice where the NOTAM user is left to integrate the information that remains valid from the baseline (AIP) data with the values provided by NOTAM. In this scenario, the NOTAM generated automatically from the AIXM coded data includes all declared distances, not only the changed values.
Item E
The following pattern should be used for automatically generating the E field text from the AIXM data:
Code Block | ||||
---|---|---|---|---|
| ||||
template = template = ["(1)" "AHP.BL.type (2)" ("AHP.BL.name (3a)" | "AHP.BL.ARP (3b)") ] "Declared distances changed as follows:" "\n" \n "(64)" ["unpaved(45)"] "RWY" "RDN.BL.designator" ("(56)" "single declared distances group" | "multiple declared distances groups") "." {"(74)" "(64)" ["unpaved(45)"] "RWY" "RDN.BL.designator" ("(56)" "single declared distances group" | "multiple declared distances groups") "."} ["\n" "RCP.TD.RDD.annotation(15)" "."]. single_declared_distances_group = "(7)" "(8)" "RCP.TD.RDD.type(9)" "RCP.TD.RDD.declaredValue.RunwayDeclaredDistanceValue.distance(10)" {"(8)" "(8)" "RCP.TD.RDD.type(9)" "RCP.TD.RDD.declaredValue.RunwayDeclaredDistanceValue.distance(10)"} ["RCP.TD.RDD.declaredValue.RunwayDeclaredDistanceValue.timInterval.Timesheet(11)"] "\n" {"(7)" "(7)" "(8)" "RCP.TD.RDD.type(9)" "RCP.TD.RDD.declaredValue.RunwayDeclaredDistanceValue.distance(10)" {"(8)" "(8)" "RCP.TD.RDD.type(9)" "RCP.TD.RDD.declaredValue.RunwayDeclaredDistanceValue.distance(10)"} ["RCP.TD.RDD.declaredValue.RunwayDeclaredDistanceValue.timInterval.Timesheet(11)"] "\n"}. multiple_declared_distances_group = "(12)" ["(13)" "(" "RCP.BL.designator" ")"] ["(14)" "(" "RCP.TD.RDD.annotation.Note" ")"] "single declared distances group" {"12" "(12)" ["(13)" "(" "RCP.BL.designator" ")"] ["(14)" "(" "RCP.TD.RDD.annotation.Note" ")"] "single declared distances group"}. |
Warning |
---|
The item E production template is based on a number of loops that group and order the declared distances values, taking into consideration the current NOTAM practice:
The objective of this algorithm is to allow simple cases (one runway direction with one set of declared distances) to be output in the single line, for example "RWY 08 TORA 2800M TODA 2800M ASDA 2400M LDA 2300M", while more complex cases are also supported, but the text will inevitably be longer and more complex, such as in the following example: "RWY 08L Note: The objective is to fully automate generation, without human intervention. However, the implementers of the specification might consider reducing the cost of a fully automated generation by allowing the operator to fine-tune the text in order to improve its readability (with the inherent risk for human error when re-typing is allowed). |
Reference | Data item (from coding scenario) | Rule | ||||||||
---|---|---|---|---|---|---|---|---|---|---|
(1) | If AHP.BL.locationIndicatorICAO is not null, then ignore this branch. | |||||||||
(2) | Insert here the type of the airport decoded as follows
| |||||||||
(3) | a. AHP.BL.name is not NIL, then insert it here. Otherwise: b. insert here the text "located at" followed by the AHP.BL.ARP.ElevatedPoint decoded according to thetext NOTAM production rules for aixm:Point | |||||||||
(4 |
) | If more than one RCP.TD is associated with the Event, then group them ascending by associated RDN.BL.designator value. If more than one RCP.TD group is detected (more than one runway direction is concerned), then use the branch (6) for each RCP.TD group and repeat (7) until all groups are processed. | |
Insert the word “unpaved” if RWY.BL.SurfaceCharacteristics.composition has one of the values 'CLAY', 'CORAL', 'EARTH', 'GRASS', 'GRAVEL', 'ICE', 'LATERITE', 'MACADAM', 'SAND', 'SNOW', 'WATER', 'OTHER'. Otherwise do not insert anything. | ||
(6) | If in the RCP.TD group that is being processed (following rule #4) there is at maximum one RCP.TD.RDD descendant that has the same type value, then use the "single declared distances group". This is the typical case, when a single set of LDA, TORA, TODA, ASDA values are declared for a runway landing direction. Otherwise, if two or more RCP.TD.RDD descendants have identical type values, then use the "multiple declared distances group" branch. In this case, there are additional "take-off alignment points" along the runway centreline, each with distinct values for TORA, TODA, LDA. It is unlikely that several LDA values exist for the same runway landing direction. |
"multiple declared distances group":
- RCP.BL.role (in the order 'THR', 'DISP_THR', any other value)
- (descending) RCP.TD.RDD.declaredValue.RunwayDeclaredDistanceValue.distance
(7) | If there exist RCP.TD.RDD.declaredValue.RunwayDeclaredDistanceValue.timInterval.Timesheet (there is a schedule applicable to certain declared distances), then group the RCP.TD.RDD.declaredValue.RunwayDeclaredDistanceValue by identical timeInterval.Timesheet. Otherwise (no schedule), create just one group. | |
(8) | For each group of RCP.TD.RDD.declaredValue.RunwayDeclaredDistanceValue selected in rule (7), order them by parent RCP.TD.RDD.type (in the order 'TORA', 'TODA', 'ASDA', 'LDA', 'TODAH', 'RTOAH', 'LDAH', other values...) and process each of them as indicated in the template | |
(9) | Insert here the declared distance type decoded as |
If AHP.BL.type=AD, LS or OTHER
indicated below.
|
|
|
| ||||||||
(10) | Insert here the declared distance value followed by its unit of measurement decoded according to the |
text NOTAM production rules for distances |
(11) |
Process the Timesheet of the group according to the |
NOTAM production rules for Item D, E - Schedules | ||
(12) | Group the RCP.TD as follows:
Then, process each group according to the template and repeat (loop #12) until all groups are processed. | |
(13) | If the RCP.BL.designator has a value, insert that value | |
(14) | If the RCP.TD.RDD has an annotation.Note with propertyName equal to 'location', then translate it into free text according to the rule for annotations decoding | |
(15) | Annotations shall be translated into free text according to the rule for decoding annotations. |
Items F & G
Leave empty.
Event Update
The eventual update of this type of event shall be encoded following the general rules for {{Event updates or cancellation}}, which provide instructions for all NOTAM fields, except for item E and the condition part of the Q code, in the case of a NOTAMC
If a NOTAMC is produced, then the 4th and 5th letters (the "condition") of the Q code shall be "AK" unless there is a new NOTAM to follow, in which case the Q code shall be “XX” and the following pattern should be used for automatically generating the E field text from the AIXM data:
Code Block | ||||
---|---|---|---|---|
| ||||
template_cancel = ["(1)" "AHP.BLtype (2)" ("AHP.BL.name (3a)" | "AHP.BL.ARP (3b)") ] "RWY" "RDN.BL.designator" ["."] \n ["resumed normal operations"] ["New NOTAM to follow (9)"] ".". |
Reference | Rule |
---|---|
(9) | If the NOTAM will be followed by a new NOTAM concerning the same situation, then the operator shall have the possibility to specify "New NOTAM to follow" and this text shall be appended at the end of item E of the NOTAM C. Note: in this case, the 4th and 5th letters of the Q code shall also be changed into “XX” |