Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Text NOTAM production rules

This section provides rules for the automated production of the text NOTAM message items, based on the AIXM 5.1 data encoding of the Event. Therefore, AIXM specific terms are used, such as names of features and properties, types of TimeSlices, etc:

  • the abbreviation RSG.BL. indicates that the corresponding data item must be taken from the RouteSegment BASELINE which is valid at the start time of the Event;
  • the abbreviation RSG.TD. indicates that the corresponding data item must be taken from the RouteSegment TEMPDELTA that was created for the Event;
    • Note: According to encoding rule ER-08, the TEMPDELTA might also include RouteAvailability elements that have been copied from the BASELINE data for compliance with the AIXM Temporality rules. For RTE.OPN scenario such static information shall be included in the text NOTAM generation algorithm to assure clarity with respect to the route status. 

Item A

Identify the FIR(s) within which the RouteSegments concerned by the Event are located.

Item Q

Apply the common NOTAM production rules for item Q, complemented by the following specific rules for this particular scenario:

Q code

The following mapping shall be used for the Q code:

RSG.BL.navigationType

Corresponding Q codes

RNAV or TACAN (for all RouteSegments concerned by the Event)

QANLC

otherwise

QARLC

Scope

Insert the value ‘E’.

Lower limit / Upper limit
  • the lowest value between all RSG.TD.RouteAvailability/AirspaceLayer.lowerLimit associated with the Event, formatted according to the common rules for {{Lower limit / Upper limit}}, shall be used as Lower limit;
  • the highest value between all RSG.TD.RouteAvailability/AirspaceLayer.upperLimit associated with the Event, formatted according to the common rules for {{Lower limit / Upper limit}}, shall be used as Upper limit.
Geographical reference

Calculate the centre and the radius (in NM) of a circle that encompasses all route segments concerned. Insert these values in the geographical reference item, 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 consists of 3 figures rounded up to the next higher whole Nautical Mile; e.g. 10.2NM shall be indicated as 011.

Items B, C and D

Items B and C shall be decoded following the common production rules.

...

  • only the closure schedules will be translated in the NOTAM Text. Eventual opening times described as schedules are considered as having been copied from the BASELINE, for completeness sake (see ER-06);
  • according to the input template, a single set of schedules is applicable to all RouteSegment closures associated with the Event. This will be ensured with a data verification rule. Therefore, it is sufficient to decode the schedules associated with one of the RSG.TD.RouteAvailability.timeInterval.

Item E

The following pattern should be used for automatically generating the E field text from the AIXM data:

Image RemovedImage Added


Code Block
titleEBNF Code
collapsetrue
template = ["RSG.BL.RouteAvailability.status(1)"] "route segments closed:" \n
"(2)" "/n" "RSG.BL.routeFormed(3)" "RSG.BL.start.pointChoice(4)" "-" "RSG.BL.end.pointChoice(5)" "open levels(6)" "direction(7)" {"direction(7)"} {"open levels(6)" "direction(7)" {"direction(7)"}} 
{"(2)" "/n" "RSG.BL.routeFormed(3)" "RSG.BL.start.pointChoice(4)" "-" "RSG.BL.end.pointChoice(5)" "open levels(6)" "direction(7)" {"direction(7)"}{"open levels(6)" "direction(7)" {"direction(7)"}}} \n
{"(87)" "/n" "RSG.BL.routeFormed(3)" "RSG.BL.start.pointChoice(4)" "-" "RSG.BL.end.pointChoice(5)" "baseline levels(9)" "direction(78)" {"direction(7)"} {"baseline levels(9)" "direction(7)" {"direction(7)"}}8)"} "remain" "RSG.TD.RouteAvailability.status(109)"} \n
{"." "/n" "RSG.TD.RouteAvailability.annotation(1110)"} "." .

Reference

Data item (from coding scenario)

Rule

(1)

route availability

If for each and everyone of the RSG.TD.RouteSegment that are concerned by the Event, during the times (considering an eventual schedule) and at the vertical levels covered by TD having RSG.TD.RouteAvailability='CLSD' the RSG.BL.RouteAvailability.status='COND' and RSG.BL.RouteAvailability(extension).ADR:conditionalRouteType='CDR1', then insert the text "CDR1". Otherwise insert the text "ATS"

(2)

route designator, start point, end point

Identify the route portions concerned and repeat steps from 3 to 5 for each route portion. To identify the route portions, order the RouteSegments associated with the Event:

  • first sort by the designatorPrefix, designatorSecondLetter, designatorNumber, multipleIdentifier of the Route that is referred to by the RSG.BL.routeFormed property;
  • second order by identical values of BL.start/EnRouteSegmentPoint.pointChoice or BL.end/EnRouteSegmentPoint.pointChoice with another segment of the same Route. Attention that it is possible to have two distinct portions of the same route associated with the Event.

(3)

route designator

Insert here the concatenated values of the designatorPrefix, designatorSecondLetter, designatorNumber, multipleIdentifier of the Route portion identified above.

(4)

start point

Insert here the DesignatedPoint.designator or the Navaid.designator or the AirportHeliport.designator that was identified as start of a route portion at point (2) above. Note that this could be either the start or the end of a RouteSegment, as it is not guaranteed that the RouteSegments have been encoded in a regular P1-P2/P2-P3/P3-P4/... order. There could be situations where the segments have been encoded as P1-P2/P3-P2/P3-P4/etc.

(5)

end point

Insert here the DesignatedPoint.designator or the Navaid.designator or the AirportHeliport.designator that was identified as end of a route portion at point (2) above. Note that this could be either the start or the end of a RouteSegment, as it is not guaranteed that the RouteSegments have been encoded in a regular P1-P2/P2-P3/P3-P4/... order. There could be situations where the segments have been encoded as P1-P2/P3-P2/P3-P4/etc.

(6)

lower limit, upper limit

If any RSG.TD.RouteAvailability/AirspaceLayer has either lowerLevel different from 'FLOOR' or upperLevel different from 'CEILING' (the segment is not completely closed on the vertical), then insert here each pair lowerLevel - upperLevel of one RSG.TD.RouteAvailability.AirspaceLayer having status='CLSD' that exists identically on all RSG.TD.RouteAvailability with status 'CLSD' of the RouteSegments of the affected route portion, decoded as indicated below: 


Code Block
titleEBNF Code
collapsetrue
template_levels = {"RSG.TD.RouteAvailability.lowerLevel" to "RSG.TD.RouteAvailability.upperLevel" ";"}.


If the value "FLOOR" is used as RSG.TD.RouteAvailability/AirspaceLayer.lowerLimit, then use the RSG.BL.lowerLimit, RSG.BL.lowerLimit.uom and RSG.BL.lowerLimitReference instead. If the value 'CEILING' is used as RSG.TD.RouteAvailability/AirspaceLayer.upperLimit, then use the RSG.BL.upperLimit, RSG.BL.upperLimit.uom and RSG.BL.upperLimitReference instead. In all situations the values shall be formatted according to the decoding ruled for vertical limits.
(7)direction

Insert here the RouteAvailability.direction as follows:

RouteAvailability.direction

Text to be inserted

FORWARDforwards
BACKWARDbackward

If both directions are to be included for the levels selected, insert here "forward and backward". 


(8)Follow this branch if there are RouteAvailability objects with a Note having purpose='REMARK' and the text="Baseline data copy." for the duration of the event. Otherwise ignore this branch.
(98)

Insert here the AirspaceLayers of the RouteAvailability objects with a Note having purpose='REMARK' and the text="Baseline data copy." decoded as in rule (6) above regardless of the status. 

If the Event has an associated schedule, consider only the AirspaceLayers/Timesheets corresponding to the closure schedule.

(109)
Insert here the RouteAvailability.status for each of the levels and directions corresponding to the AirspaceLayers selected on (9).

(1110)

note

Annotations shall be translated into free text according to the common rules for annotations decoding.

Note: The objective is to full automatic 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).

Items F & G

According to the OPADD rules, item F & G shall be left empty.

Event Update

The eventual update of this type of event shall be encoded following the general rules for {{Event updates [archived] Event update 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 NOTAM C

If a NOTAM C is produced, then the 4th and 5th letters (the "condition") of the Q code shall be "CN", except for the situation of a “new NOTAM to follow", in which case “XX”shall be used. 

The following pattern should be used for automatically generating the E field text from the AIXM data:

Image RemovedImage Added

Code Block
titleEBNF Code
collapsetrue
template_cancel = "RSG.BL.RouteAvailability.status(1)" "route" ("closure cancelscancelled." \n| [" : New NOTAM to follow.(1211)"]).

Reference

Rule

(811)

If the NOTAM will be followed by a new NOTAM concerning the same situation, then the operator shall have the possibility to

specify

choose the "

NEW

New NOTAM

TO FOLLOW" and this text shall be appended at the end of item E of the NOTAM C

to follow" branch.  This branch cannot be selected automatically because this information is only known by the operator.

Note: in this case, the 4th and 5th letters of the Q code shall also be changed into “XX”.