<?xml version="1.0" encoding="utf-8"?>
  <?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
  <!-- generated by https://github.com/cabo/kramdown-rfc version 1.6.17 (Ruby 2.7.0) -->


<!DOCTYPE rfc  [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">

]>

<?rfc comments="yes"?>

<rfc ipr="trust200902" docName="draft-ietf-ccamp-rfc9093-bis-08" category="std" consensus="true" submissionType="IETF" obsoletes="9093" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title abbrev="Yang for Layer 0 Types">A YANG Data Model for Layer 0 Types</title>

    <author initials="S." surname="Belotti" fullname="Sergio Belotti" role="editor">
      <organization>Nokia</organization>
      <address>
        <email>sergio.belotti@nokia.com</email>
      </address>
    </author>
    <author initials="I." surname="Busi" fullname="Italo Busi" role="editor">
      <organization>Huawei</organization>
      <address>
        <email>italo.busi@huawei.com</email>
      </address>
    </author>
    <author initials="D." surname="Beller" fullname="Dieter Beller" role="editor">
      <organization>Nokia</organization>
      <address>
        <email>dieter.beller@nokia.com</email>
      </address>
    </author>
    <author initials="H." surname="Zheng" fullname="Haomian Zheng">
      <organization>Huawei</organization>
      <address>
        <email>zhenghaomian@huawei.com</email>
      </address>
    </author>
    <author initials="E." surname="Le Rouzic" fullname="Esther Le Rouzic">
      <organization>Orange</organization>
      <address>
        <email>esther.lerouzic@orange.com</email>
      </address>
    </author>
    <author initials="A." surname="Guo" fullname="Aihua Guo">
      <organization>Futurewei Technologies</organization>
      <address>
        <email>aihuaguo.ietf@gmail.com</email>
      </address>
    </author>
    <author initials="D." surname="King" fullname="Daniel King">
      <organization>University of Lancaster</organization>
      <address>
        <email>d.king@lancaster.ac.uk</email>
      </address>
    </author>

    <date year="2024" month="February" day="01"/>

    
    <workgroup>CCAMP Working Group</workgroup>
    

    <abstract>


<t>This document defines a collection of common data types and groupings
   in the YANG data modeling language.  These derived common types and
   groupings are intended to be imported by modules that model Layer 0
   optical Traffic Engineering (TE) configuration and state capabilities
   such as Wavelength Switched Optical Networks (WSONs) and flexi-grid
   Dense Wavelength Division Multiplexing (DWDM) networks.</t>

<t>This document obsoletes RFC 9093.</t>



    </abstract>



  </front>

  <middle>


<section anchor="introduction"><name>Introduction</name>

<t>YANG <xref target="RFC7950"/> is a data modeling language used to model
   configuration data, state data, Remote Procedure Calls, and
   notifications for network management protocols such as the Network
   Configuration Protocol (NETCONF) <xref target="RFC6241"/>.  The YANG language
   supports a small set of built-in data types and provides mechanisms
   to derive other types from the built-in types.</t>

<t>This document introduces a collection of common data types derived
   from the built-in YANG data types.  The derived types and groupings
   are designed to be the common types applicable for modeling Traffic
   Engineering (TE) features as well as non-TE features (e.g., physical
   network configuration aspects) for Layer 0 optical networks in
   model(s) defined outside of this document.  The applicability of
   Layer 0 types specified in this document includes Wavelength Switched
   Optical Networks (WSONs) <xref target="RFC6163"/> <xref target="ITU-T_G.694.1"/> and <xref target="ITU-T_G.694.2"/>, and flexi-grid Dense
   Wavelength Division Multiplexing (DWDM) networks <xref target="RFC7698"/>
   <xref target="ITU-T_G.694.1"/>.</t>

<t>This document adds new type definitions to the YANG modules and
   obsoletes <xref target="RFC9093"/>.  For further details, see the revision
   statements of the YANG module in <xref target="yang-code"/> or the summary in
   <xref target="changes-bis"/>.</t>

<t>The YANG data model in this document conforms to the Network
   Management Datastore Architecture defined in <xref target="RFC8342"/>.</t>

<section anchor="terminology-and-notations"><name>Terminology and Notations</name>

<t>Refer to <xref target="RFC7446"/> and <xref target="RFC7581"/> for the key terms used in this
   document, and the terminology for describing YANG data models can be
   found in <xref target="RFC7950"/>.</t>

<t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL
NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED",
"MAY", and "OPTIONAL" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>

</section>
<section anchor="prefix-in-data-node-names"><name>Prefix in Data Node Names</name>

<t>In this document, names of data nodes and other data model objects
   are prefixed using the standard prefix associated with the
   corresponding YANG imported modules.</t>

<texttable title="Prefixes and corresponding YANG modules" anchor="tab-prefixes">
      <ttcol align='left'>Prefix</ttcol>
      <ttcol align='left'>YANG module</ttcol>
      <ttcol align='left'>Reference</ttcol>
      <c>l0-types</c>
      <c>ietf-layer0-types</c>
      <c>RFC XXXX</c>
</texttable>

<t>RFC Editor Note:
Please replace XXXX with the RFC number assigned to this document.</t>

</section>
</section>
<section anchor="layer-0-types-module-contents"><name>Layer 0 Types Module Contents</name>

<t>This document defines a YANG module for common Layer 0 types, ietf-
   layer0-types.  This module is used for WSON and flexi-grid DWDM
   networks.  The "ietf-layer0-types" module contains the following YANG
   reusable types and groupings:</t>

<t>l0-grid-type:</t>

<ul empty="true"><li>
  <t>A base YANG identity for the grid type as defined in <xref target="RFC6205"/> and
     <xref target="RFC7699"/>.</t>
</li></ul>

<t>cwdm-ch-spc-type:</t>

<ul empty="true"><li>
  <t>A base YANG identity for the Coarse Wavelength Division
     Multiplexing (CWDM) channel-spacing type as defined in <xref target="RFC6205"/>.</t>
</li></ul>

<t>dwdm-ch-spc-type:</t>

<ul empty="true"><li>
  <t>A base YANG identity for the DWDM channel-spacing type as defined
     in <xref target="RFC6205"/>.</t>
</li></ul>

<t>flexi-ncfg-type:</t>

<ul empty="true"><li>
  <t>A base YANG identity for the DWDM flexi-grid Nominal Central Frequency Granularity (NCFG) 
      type as defined in <xref target="RFC7699"/>.</t>
</li></ul>

<t>flexi-slot-width-granularity:</t>

<ul empty="true"><li>
  <t>TBD: add a description and a reference (also in YANG)</t>
</li></ul>

<t>fec-type:</t>

<ul empty="true"><li>
  <t>TBD: add a description and the list of references defined in YANG</t>
</li></ul>

<t>line-coding:</t>

<ul empty="true"><li>
  <t>TBD: add a description and the list of references defined in YANG</t>
</li></ul>

<t>wavelength-assignment:</t>

<ul empty="true"><li>
  <t>TBD: add a description and the list of references defined in YANG</t>
</li></ul>

<t>term-type:</t>

<ul empty="true"><li>
  <t>TBD: add a description and the list of references defined in YANG</t>
</li></ul>

<t>otu-type:</t>

<ul empty="true"><li>
  <t>TBD: add a description and the list of references defined in YANG</t>
</li></ul>

<t>operational-mode:</t>

<ul empty="true"><li>
  <t>TBD: add a description and the list of references defined in YANG</t>
</li></ul>

<t>wson-label-start-end:</t>

<ul empty="true"><li>
  <t>The WSON label range was defined in <xref target="RFC6205"/>, and the generic
     topology model defines the label-start/label-end in <xref target="RFC8795"/>.
     This grouping shows the WSON-specific label-start and label-end
     information.</t>
</li></ul>

<t>wson-label-hop:</t>

<ul empty="true"><li>
  <t>The WSON label range was defined in <xref target="RFC6205"/>, and the generic
     topology model defines the label-hop in <xref target="RFC8795"/>.  This grouping
     shows the WSON-specific label-hop information.</t>
</li></ul>

<t>l0-label-range-info:</t>

<ul empty="true"><li>
  <t>A YANG grouping that defines the Layer 0 label range information
     applicable for WSON as defined in <xref target="RFC6205"/>. The label range info is defined per priority <xref target="RFC4203"/>. This grouping is
     used in the flexi-grid DWDM by adding more flexi-grid-specific
     parameters.</t>
</li></ul>

<t>wson-label-step:</t>

<ul empty="true"><li>
  <t>A YANG grouping that defines label steps for WSON as defined in
     <xref target="I-D.ietf-teas-rfc8776-update"/>.</t>
</li></ul>

<t>flexi-grid-label-start-end:</t>

<ul empty="true"><li>
  <t>The flexi-grid label range was defined in <xref target="RFC7699"/>, and the
  generic topology model defines the label-start/label-end in
  <xref target="RFC8795"/>.  This grouping shows the flexi-grid-specific label-
  start and label-end information which is used to describe the range of available nominal central frequencies.</t>
</li></ul>

<ul empty="true"><li>
  <t>As described in section 3.1 of <xref target="RFC8363"/>, the range of available nominal central frequencies are advertised for m=1, which means that for an available central frequency n, the frequency slot from central frequency n-1 to central frequency n+1 is available.</t>
</li></ul>

<t>flexi-grid-label-hop:</t>

<ul empty="true"><li>
  <t>The flexi-grid label range was defined in <xref target="RFC8363"/>, and the
     generic topology model defines the label-hop in <xref target="RFC8795"/>.  This
     grouping shows the WSON-specific label-hop information.</t>
</li></ul>

<t>flexi-grid-label-range-info:</t>

<ul empty="true"><li>
  <t>A YANG grouping that defines flexi-grid label range information as
     defined in <xref target="RFC8363"/>.</t>
</li></ul>

<t>flexi-grid-label-step:</t>

<ul empty="true"><li>
  <t>A YANG grouping that defines flexi-grid label steps as defined in
     <xref target="I-D.ietf-teas-rfc8776-update"/>.</t>
</li></ul>

<t>wdm-label-start-end:</t>

<ul empty="true"><li>
  <t>A YANG grouping that combines the definition of label-start/label-end information
    that was defined separately in wson-label-start-end and flexi-grid-label-start-end,
    to support optical network scenarios that contain both fixed- and flexi-grid
    links.</t>
</li></ul>

<t>wdm-label-hop:</t>

<ul empty="true"><li>
  <t>A YANG grouping that combines the definition of label hop information
    that was defined separately in wson-label-hop and flexi-grid-label-hop,
    to support optical network scenarios that contain both fixed- and flexi-grid
    links.</t>
</li></ul>

<t>wdm-label-range-info:</t>

<ul empty="true"><li>
  <t>A YANG grouping that combines the definition of label range information
    that was defined separately in wson-label-range-info and flexi-grid-label-range-info,
    to support optical network scenarios that contain both fixed- and flexi-grid
    links.</t>
</li></ul>

<t>wdm-label-step:</t>

<ul empty="true"><li>
  <t>A YANG grouping that combines the definition of label step information
    defined separately in wson-label-step and flexi-grid-label-step,
    to support optical network scenarios that contain both fixed- and flexi-grid
    links.</t>
</li></ul>

<t>transceiver-capabilities:</t>

<ul empty="true"><li>
  <t>a YANG grouping to define the transceiver capabilities (also called
   "modes") needed to determine optical signal compatibility.</t>
</li></ul>

<t>standard-mode:</t>

<ul empty="true"><li>
  <t>a YANG grouping for the standard modes defined in <xref target="ITU-T_G.698.2"/>.</t>
</li></ul>

<t>organizational-mode:</t>

<ul empty="true"><li>
  <t>a YANG grouping to define transponder operational mode supported by
   organizations or vendors.</t>
</li></ul>

<t>common-explicit-mode:</t>

<ul empty="true"><li>
  <t>a YANG grouping to define the list of attributes related to optical
   impairments limits in case of transceiver explicit mode.  This
   grouping should be the same used in
   <xref target="I-D.ietf-ccamp-dwdm-if-param-yang"/>.</t>
</li></ul>

<t>transmitter-tuning-range:</t>

<ul empty="true"><li>
  <t>a YANG grouping that defines the transmitter tuning range, which
   includes the minimum and maximum tuning frequency, as well as the
   frequency tuning steps.</t>
</li></ul>

<t>common-organizational-explicit-mode:</t>

<ul empty="true"><li>
  <t>a YANG grouping to define the common capabilities attributes limit
   range in case of operational mode and explicit mode.  Also this
   grouping should be used in <xref target="I-D.ietf-ccamp-dwdm-if-param-yang"/>.</t>
</li></ul>

<t>cd-pmd-penalty:</t>

<ul empty="true"><li>
  <t>a YANG grouping to define the triplet used as entries in the list
   optional penalty associated with a given accumulated CD and PMD.
   This list of triplet cd, pmd, penalty can be used to sample the
   function penalty = f(CD, PMD).</t>
</li></ul>

<section anchor="wdm-label-and-label-range"><name>WDM Label and Label Range</name>

<t>As described in <xref target="RFC6205"/> and <xref target="RFC7699"/>, the WDM label represents the frequency slot assigned to a WDM LSP on a given WDM Link (which models an OMS MCG).</t>

<t>The same WDM label shall be assigned to the same WDM LSP on all the WDM Links on a regen-free LSP path or path segment.</t>

<t>A frequency slot is defined in <xref target="ITU-T_G.694.1"/> as a contiguous frequency range characterized by its nominal central frequency and slot width. The frequency range allocated to a frequency slot is unavailable to other frequency slots.</t>

<t>The definition of the frequency slot depends on the WDM grid type:</t>

<t><list style="symbols">
  <t>In case of CWDM fixed-grid, defined in <xref target="ITU-T_G.694.2"/>, the frequency slot is defined by a fixed CWDM channel spacing (cwdm-ch-spc-type) and by the nominal central wavelength which is computed as described in <xref target="RFC6205"/>:</t>
</list></t>

<figure><artwork><![CDATA[
      lambda = 1471 nm + N x channel spacing (measured in nm)
]]></artwork></figure>

<t><list style="symbols">
  <t>In case of DWDM fixed-grid, defined in <xref target="ITU-T_G.694.1"/>, the frequency slot is defined by a fixed DWDM channel spacing (dwdm-ch-spc-type) and by the nominal central frequency, which is computed as described in <xref target="RFC6205"/>:</t>
</list></t>

<figure><artwork><![CDATA[
      f = 193100.000 GHz + N x channel spacing (measured in GHz)
]]></artwork></figure>

<t><list style="symbols">
  <t>In case of DWDM flexible-grid, defined in <xref target="ITU-T_G.694.1"/>, the frequency slot is defined by the slot width and by the nominal central frequency, which are computed, based on the slot width granularity (SWG, fixed at 12.5GHz in <xref target="ITU-T_G.694.1"/>), and of the nominal central frequency granularity (NCFG, fixed at 6.25GHz in <xref target="ITU-T_G.694.1"/>) respectively, as described in <xref target="RFC7699"/>:</t>
</list></t>

<figure><artwork><![CDATA[
      SW = M x SWG (measured in GHz)
      f = 193100.000 GHz + N x NCFG (measured in GHz)
]]></artwork></figure>

<t>The definition of the channel spacing, NCFG and SWG in the YANG model are defined to support modelling of vendor-specific values (e.g., finer vendor-specific granularity for NCFG and SWG).</t>

<t>The WDM Label Range represents the frequency slots that are available for WDM LSPs to be set up over a given WDM Link.</t>

<t>The WDM Label Range is defined by the label-restriction list, defined in <xref target="I-D.ietf-teas-rfc8776-update"/>, which, for WDM, should be augmented using the l0-label-range-info grouping (for WSON only models) or the flexi-grid-label-range-info grouping (for DWDM flexible-grid only models) or the wdm-label-range-info grouping (for models that supports both WSON and DWDM flexible-grid).</t>

<t>Each entry in the label-restriction list represents either the range of the available central wavelength values (in case of CWDM fixed-grid) or the range of the available nominal central frequencies values (in case of DWDM fixed or flexible grids): the grid-type attribute defines the type of grid for each entry of the list.</t>

<t>In case of DWDM flexible grid, each entry in the label-restriction list represents also the range of the supported slot width values based on the following attributes, defined in <xref target="RFC7699"/>:</t>

<t><list style="symbols">
  <t>slot-width-granularity, which represents the minimum space between slot widths;</t>
  <t>min-slot-width-factor: a multiplier of the slot width granularity, indicating the minimum slot width supported by each entry in the label-restriction list;</t>
  <t>max-slot-width-factor: a multiplier of the slot width granularity, indicating the maximum slot width supported by each entry in the label-restriction list.</t>
</list></t>

<t>Each entry of the label-restriction list, as defined in <xref target="I-D.ietf-teas-rfc8776-update"/>, defines a label-start, a label-end, a label-step and a range-bitmap.</t>

<t>The label-start and label-end definitions for WDM should be augmented using the wson-label-start-end grouping (for WSON only models) or the flexi-grid-label-start-end grouping (for DWDM flexible-grid only models) or the wdm-label-start-end grouping (for models that supports both WSON and DWDM flexible-grid).</t>

<t>The label-step definition for WDM should be augmented using the wson-label-step grouping (for WSON only models) or the flexi-grid-label-step grouping (for DWDM flexible-grid only models) or the wdm-label-step grouping (for models that supports both WSON and DWDM flexible-grid). The label-step definition for WDM depends on the WDM grid type:</t>

<t><list style="symbols" anchor="yang-tree">
  <t>For CWDM and DWDM fixed grids, it describes the channel spacing, as defined in <xref target="RFC6205"/>;</t>
  <t>For DWDM flexible grids, it describes the nominal central frequency granularity (e.g., 6,25 GHz) as well as the multiplier for the supported values of n, as defined in <xref target="RFC7699"/>.</t>
</list></t>

</section>
</section>
<section anchor="yang-tree-for-layer-0-types-groupings"><name>YANG Tree for Layer 0 Types Groupings</name>

<figure anchor="fig-yang-tree"><artwork type="ascii-art"><![CDATA[
module: ietf-layer0-types

  grouping wdm-label-start-end:
    +-- (grid-type)?
       +--:(fixed-dwdm)
       |  +-- dwdm-n?    l0-types:dwdm-n
       +--:(cwdm)
       |  +-- cwdm-n?    l0-types:cwdm-n
       +--:(flexi-grid)
          +-- flexi-n?   l0-types:flexi-n
  grouping wdm-label-step:
    +-- (l0-grid-type)?
       +--:(fixed-dwdm)
       |  +-- wson-dwdm-channel-spacing?    identityref
       +--:(cwdm)
       |  +-- wson-cwdm-channel-spacing?    identityref
       +--:(flexi-grid)
          x-- flexi-grid-channel-spacing?   identityref
          +-- flexi-ncfg?                   identityref
          +-- flexi-n-step?                 uint8
  grouping wdm-label-hop:
    +-- (grid-type)?
       +--:(fixed-dwdm)
       |  +-- (fixed-single-or-super-channel)?
       |     +--:(single)
       |     |  +-- dwdm-n?               l0-types:dwdm-n
       |     +--:(multi)
       |        +-- subcarrier-dwdm-n*    l0-types:dwdm-n
       +--:(cwdm)
       |  +-- cwdm-n?                     l0-types:cwdm-n
       +--:(flexi-grid)
          +-- (single-or-super-channel)?
             +--:(single)
             |  +-- flexi-n?              l0-types:flexi-n
             |  +-- flexi-m?              l0-types:flexi-m
             x--:(super)
             |  +-- subcarrier-flexi-n* [flexi-n]
             |     +-- flexi-n?   l0-types:flexi-n
             |     +-- flexi-m?   l0-types:flexi-m
             +--:(multi)
                +-- frequency-slots
                   +-- frequency-slot* [flexi-n]
                      +-- flexi-n?   l0-types:flexi-n
                      +-- flexi-m?   l0-types:flexi-m
  grouping wdm-label-range-info:
    +-- grid-type?    identityref
    +-- priority?     uint8
    +-- flexi-grid
       +-- slot-width-granularity?   identityref
       +-- min-slot-width-factor?    uint16
       +-- max-slot-width-factor?    uint16
  grouping wson-label-start-end:
    +-- (grid-type)?
       +--:(dwdm)
       |  +-- dwdm-n?   l0-types:dwdm-n
       +--:(cwdm)
          +-- cwdm-n?   l0-types:cwdm-n
  grouping wson-label-hop:
    +-- (grid-type)?
       +--:(dwdm)
       |  +-- (single-or-super-channel)?
       |     +--:(single)
       |     |  +-- dwdm-n?              l0-types:dwdm-n
       |     +--:(super)
       |        +-- subcarrier-dwdm-n*   l0-types:dwdm-n
       +--:(cwdm)
          +-- cwdm-n?                    l0-types:cwdm-n
  grouping l0-label-range-info:
    +-- grid-type?   identityref
    +-- priority?    uint8
  grouping wson-label-step:
    +-- (l0-grid-type)?
       +--:(dwdm)
       |  +-- wson-dwdm-channel-spacing?   identityref
       +--:(cwdm)
          +-- wson-cwdm-channel-spacing?   identityref
  grouping flexi-grid-label-start-end:
    +-- flexi-n?   l0-types:flexi-n
  grouping flexi-grid-frequency-slot:
    +-- flexi-n?   l0-types:flexi-n
    +-- flexi-m?   l0-types:flexi-m
  grouping flexi-grid-label-hop:
    +-- (single-or-super-channel)?
       +--:(single)
       |  +-- flexi-n?              l0-types:flexi-n
       |  +-- flexi-m?              l0-types:flexi-m
       x--:(super)
       |  +-- subcarrier-flexi-n* [flexi-n]
       |     +-- flexi-n?   l0-types:flexi-n
       |     +-- flexi-m?   l0-types:flexi-m
       +--:(multi)
          +-- frequency-slots
             +-- frequency-slot* [flexi-n]
                +-- flexi-n?   l0-types:flexi-n
                +-- flexi-m?   l0-types:flexi-m
  grouping flexi-grid-label-range-info:
    +-- grid-type?    identityref
    +-- priority?     uint8
    +-- flexi-grid
       +-- slot-width-granularity?   identityref
       +-- min-slot-width-factor?    uint16
       +-- max-slot-width-factor?    uint16
  grouping flexi-grid-label-step:
    x-- flexi-grid-channel-spacing?   identityref
    +-- flexi-ncfg?                   identityref
    +-- flexi-n-step?                 uint8
  grouping transceiver-mode:
    +-- (mode)
       +--:(G.698.2)
       |  +--ro standard-mode?            standard-mode
       |  +--ro line-coding-bitrate*      identityref
       |  +-- min-central-frequency?    frequency-thz
       |  +-- max-central-frequency?    frequency-thz
       |  +-- transceiver-tunability?   frequency-ghz
       |  +--ro tx-channel-power-min?     power-dbm
       |  +--ro tx-channel-power-max?     power-dbm
       |  +--ro rx-channel-power-min?     power-dbm
       |  +--ro rx-channel-power-max?     power-dbm
       |  +--ro rx-total-power-max?       power-dbm
       +--:(organizational-mode)
       |  +--ro organizational-mode
       |     +--ro operational-mode?          operational-mode
       |     +--ro organization-identifier?   organization-identifier
       |     +--ro line-coding-bitrate*       identityref
       |     +--ro min-central-frequency?     frequency-thz
       |     +--ro max-central-frequency?     frequency-thz
       |     +--ro transceiver-tunability?    frequency-ghz
       |     +--ro tx-channel-power-min?      power-dbm
       |     +--ro tx-channel-power-max?      power-dbm
       |     +--ro rx-channel-power-min?      power-dbm
       |     +--ro rx-channel-power-max?      power-dbm
       |     +--ro rx-total-power-max?        power-dbm
       +--:(explicit-mode)
          +--ro explicit-mode
             +--ro line-coding-bitrate?                identityref
             +--ro bitrate?                            uint16
             +--ro max-diff-group-delay?               uint32
             +--ro max-chromatic-dispersion?           decimal64
             +--ro cd-penalty* []
             |  +--ro cd-value         union
             |  +--ro penalty-value    union
             +--ro max-polarization-mode-dispersion?   decimal64
             +--ro pmd-penalty* []
             |  +--ro pmd-value        union
             |  +--ro penalty-value    union
             +--ro max-polarization-dependant-loss
             |       power-loss-or-null
             +--ro pdl-penalty* []
             |  +--ro pdl-value        power-loss-or-null
             |  +--ro penalty-value    union
             +--ro available-modulation-type?          identityref
             +--ro min-OSNR?                           snr
             +--ro rx-ref-channel-power?               power-dbm
             +--ro rx-channel-power-penalty* []
             |  +--ro rx-channel-power-value    power-dbm-or-null
             |  +--ro penalty-value             union
             +--ro min-Q-factor?                       int32
             +--ro available-baud-rate?                uint32
             +--ro roll-off?                           decimal64
             +--ro min-carrier-spacing?                frequency-ghz
             +--ro available-fec-type?                 identityref
             +--ro fec-code-rate?                      decimal64
             +--ro fec-threshold?                      decimal64
             +--ro in-band-osnr?                       snr
             +--ro out-of-band-osnr?                   snr
             +--ro tx-polarization-power-difference?   decimal-2
             +--ro polarization-skew?                  decimal64
             +--ro min-central-frequency?              frequency-thz
             +--ro max-central-frequency?              frequency-thz
             +--ro transceiver-tunability?             frequency-ghz
             +--ro tx-channel-power-min?               power-dbm
             +--ro tx-channel-power-max?               power-dbm
             +--ro rx-channel-power-min?               power-dbm
             +--ro rx-channel-power-max?               power-dbm
             +--ro rx-total-power-max?                 power-dbm
             +--ro compatible-modes
  grouping transceiver-capabilities:
    +-- supported-modes!
       +--ro supported-mode* [mode-id]
          +--ro mode-id?                        string
          +--ro (mode)
             +--:(G.698.2)
             |  +--ro standard-mode?            standard-mode
             |  +--ro line-coding-bitrate*      identityref
             |  +--ro min-central-frequency?    frequency-thz
             |  +--ro max-central-frequency?    frequency-thz
             |  +--ro transceiver-tunability?   frequency-ghz
             |  +--ro tx-channel-power-min?     power-dbm
             |  +--ro tx-channel-power-max?     power-dbm
             |  +--ro rx-channel-power-min?     power-dbm
             |  +--ro rx-channel-power-max?     power-dbm
             |  +--ro rx-total-power-max?       power-dbm
             +--:(organizational-mode)
             |  +--ro organizational-mode
             |     +--ro operational-mode?          operational-mode
             |     +--ro organization-identifier?
             |     |       organization-identifier
             |     +--ro line-coding-bitrate*       identityref
             |     +--ro min-central-frequency?     frequency-thz
             |     +--ro max-central-frequency?     frequency-thz
             |     +--ro transceiver-tunability?    frequency-ghz
             |     +--ro tx-channel-power-min?      power-dbm
             |     +--ro tx-channel-power-max?      power-dbm
             |     +--ro rx-channel-power-min?      power-dbm
             |     +--ro rx-channel-power-max?      power-dbm
             |     +--ro rx-total-power-max?        power-dbm
             +--:(explicit-mode)
                +--ro explicit-mode
                   +--ro line-coding-bitrate?
                   |       identityref
                   +--ro bitrate?                            uint16
                   +--ro max-diff-group-delay?               uint32
                   +--ro max-chromatic-dispersion?
                   |       decimal64
                   +--ro cd-penalty* []
                   |  +--ro cd-value         union
                   |  +--ro penalty-value    union
                   +--ro max-polarization-mode-dispersion?
                   |       decimal64
                   +--ro pmd-penalty* []
                   |  +--ro pmd-value        union
                   |  +--ro penalty-value    union
                   +--ro max-polarization-dependant-loss
                   |       power-loss-or-null
                   +--ro pdl-penalty* []
                   |  +--ro pdl-value        power-loss-or-null
                   |  +--ro penalty-value    union
                   +--ro available-modulation-type?
                   |       identityref
                   +--ro min-OSNR?                           snr
                   +--ro rx-ref-channel-power?
                   |       power-dbm
                   +--ro rx-channel-power-penalty* []
                   |  +--ro rx-channel-power-value
                   |  |       power-dbm-or-null
                   |  +--ro penalty-value             union
                   +--ro min-Q-factor?                       int32
                   +--ro available-baud-rate?                uint32
                   +--ro roll-off?
                   |       decimal64
                   +--ro min-carrier-spacing?
                   |       frequency-ghz
                   +--ro available-fec-type?
                   |       identityref
                   +--ro fec-code-rate?
                   |       decimal64
                   +--ro fec-threshold?
                   |       decimal64
                   +--ro in-band-osnr?                       snr
                   +--ro out-of-band-osnr?                   snr
                   +--ro tx-polarization-power-difference?
                   |       decimal-2
                   +--ro polarization-skew?
                   |       decimal64
                   +--ro min-central-frequency?
                   |       frequency-thz
                   +--ro max-central-frequency?
                   |       frequency-thz
                   +--ro transceiver-tunability?
                   |       frequency-ghz
                   +--ro tx-channel-power-min?
                   |       power-dbm
                   +--ro tx-channel-power-max?
                   |       power-dbm
                   +--ro rx-channel-power-min?
                   |       power-dbm
                   +--ro rx-channel-power-max?
                   |       power-dbm
                   +--ro rx-total-power-max?
                   |       power-dbm
                   +--ro compatible-modes
                      +--ro supported-application-codes*
                      |       -> ../../../mode-id
                      +--ro supported-organizational-modes*
                              -> ../../../mode-id
  grouping standard-mode:
    +--ro standard-mode?   standard-mode
  grouping organizational-mode:
    +--ro operational-mode?          operational-mode
    +--ro organization-identifier?   organization-identifier
  grouping penalty-value:
    +--ro penalty-value    union
  grouping common-explicit-mode:
    +--ro line-coding-bitrate?                identityref
    +--ro bitrate?                            uint16
    +--ro max-diff-group-delay?               uint32
    +--ro max-chromatic-dispersion?           decimal64
    +--ro cd-penalty* []
    |  +--ro cd-value         union
    |  +--ro penalty-value    union
    +--ro max-polarization-mode-dispersion?   decimal64
    +--ro pmd-penalty* []
    |  +--ro pmd-value        union
    |  +--ro penalty-value    union
    +--ro max-polarization-dependant-loss     power-loss-or-null
    +--ro pdl-penalty* []
    |  +--ro pdl-value        power-loss-or-null
    |  +--ro penalty-value    union
    +--ro available-modulation-type?          identityref
    +--ro min-OSNR?                           snr
    +--ro rx-ref-channel-power?               power-dbm
    +--ro rx-channel-power-penalty* []
    |  +--ro rx-channel-power-value    power-dbm-or-null
    |  +--ro penalty-value             union
    +--ro min-Q-factor?                       int32
    +--ro available-baud-rate?                uint32
    +--ro roll-off?                           decimal64
    +--ro min-carrier-spacing?                frequency-ghz
    +--ro available-fec-type?                 identityref
    +--ro fec-code-rate?                      decimal64
    +--ro fec-threshold?                      decimal64
    +--ro in-band-osnr?                       snr
    +--ro out-of-band-osnr?                   snr
    +--ro tx-polarization-power-difference?   decimal-2
    +--ro polarization-skew?                  decimal64
  grouping common-standard-organizational-mode:
    +--ro line-coding-bitrate*   identityref
  grouping transmitter-tuning-range:
    +-- min-central-frequency?    frequency-thz
    +-- max-central-frequency?    frequency-thz
    +-- transceiver-tunability?   frequency-ghz
  grouping common-all-modes:
    +-- min-central-frequency?    frequency-thz
    +-- max-central-frequency?    frequency-thz
    +-- transceiver-tunability?   frequency-ghz
    +--ro tx-channel-power-min?     power-dbm
    +--ro tx-channel-power-max?     power-dbm
    +--ro rx-channel-power-min?     power-dbm
    +--ro rx-channel-power-max?     power-dbm
    +--ro rx-total-power-max?       power-dbm
  grouping common-transceiver-configured-param:
    +--ro line-coding-bitrate?   identityref
    +-- tx-channel-power?      power-dbm-or-null
    +--ro rx-channel-power?      power-dbm-or-null
    +--ro rx-total-power?        power-dbm-or-null
  grouping l0-tunnel-attributes:
    +-- bit-stuffing?            boolean
    +-- wavelength-assignment?   identityref
  grouping frequency-range:
    +-- lower-frequency    frequency-thz
    +-- upper-frequency    frequency-thz
  grouping l0-path-constraints:
    +-- gsnr-margin?   snr
  grouping l0-path-properties:
    +--ro estimated-gsnr?          snr
    +--ro estimated-eol-gsnr?      snr
    +--ro estimated-lowest-gsnr?   snr
]]></artwork></figure>

</section>
<section anchor="yang-code"><name>YANG Module for Layer 0 Types</name>

<figure title="Layer 0 Types YANG module" anchor="fig-yang-code"><sourcecode type="yang" markers="true" name="ietf-layer0-types@2024-01-23.yang"><![CDATA[
module ietf-layer0-types {
  yang-version 1.1;
  namespace "urn:ietf:params:xml:ns:yang:ietf-layer0-types";
  prefix l0-types;

  organization
    "IETF CCAMP Working Group";
  contact
    "WG Web:  <https://datatracker.ietf.org/wg/ccamp/>
     WG List: <mailto:ccamp@ietf.org>

     Editor:  Dieter Beller
              <mailto:Dieter.Beller@nokia.com>

     Editor:  Sergio Belotti
              <mailto:Sergio.Belotti@nokia.com>

     Editor:  Italo Busi
              <mailto:Italo.Busi@huawei.com>

     Editor:  Haomian Zheng
              <mailto:zhenghaomian@huawei.com>";
  description
    "This module defines Optical Layer 0 types.  This module
     provides groupings that can be applicable to Layer 0
     Fixed Optical Networks (e.g., CWDM (Coarse Wavelength
     Division Multiplexing) and DWDM (Dense Wavelength Division
     Multiplexing)) and flexi-grid optical networks.

     Copyright (c) 2024 IETF Trust and the persons identified
     as authors of the code.  All rights reserved.

     Redistribution and use in source and binary forms, with
     or without modification, is permitted pursuant to, and
     subject to the license terms contained in, the Revised
     BSD License set forth in Section 4.c of the IETF Trust's
     Legal Provisions Relating to IETF Documents
     (https://trustee.ietf.org/license-info).

     This version of this YANG module is part of RFC XXXX; see
     the RFC itself for full legal notices.

     The key words 'MUST', 'MUST NOT', 'REQUIRED', 'SHALL', 'SHALL
     NOT', 'SHOULD', 'SHOULD NOT', 'RECOMMENDED', 'NOT RECOMMENDED',
     'MAY', and 'OPTIONAL' in this document are to be interpreted as
     described in BCP 14 (RFC 2119) (RFC 8174) when, and only when,
     they appear in all capitals, as shown here.";

// RFC Ed.: replace XXXX with actual RFC number and remove
// this note

// replace the revision date with the module publication date
// the format is (year-month-day)
  revision 2024-01-23 {
    description
      "To be updated";
    reference
      "RFC XXXX: A YANG Data Model for Layer 0 Types";
  }

  revision 2021-08-13 {
    description
      "Initial version";
    reference
      "RFC 9093: A YANG Data Model for Layer 0 Types";
  }

/*
 * Identities
 */

  identity l0-grid-type {
    description
      "Layer 0 grid type";
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable 
      (LSC), Label Switching Routers,

       ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
       CWDM wavelength grid";
  }

    identity wson-grid-cwdm {
      base l0-grid-type;
      description
        "CWDM grid";
      reference
        "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
        Label Switching Routers,

        ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
        CWDM wavelength grid";
    }

    identity wson-grid-dwdm {
      base l0-grid-type;
      description
        "DWDM grid";
      reference
        "RFC 6205: Generalized Labels for Lambda-Switch-Capable 
        (LSC), Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

    identity flexi-grid-dwdm {
      base l0-grid-type;
      description
        "Flexi-grid";
      reference
        "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
        Switch Capable (LSC) Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

  identity cwdm-ch-spc-type {
    description
      "CWDM channel-spacing type";
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers,
       
       ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
       CWDM wavelength grid";
  }

    identity cwdm-20nm {
      base cwdm-ch-spc-type;
      description
        "20nm channel spacing";
      reference
        "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
        Label Switching Routers,
        
        ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
        CWDM wavelength grid";
    }

  identity dwdm-ch-spc-type {
    description
      "DWDM channel-spacing type";
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers,

       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency grid";
  }

    identity dwdm-100ghz {
      base dwdm-ch-spc-type;
      description
        "100 GHz channel spacing";
      reference
        "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
        Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

    identity dwdm-50ghz {
      base dwdm-ch-spc-type;
      description
        "50 GHz channel spacing";
      reference
        "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
        Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

    identity dwdm-25ghz {
      base dwdm-ch-spc-type;
      description
        "25 GHz channel spacing";
      reference
        "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
        Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

    identity dwdm-12p5ghz {
      base dwdm-ch-spc-type;
      description
        "12.5 GHz channel spacing";
      reference
        "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
        Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

  identity flexi-ch-spc-type {
    status deprecated;
    description
      "Flexi-grid channel-spacing type";
  }

    identity flexi-ch-spc-6p25ghz {
      base flexi-ch-spc-type;
      status deprecated;
      description
        "6.25 GHz channel spacing";
    }

  identity flexi-ncfg-type {
    description
      "Flexi-grid Nominal Central Frequency Granularity (NCFG) 
      type";
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers,

      ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
      DWDM frequency grid";
  }

    identity flexi-ncfg-6p25ghz {
      base flexi-ncfg-type;
      description
        "6.25 GHz Nominal Central Frequency Granularity (NCFG)";
      reference
        "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
        Switch Capable (LSC) Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

  identity flexi-slot-width-granularity {
    description
      "Flexi-grid slot width granularity";
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers,

      ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
      DWDM frequency grid";
  }

    identity flexi-swg-12p5ghz {
      base flexi-slot-width-granularity;
      description
        "12.5 GHz slot width granularity";
      reference
        "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
        Switch Capable (LSC) Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

  identity modulation {
    description "base identity for modulation type";
  }

    identity DPSK {
      base modulation;
      description
        "DPSK (Differential Phase Shift Keying) modulation";
    }

    identity QPSK {
      base modulation;
      description
        "QPSK (Quadrature Phase Shift Keying) modulation";
    }

    identity DP-QPSK {
      base modulation;
      description
        "DP-QPSK (Dual Polarization Quadrature
        Phase Shift Keying) modulation";
    }

    identity QAM8 {
      base modulation;
      description
        "8QAM (8 symbols Quadrature Amplitude Modulation)";
    }

    identity DP-QAM8 {
      base modulation;
      description
        "DP-QAM8 (8 symbols Dual Polarization Quadrature Amplitude
        Modulation)";
    }

    identity QAM16 {
      base modulation;
      description
        "QAM16 (16 symbols Quadrature Amplitude Modulation)";
    }

    identity DP-QAM16 {
      base modulation;
      description
        "DP-QAM16 (16 symbols Dual Polarization Quadrature Amplitude 
        Modulation)";
    }

    identity QAM32 {
      base modulation;
      description
        "QAM32 (32 symbols Quadrature Amplitude Modulation)";
    }

    identity DP-QAM32 {
      base modulation;
      description
        "DP-QAM32 (32 symbols Dual Polarization Quadrature Amplitude
        Modulation)";
    }

    identity QAM64 {
      base modulation;
      description
        "QAM64 (64 symbols Quadrature Amplitude Modulation)";
    }

    identity DP-QAM64 {
      base modulation;
      description
        "DP-QAM64 (64 symbols Dual Polarization Quadrature Amplitude
        Modulation)";
    }

  identity fec-type {
    description
      "Base identity from which specific FEC
      (Forward Error Correction) type identities are derived.";
  }

    identity g-fec {
      base fec-type;
      description
        "Generic Forward Error Correction (G-FEC).";
      reference
        "ITU-T G.975 v2.0 (10/2000): Forward error correction for 
        submarine systems.";
    }

    identity super-fec {
      base fec-type;
      description
        "Super Forward Error Correction (S-FEC).";
      reference
        "ITU-T G.975.1 v1.2 (07/2013): Forward error correction for 
        high bit-rate DWDM submarine systems.";
    }

    identity no-fec {
      base fec-type;
      description
        "No FEC";
    }

    identity sc-fec {
      base fec-type;
      description
        "Staircase Forward Error Correction (SC-FEC).";
      reference
        "Annex A of ITU-T G.709.2 v1.1 (09/2020):OTU4 long-reach 
        interface.";
    }

    identity o-fec {
      base fec-type;
      description
        "Open Forward Error Correction (O-FEC) which reuses the 
        Bose, Chaudhuri and Hocquenghem (BCH) FEC.";
      reference
        "Clause 16.4.4 of ITU-T G.709.3 v2.1 (11/2022): Flexible OTN 
        long-reach interfaces;

        Annex E of ITU-T G.709.3 v2.1 (11/2022): Flexible OTN 
        long-reach interfaces.";
    }

    identity c-fec {
      base fec-type;
      description
        "Concatenated FEC (C-FEC) that combines an outer Staircase 
        Forward Error Correction (SC-FEC) code and an inner 
        double-extended SD-FEC (128,119) Hamming code.
        
        More details are provided in clause 15/G.709.3 where it is 
        called DSH instead of concatenated FEC.";
      reference
        "Annex A of ITU-T G.709.2 v1.1 (09/2020):OTU4 long-reach 
        interface;
        
        Annex D of ITU-T G.709.3 v2.1 (11/2022): Flexible OTN 
        long-reach interfaces;
        
        Clause 15 of ITU-T G.709.3 v2.1 (11/2022): Flexible OTN 
        long-reach interfaces.";
    }

  identity line-coding {
    description
      "Base identity to defined the bit rate/line coding of optical 
      tributary signals.";
    reference 
      "Section 7.1.2 of ITU-T G.698.2 v3.0 (11/2018).";
  }  

    identity line-coding-NRZ-2p5G {
      base line-coding;
      description
        "The non return to zero (NRZ) bit rate/line coding used by 
        the optical tributary signal class NRZ 2.5G";
      reference 
        "Section 3.2.6 of ITU-T G.959.1 v8.0 (07/2018).";
    }

    identity line-coding-NRZ-OTU1 {
      base line-coding;
      description
        "The non return to zero (NRZ) bit rate/line coding used by 
        the Optical channel Transport Unit order 1 (OTU1) optical 
        tributary signals";
      reference 
        "Section 7.2.1.2 of ITU-T G.959.1 v8.0 (07/2018).";
    }

    identity line-coding-NRZ-10G {
      description
        "The non return to zero (NRZ) bit rate/line coding used by 
        the optical tributary signal class NRZ 10G";
      reference 
        "Section 3.2.7 of ITU-T G.959.1 v8.0 (07/2018).";
    }

    identity line-coding-NRZ-OTU2 {
      base line-coding;
      description
        "The non return to zero (NRZ) bit rate/line coding used by 
        the Optical channel Transport Unit order 2 (OTU2) optical 
        tributary signals";
      reference 
        "Section 7.2.1.2 of ITU-T G.959.1 v8.0 (07/2018).";
    }

    identity line-coding-OTL4.4-SC {
      base line-coding;
      description
        "The bit rate/line coding used by optical tributary 
        signals carrying a 100G Optical Transport Unit order 4 
        (OTU4) with Staircase Forward Error Correction (SC FEC) 
        from a group of four Optical Transport Lanes (OTL).";
      reference 
        "Section 3.2.1 of ITU-T G.698.2 v3.0 (11/2018).";
    }

    identity line-coding-FOIC1.4-SC {
      base line-coding;
      description
        "The bit rate/line coding used by optical tributary signals 
        carrying a FlexO Interface of order C1 with 4 lanes 
        (FOIC1.1) with Staircase Forward Error Correction 
        (SC FEC).";
      reference 
        "Section 3.2.1 of ITU-T G.698.2 v3.0 (11/2018).";
    }

  identity wavelength-assignment {
    description
      "Wavelength selection base";
    reference
      "RFC 7689: Signaling Extensions for Wavelength Switched 
      Optical Networks";
  }

    identity first-fit-wavelength-assignment {
      base wavelength-assignment;
      description
        "All the available wavelengths are numbered,
        and this WA (Wavelength Assignment) method chooses
        the available wavelength with the lowest index";
      reference
        "RFC 7689: Signaling Extensions for Wavelength Switched 
        Optical Networks";
    }

    identity random-wavelength-assignment {
      base wavelength-assignment;
      description
        "This WA method chooses an available
        wavelength randomly";
      reference
        "RFC 7689: Signaling Extensions for Wavelength Switched 
        Optical Networks";
    }

    identity least-loaded-wavelength-assignment {
      base wavelength-assignment;
      description
        "This WA method selects the wavelength that
        has the largest residual capacity on the most loaded
        link along the route (in multi-fiber networks)";
      reference
        "RFC 7689: Signaling Extensions for Wavelength Switched 
        Optical Networks";
    }

  identity term-type {
    description
      "Termination type";
    reference
      "ITU-T G.709: Interfaces for the Optical Transport Network";
  }

    identity term-phys {
      base term-type;
      description
        "Physical layer termination";
    }

    identity term-otu {
      base term-type;
      description
        "OTU (Optical Transport Unit) termination";
    }

    identity term-odu {
      base term-type;
      description
        "ODU (Optical Data Unit) termination";
    }

    identity term-opu {
      base term-type;
      description
        "OPU (Optical Payload Unit) termination";
    }

  identity otu-type {
    description
      "Base identity from which specific OTU identities are derived";
    reference
      "ITU-T G.709: Interfaces for the Optical Transport Network";
  }

    identity OTU1 {
      base otu-type;
      description
        "OTU1 (2.66 Gb/s)";
    }

    identity OTU1e {
      base otu-type;
      description
        "OTU1e (11.04 Gb/s)";
    }

    identity OTU1f {
      base otu-type;
      description
        "OTU1f (11.27 Gb/s)";
    }

    identity OTU2 {
      base otu-type;
      description
        "OTU2 (10.70 Gb/s)";
    }

    identity OTU2e {
      base otu-type;
      description
        "OTU2e (11.09 Gb/s)";
    }

    identity OTU2f {
      base otu-type;
      description
        "OTU2f (11.31G)";
    }

    identity OTU3 {
      base otu-type;
      description
        "OTU3 (43.01 Gb/s)";
    }

    identity OTU3e1 {
      base otu-type;
      description
        "OTU3e1 (44.57 Gb/s)";
    }

    identity OTU3e2 {
      base otu-type;
      description
        "OTU3e2 (44.58 Gb/s)";
    }

    identity OTU4 {
      base otu-type;
      description
        "OTU4 (111.80 Gb/s)";
    }

    identity OTUCn {
      base otu-type;
      description
        "OTUCn (n x 105.25 Gb/s)";
    }

  identity type-power-mode {
    description
      "power equalization mode used within the 
       OMS and its elements";
  }

    identity power-spectral-density {
      base type-power-mode;
      description
        "all elements must use power spectral density (W/Hz)";
    }

    identity carrier-power {
      base type-power-mode;
      description
        "all elements must use power (dBm)";
    }

  identity operational-mode {
    description
      "Base identity to be used when defining organization/vendor 
      specific modes.
      
      The format of the derived identities has to be defined by the 
      organization which is responsible for defining the 
      corresponding optical interface specification.";
    reference
      "Section 2.5.2 of RFC YYYY: A YANG Data Model for Optical
      Impairment-aware Topology.";
  }
// RFC Ed.: replace YYYY with actual RFC number and remove
// this note after draft-ietf-ccamp-optical-impairment-topology-yang
// is published as an RFC

/*
 * Typedefs
 */

  typedef dwdm-n {
    type int16;
    description
      "The given value 'N' is used to determine the nominal central
       frequency.

       The nominal central frequency, 'f', is defined by:
         f = 193100.000 GHz + N x channel spacing (measured in GHz),

       where 193100.000 GHz (193.100000 THz) is the ITU-T 'anchor
       frequency' for transmission over the DWDM grid, and where
       'channel spacing' is defined by the dwdm-ch-spc-type.";
    reference
      "RFC6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers,

       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency grid";
  }

  typedef cwdm-n {
    type int16;
    description
      "The given value 'N' is used to determine the nominal central
       wavelength.

       The nominal central wavelength is defined by:
         Wavelength = 1471 nm + N x channel spacing (measured in nm)

       where 1471 nm is the conventional 'anchor wavelength' for
       transmission over the CWDM grid, and where 'channel spacing'
       is defined by the cwdm-ch-spc-type.";
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers,

       ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
       CWDM wavelength grid";
  }

  typedef flexi-n {
    type int16;
    description
      "The given value 'N' is used to determine the nominal central
       frequency.

       The nominal central frequency, 'f', is defined by:
         f = 193100.000 GHz + N x NCFG (measured in GHz),

       where 193100.000 GHz (193.100000 THz) is the ITU-T 'anchor
       frequency' for transmission over the DWDM grid, and where
       NCFG is defined by the flexi-ncfg-type, or by the deprecated 
       flexi-ch-spc-type.";
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers,

       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency grid";
  }

  typedef flexi-m {
    type uint16;
    description
      "The given value 'M' is used to determine the slot width.

       A slot width is defined by:
         slot width = M x SWG (measured in GHz),

       where SWG is defined by the flexi-slot-width-granularity.";
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers,

       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency grid";
  }

  typedef standard-mode {
    type string;
    description
      "Identifies an ITU-T G.698.2 standard application code.

      It MUST be a string with a format that follows the 
      nomenclature defined in section 5.3 of ITU-T G.698.2.";
    reference
      "ITU-T G.698.2 (11/2018)";
  }

  typedef organization-identifier {
    type string;
    description
      "vendor/organization identifier that uses a private mode
      out of already defined in G.698.2 ITU-T application-code";
    reference
      "Section 2.5.2 of RFC YYYY: A YANG Data Model for Optical
      Impairment-aware Topology.";
  }
// RFC Ed.: replace YYYY with actual RFC number and remove
// this note after draft-ietf-ccamp-optical-impairment-topology-yang
// is published as an RFC

  typedef operational-mode {
    type identityref {
      base operational-mode;
    }
    description
      "Identifies an organization (e.g., vendor) specific mode.
      
      The format of these identities has to be defined by the 
      organization which is responsible for defining the 
      corresponding optical interface specification.";
    reference
      "Section 2.5.2 of RFC YYYY: A YANG Data Model for Optical
      Impairment-aware Topology.";
  }
// RFC Ed.: replace YYYY with actual RFC number and remove
// this note after draft-ietf-ccamp-optical-impairment-topology-yang
// is published as an RFC

  typedef frequency-thz {
    type decimal64 {
      fraction-digits 9;
    }
    units "THz";
    description
      "The DWDM frequency in THz, e.g., 193.112500000";
  }

  typedef frequency-ghz {
    type decimal64 {
      fraction-digits 6;
    }
    units "GHz";
    description
      "The DWDM frequency in GHz, e.g., 193112.500000";
  }    

  typedef snr {
    type decimal64 {
      fraction-digits 2;
    }
    units "dB@0.1nm";
    description
      "(Optical) Signal to Noise Ratio measured over 0.1 nm
      resolution bandwidth";
  }

  typedef snr-or-null {
    type union {
      type snr;
      type empty;
    }
    description
      "(Optical) Signal to Noise Ratio measured over 0.1 nm
      resolution bandwidth, when known, or an empty value when
      unknown.";
  }

  typedef fiber-type {
    type enumeration {
      enum G.652 {
        description
          "G.652 Standard Singlemode Fiber";                 
      }
      enum G.654 {
        description
          "G.654 Cutoff Shifted Fiber";
      }
      enum G.653 {
        description "G.653 Dispersion Shifted Fiber";
      }
      enum G.655 {
        description "G.655 Non-Zero Dispersion Shifted Fiber";
      }
      enum G.656 {
        description
          "G.656 Non-Zero Dispersion for Wideband Optical Transport";
      }
      enum G.657 {
        description
          "G.657 Bend-Insensitive Fiber";
      }
    }
    description
      "ITU-T based fiber-types";
  }

  typedef decimal-2 {
    type decimal64 {
      fraction-digits 2;
    }
    description
      "A decimal64 value with two digits.";
  }

  typedef decimal-2-or-null {
    type union {
      type decimal-2;
      type empty;
    }
    description
      "A decimal64 value with two digits, when the value is known or
      an empty value when the value is not known.";
  }

  typedef power-gain {
    type decimal-2 {
      range "0..max";
    }
    units "dB";
    description
      "The gain in dB.";
  }

  typedef power-gain-or-null {
    type union {
      type power-gain;
      type empty;
    }
    description
      "The gain in dB, when it is known or an empty 
      value when the power gain/loss is not known.";
  }

  typedef power-loss {
    type decimal-2 {
      range "0..max";
    }
    units "dB";
    description
      "The power attenuation in dB.";
  }

  typedef power-loss-or-null {
    type union {
      type power-loss;
      type empty;
    }
    description
      "The power attenuation in dB, when it is known or an empty 
      value when the loss is not known.";
  }

  typedef power-ratio {
    type decimal-2;
    units "dB";
    description
      "The power difference in dB.";
  }

  typedef power-ratio-or-null {
    type union {
      type power-ratio;
      type empty;
    }
    description
      "The power difference in dB, when it is known or an empty 
      value when the difference is not known.";
  }

  typedef power-dbm {
    type decimal-2;
    units "dBm";
    description
      "The power in dBm.";
  }

  typedef power-dbm-or-null {
    type union {
      type power-dbm;
      type empty;
    }
    description
      "The power in dBm, when it is known or an empty value when the
      power is not known.";
  }

  typedef decimal-5 {
    type decimal64 {
      fraction-digits 5;
    }
    description
      "A decimal64 value with five digits.";
  }

  typedef decimal-5-or-null {
    type union {
      type decimal-5;
      type empty;
    }
    description
      "A decimal64 value with five digits, when the value is known 
      or an empty value when the value is not known.";
  }

  typedef psd {
    type decimal64 {
      fraction-digits 16;
    }
    units "W/Hz";
    description
      "The power spectral density (PSD).
      
      Typical value : 3.9 E-14, resolution 0.1nW/MHz.";
  }

  typedef psd-or-null {
    type union {
      type psd;
      type empty;
    }
    description
      "The power spectral density (PSD), when it is known or an
      empty value when the PSD is not known.";
  }

/*
 * Groupings
 */

  grouping wdm-label-start-end {
    description
      "The WDM label-start or label-end used to specify DWDM and
       CWDM label range.";

    choice grid-type {
      description
        "Label for fixed & flexi-DWDM or CWDM grid";
      case fixed-dwdm {
        leaf dwdm-n {
          when "derived-from-or-self(../../../grid-type,
                \"wson-grid-dwdm\")" {
            description
              "Valid only when grid type is DWDM.";
          }
          type l0-types:dwdm-n;
          description
            "The given value 'N' is used to determine the
             nominal central frequency.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case cwdm {
        leaf cwdm-n {
          when "derived-from-or-self(../../../grid-type,
                \"wson-grid-cwdm\")" {
            description
              "Valid only when grid type is CWDM.";
          }
          type l0-types:cwdm-n;
          description
            "The given value 'N' is used to determine the nominal
             central wavelength.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case flexi-grid {
        uses l0-types:flexi-grid-label-start-end;
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers";
  }

  grouping wdm-label-step {
    description
      "Label step information for fixed & flexi-DWDM or CWDM grid";
    choice l0-grid-type {
      description
        "Grid type: DWDM, CWDM, etc.";
      case fixed-dwdm {
        leaf wson-dwdm-channel-spacing {
          when "derived-from-or-self(../../grid-type,
                \"wson-grid-dwdm\")" {
            description
              "Valid only when grid type is DWDM.";
          }
          type identityref {
            base dwdm-ch-spc-type;
          }
          description
            "Label-step is the channel spacing (GHz), e.g., 100.000,
             50.000, 25.000, or 12.500 GHz for DWDM.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case cwdm {
        leaf wson-cwdm-channel-spacing {
          when "derived-from-or-self(../../grid-type,
                \"wson-grid-cwdm\")" {
            description
              "Valid only when grid type is CWDM.";
          }
          type identityref {
            base cwdm-ch-spc-type;
          }
          description
            "Label-step is the channel spacing (nm), i.e., 20 nm
             for CWDM, which is the only value defined for CWDM.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case flexi-grid {
        uses flexi-grid-label-step;
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers,
       ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
       CWDM wavelength grid,
       RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-Grid
       Dense Wavelength Division Multiplexing (DWDM) Networks";
  }

  grouping wdm-label-hop {
    description
      "Generic label-hop information for fixed & flexi-DWDM or
       CWDM grid";
    choice grid-type {
      description
        "Label for DWDM or CWDM grid";
      case fixed-dwdm {
        choice fixed-single-or-super-channel {
          description
            "single or super channel";
          case single {
            leaf dwdm-n {
              type l0-types:dwdm-n;
              description
                "The given value 'N' is used to determine the
                 nominal central frequency.";
            }
          }
          case multi {
            leaf-list subcarrier-dwdm-n {
              type l0-types:dwdm-n;
              min-elements 2;
              description
                "The given values 'N' are used to determine the
                 nominal central frequency for each subcarrier
                 channel.";
              reference
                "ITU-T G.694.1 (10/2020): Spectral grids for WDM
                applications: DWDM frequency grid";
            }
          }
        }
      }
      case cwdm {
        leaf cwdm-n {
          type l0-types:cwdm-n;
          description
            "The given value 'N' is used to determine the nominal
             central wavelength.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case flexi-grid {
        uses l0-types:flexi-grid-label-hop;
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers";
  }

  grouping wdm-label-range-info {
    description
      "WDM label range related information";
    uses l0-label-range-info;
    container flexi-grid {
      when "derived-from-or-self(../grid-type,
          \"flexi-grid-dwdm\")" {
        description
          "Applicable only when the grid type is flexi-grid-dwdm.";
      }
      description
        "flexi-grid definition";
      leaf slot-width-granularity {
        type identityref {
          base flexi-slot-width-granularity;
        }
        default "flexi-swg-12p5ghz";
        description
          "Minimum space between slot widths. Default is 12.500
           GHz.";
        reference
          "RFC 7698: Framework and Requirements for GMPLS-Based
           Control of Flexi-Grid Dense Wavelength Division
           Multiplexing (DWDM) Networks";
      }
      leaf min-slot-width-factor {
        type uint16 {
          range "1..max";
        }
        default "1";
        description
          "A multiplier of the slot width granularity, indicating
           the minimum slot width supported by an optical port.

           Minimum slot width is calculated by:
             Minimum slot width (GHz) =
               min-slot-width-factor * slot-width-granularity.";
        reference
          "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-
           Grid Dense Wavelength Division Multiplexing (DWDM)
           Networks";
      }
      leaf max-slot-width-factor {
        type uint16 {
          range "1..max";
        }
        must '. >= ../min-slot-width-factor' {
          error-message
            "Maximum slot width must be greater than or equal to
             minimum slot width.";
        }
        description
          "A multiplier of the slot width granularity, indicating
           the maximum slot width supported by an optical port.

           Maximum slot width is calculated by:
             Maximum slot width (GHz) =
               max-slot-width-factor * slot-width-granularity

           If specified, maximum slot width must be greater than or
           equal to minimum slot width.  If not specified, maximum
           slot width is equal to minimum slot width.";
        reference
          "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-
           Grid Dense Wavelength Division Multiplexing (DWDM)
           Networks";
      }
    }
  }

  grouping wson-label-start-end {
    description
      "The WSON label-start or label-end used to specify WSON label
       range.";
    choice grid-type {
      description
        "Label for DWDM or CWDM grid";
      case dwdm {
        leaf dwdm-n {
          when "derived-from-or-self(../../../grid-type,
                \"wson-grid-dwdm\")" {
            description
              "Valid only when grid type is DWDM.";
          }
          type l0-types:dwdm-n;
          description
            "The central frequency of DWDM.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case cwdm {
        leaf cwdm-n {
          when "derived-from-or-self(../../../grid-type,
                \"wson-grid-cwdm\")" {
            description
              "Valid only when grid type is CWDM.";
          }
          type l0-types:cwdm-n;
          description
            "Channel wavelength computing input.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers";
  }

  grouping wson-label-hop {
    description
      "Generic label-hop information for WSON";
    choice grid-type {
      description
        "Label for DWDM or CWDM grid";
      case dwdm {
        choice single-or-super-channel {
          description
            "single or super channel";
          case single {
            leaf dwdm-n {
              type l0-types:dwdm-n;
              description
                "The given value 'N' is used to determine the
                 nominal central frequency.";
            }
          }
          case super {
            leaf-list subcarrier-dwdm-n {
              type l0-types:dwdm-n;
              description
                "The given values 'N' are used to determine the
                 nominal central frequency for each subcarrier
                 channel.";
              reference
                "ITU-T G.694.1 (10/2020): Spectral grids for WDM
                applications: DWDM frequency grid";
            }
          }
        }
      }
      case cwdm {
        leaf cwdm-n {
          type l0-types:cwdm-n;
          description
            "The given value 'N' is used to determine the nominal
             central wavelength.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers";
  }

  grouping l0-label-range-info {
    description
      "Information about Layer 0 label range.";
    leaf grid-type {
      type identityref {
        base l0-grid-type;
      }
      description
        "Grid type";
    }
    leaf priority {
      type uint8;
      description
        "Priority in Interface Switching Capability Descriptor
         (ISCD).";
      reference
        "RFC 4203: OSPF Extensions in Support of Generalized
         Multi-Protocol Label Switching (GMPLS)";
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers";
  }

  grouping wson-label-step {
    description
      "Label step information for WSON";
    choice l0-grid-type {
      description
        "Grid type: DWDM, CWDM, etc.";
      case dwdm {
        leaf wson-dwdm-channel-spacing {
          when "derived-from-or-self(../../grid-type,
                \"wson-grid-dwdm\")" {
            description
              "Valid only when grid type is DWDM.";
          }
          type identityref {
            base dwdm-ch-spc-type;
          }
          description
            "Label-step is the channel spacing (GHz), e.g., 100.000,
             50.000, 25.000, or 12.500 GHz for DWDM.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case cwdm {
        leaf wson-cwdm-channel-spacing {
          when "derived-from-or-self(../../grid-type,
                \"wson-grid-cwdm\")" {
            description
              "Valid only when grid type is CWDM.";
          }
          type identityref {
            base cwdm-ch-spc-type;
          }
          description
            "Label-step is the channel spacing (nm), i.e., 20 nm
             for CWDM, which is the only value defined for CWDM.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers,

       ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
       CWDM wavelength grid";
  }

  grouping flexi-grid-label-start-end {
    description
      "The flexi-grid label-start or label-end used to specify
       flexi-grid label range.";
    leaf flexi-n {
      type l0-types:flexi-n;
      description
        "The given value 'N' is used to determine the nominal
        central frequency.

        As described in section 3.1 of RFC 8363, the range of 
        available nominal central frequencies are advertised for 
        m=1, which means that for an available central frequency n, 
        the frequency slot from central frequency n-1 to central 
        frequency n+1 is available.";
    }
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers,
      
      RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-Grid 
      Dense Wavelength Division Multiplexing (DWDM) Networks";
  }

  grouping flexi-grid-frequency-slot {
    description
      "Flexi-grid frequency slot grouping.";
    uses flexi-grid-label-start-end;
    leaf flexi-m {
      type l0-types:flexi-m;
      description
        "The given value 'M' is used to determine the slot width.";
    }
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers";
  }

  grouping flexi-grid-label-hop {
    description
      "Generic label-hop information for flexi-grid";
    choice single-or-super-channel {
      description
        "single or super channel";
      case single {
        uses flexi-grid-frequency-slot;
      }
      case super {
        status deprecated;
        list subcarrier-flexi-n {
          key "flexi-n";
          uses flexi-grid-frequency-slot;
          description
            "List of subcarrier channels for flexi-grid super
             channel.";
        }
      }
      case multi {
        container frequency-slots {
          description
            "The top level container for the list of frequency 
            slots used for flexi-grid super channel.";
          list frequency-slot {
            key "flexi-n";
            min-elements 2;
            uses flexi-grid-frequency-slot;
            description
              "List of frequency slots used for flexi-grid super 
              channel.";
          }
        }
      }
    }
    reference
      "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-Grid 
      Dense Wavelength Division Multiplexing (DWDM) Networks";
  }

  grouping flexi-grid-label-range-info {
    description
      "Flexi-grid-specific label range related information";
    uses l0-label-range-info;
    container flexi-grid {
      description
        "flexi-grid definition";
      leaf slot-width-granularity {
        type identityref {
          base flexi-slot-width-granularity;
        }
        default "flexi-swg-12p5ghz";
        description
          "Minimum space between slot widths. Default is 12.500
           GHz.";
        reference
          "RFC 8363: GMPLS OSPF-TE Extensions in Support of 
          Flexi-Grid Dense Wavelength Division Multiplexing (DWDM) 
          Networks";
      }
      leaf min-slot-width-factor {
        type uint16 {
          range "1..max";
        }
        default "1";
        description
          "A multiplier of the slot width granularity, indicating
           the minimum slot width supported by an optical port.

           Minimum slot width is calculated by:
             Minimum slot width (GHz) =
               min-slot-width-factor * slot-width-granularity.";
        reference
          "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-
           Grid Dense Wavelength Division Multiplexing (DWDM)
           Networks";
      }
      leaf max-slot-width-factor {
        type uint16 {
          range "1..max";
        }
        must '. >= ../min-slot-width-factor' {
          error-message
            "Maximum slot width must be greater than or equal to
             minimum slot width.";
        }
        description
          "A multiplier of the slot width granularity, indicating
           the maximum slot width supported by an optical port.

           Maximum slot width is calculated by:
             Maximum slot width (GHz) =
               max-slot-width-factor * slot-width-granularity

           If specified, maximum slot width must be greater than or
           equal to minimum slot width.  If not specified, maximum
           slot width is equal to minimum slot width.";
        reference
          "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-
           Grid Dense Wavelength Division Multiplexing (DWDM)
           Networks";
      }
    }
  }

  grouping flexi-grid-label-step {
    description
      "Label step information for flexi-grid";
    leaf flexi-grid-channel-spacing {
      type identityref {
        base flexi-ch-spc-type;
      }
      default "flexi-ch-spc-6p25ghz";
      status deprecated;
      description
        "Label-step is the nominal central frequency granularity
         (GHz), e.g., 6.25 GHz.";
      reference
        "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
         Switch Capable (LSC) Label Switching Routers";
    }
    leaf flexi-ncfg {
      type identityref {
        base flexi-ncfg-type;
      }
      default "flexi-ncfg-6p25ghz";
      description
        "Label-step is the nominal central frequency granularity
         (GHz), e.g., 6.25 GHz.";
      reference
        "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
         Switch Capable (LSC) Label Switching Routers";
    }
    leaf flexi-n-step {
      type uint8;
      description
        "This attribute defines the multiplier for the supported
         values of 'N'.

         For example, given a grid with a nominal central frequency
         granularity of 6.25 GHz, the granularity of the supported
         values of the nominal central frequency could be 12.5 GHz.
         In this case, the values of flexi-n should be even and this
         constraint is reported by setting the flexi-n-step to 2.

         This attribute is also known as central frequency
         granularity in RFC 8363.";
      reference
        "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-Grid
         Dense Wavelength Division Multiplexing (DWDM) Networks";
    }
  }

  grouping transceiver-mode {
    description
      "This grouping is intended to be used for reporting the
       information of a transceiver's mode.
       
       The compatible-modes container shall be augmented with the 
       proper leafrefs when used: see for example the 
       transceiver-capabilities grouping below.";
    choice mode {
      mandatory true;
      description
        "Indicates whether the transceiver's mode is a standard
          mode, an organizational mode or an explicit mode.";
      case G.698.2 {
        uses standard-mode;
        uses common-standard-organizational-mode;
        uses common-all-modes;
      }
      case organizational-mode {
        container organizational-mode {
          config false;
          description
            "The set of attributes for an organizational mode";
          uses organizational-mode;
          uses common-standard-organizational-mode;
          uses common-all-modes;
        }  // container organizational-mode
      }
      case explicit-mode {
        container explicit-mode {
          config false;
          description
            "The set of attributes for an explicit mode";
          uses common-explicit-mode;
          uses common-all-modes;
          container compatible-modes {
            description
              "Container for all the standard and organizational
                modes supported by the transceiver's explicit
                mode.";
          }  // container compatible-modes
        }  // container explicit-mode
      } // end of case explicit-mode
    } // end of choice
  }

  grouping transceiver-capabilities {
    description
      "This grouping is intended to be used for reporting the
       capabilities of a transceiver.";

    container supported-modes {
      presence
        "When present, it indicates that the modes supported by a 
        transceiver are reported.";
      description
        "The top level container for the list supported 
        transceiver's modes.";
      list supported-mode {
        key "mode-id";
        config false;
        min-elements 1;
        description "The list of supported transceiver's modes.";
        leaf mode-id {
          type string { 
            length "1..255";
          }
          description "ID for the supported transceiver's mode.";
        }
        uses transceiver-mode {
          augment "mode/explicit-mode/explicit-mode/"
                + "compatible-modes" {
            description
              "Augments the compatible modes with the proper 
              leafrefs.";
            leaf-list supported-application-codes {
              type leafref {
                path "../../../mode-id";
              }
              must "../../../../"
                  + "supported-mode[mode-id=current()]/"
                  + "standard-mode" {
                description
                  "The pointer is only for application codes
                  supported by transceiver."; 
              }
              description
                "List of pointers to the application codes
                  supported by the transceiver's explicit mode.";
            }
            leaf-list supported-organizational-modes {
              type leafref {
                path "../../../mode-id";
              }
              must "../../../../"
                  + "supported-mode[mode-id=current()]/"
                  + "organizational-mode" {
                description
                  "The pointer is only for organizational modes
                    supported by transceiver.";
              }
              description
                "List of pointers to the organizational modes
                  supported by the transceiver's explicit mode.";
            }
          }
        }
      }  // list supported-modes
    }  // container supported-modes
  }  // grouping transceiver-capabilities

  grouping standard-mode {
    description
      "ITU-T G.698.2 standard mode that guarantees interoperability.
       It must be an string with the following format:
       B-DScW-ytz(v) where all these attributes are conformant
       to the ITU-T recomendation";

    leaf standard-mode {
      type standard-mode;
      config false;
      description
        "G.698.2 standard mode";
    }
  }

  grouping organizational-mode {
    description
      "Transponder operational mode supported by organizations or
       vendor";

    leaf operational-mode {
      type operational-mode;
      config false;
      description
        "configured organization- or vendor-specific
         application identifiers (AI) supported by the transponder";
    }
    leaf organization-identifier {
      type organization-identifier;
      config false;
      description
        "organization identifier that uses organizational
         mode";
    }
  }

  grouping penalty-value {
    description
      "A common definition of the penalty value used for describing
      multiple penalty types (.e.g, CD, PMD, PDL).";

    leaf penalty-value {
      type union {
        type decimal64 {
          fraction-digits 2;
          range "0..max";
        }
        type empty;
      }
      units "dB";
      config false;
      mandatory true;
      description
        "The OSNR penalty associated with the related optical 
        impairment at the receiver, when the value is known or an 
        empty value when the value is not known.";
    }
  }

  grouping common-explicit-mode {
    description
      "Attributes capabilities related to explicit transceiver's
      mode.
      
      This grouping also contains the list of attributes related to
      optical impairment limits for explicit mode (min OSNR, max PMD,
      max CD, max PDL, Q-factor limit, etc.).

      In case of standard and operational mode the attributes are
      implicit.";
    leaf line-coding-bitrate {
      type identityref {
        base line-coding;
      }
      config false;
      description
        "Bit rate/line coding of the optical tributary signal.";
      reference 
        "ITU-T G.698.2 section 7.1.2";
    }
    leaf bitrate {
      type uint16;
      units "Gbit/sec";
      config false;
      description
        "The gross bitrate (e.g., 100, 200) of the optical tributary
        signal.";
    }
    leaf max-diff-group-delay  {
      type uint32;
      units "ps";
      config false;
      description
        "Maximum Differential group delay of this mode for this 
        lane";
    }
    leaf max-chromatic-dispersion {
      type decimal64 {
        fraction-digits 2;
        range "0..max";
      }
      units "ps/nm";
      config false;
      description
        "Maximum acceptable accumulated chromatic dispersion (CD) 
        on the receiver";
    }
    list cd-penalty {
      config false;
      description
        "Optional penalty associated with a given accumulated
        chromatic dispersion (CD) value.

        This list of pair cd and penalty values can be used to
        sample the function penalty = f(CD).";
      leaf cd-value {
        type union {
          type decimal64 {
            fraction-digits 2;
            range "0..max";
          }
          type empty;
        }
        units "ps/nm";
        config false;
        mandatory true;
        description
          "The Chromatic Dispersion (CD), when the value is known 
          or an empty value when the value is not known.";
      }
      uses penalty-value;
    }
    leaf max-polarization-mode-dispersion {
      type decimal64 {
        fraction-digits 2;
        range "0..max";
      }
      units "ps";
      config false;
      description
        "Maximum acceptable accumulated polarization mode
         dispersion (PMD) on the receiver";
    }
    list pmd-penalty {
      config false;
      description
        "Optional penalty associated with a given accumulated
        polarization mode dispersion (PMD) value.

        This list of pair pmd and penalty can be used to
        sample the function penalty = f(PMD).";
      leaf pmd-value {
        type union {
          type decimal64 {
            fraction-digits 2;
            range "0..max";
          }
          type empty;
        }
        units "ps";
        config false;
        mandatory true;
        description
          "The Polarization Mode Dispersion (PMD), when the value 
          is known or an empty value when the value is not known.";
      }
      uses penalty-value;
    }
    leaf max-polarization-dependant-loss {
      type power-loss-or-null;
      config false;
      mandatory true;
      description
        "Maximum acceptable accumulated accumulated polarization 
        dependent loss (PDL) on the receiver";
    }
    list pdl-penalty {
      config false;
      description
        "Optional penalty associated with a given accumulated 
        polarization dependent loss (PDL) value.

        This list of pair pdl and penalty values can be used to
        sample the function PDL = f(penalty).";
      leaf pdl-value {
        type power-loss-or-null;
        config false;
        mandatory true;
        description
          "Maximum acceptable accumulated polarization dependent
          loss.";
      }
      uses penalty-value;
    }
    leaf available-modulation-type {
      type identityref {
        base modulation;
      }
      config false;
      description
        "Modulation type the specific transceiver in the list
         can support";
    }
    leaf min-OSNR {
      type snr;
      units "dBm";
      config false;
      description
        "min OSNR measured over 0.1 nm resolution bandwidth:
        if received OSNR at Rx-power reference point
        (rx-ref-channel-power) is lower than MIN-OSNR, an increased 
        level of bit-errors post-FEC needs to be expected";
    }
    leaf rx-ref-channel-power {
      type power-dbm;
      config false;
      description
        "The channel power used as reference for defining penalties 
        and min-OSNR";
    }
    list rx-channel-power-penalty {
      config false;
      description
        "Optional penalty associated with a received power
          lower than rx-ref-channel-power.
          This list of pair power and penalty can be used to
          sample the function penalty = f(rx-channel-power).";
      leaf rx-channel-power-value {
        type power-dbm-or-null;
        units "dBm";
        config false;
        mandatory true;
        description
          "The Received Power, when the value is known or an empty 
          value when the value is not known.";
      }
      uses penalty-value;
    }
    leaf min-Q-factor {
      type int32;
      units "dB";
      config false;
      description "min Qfactor at FEC threshold";
    }
    leaf available-baud-rate {
      type uint32;
      units "Bd";
      config false;
      description
        "Baud-rate the specific transceiver in 
        the list can support.
         Baud-rate is the unit for
         symbol rate or modulation rate 
         in symbols per second or
         pulses per second. 
         It is the number of distinct symbol
         changes (signal events) made to the 
         transmission medium
         per second in a digitally 
         modulated signal or a line code";
    }
    leaf roll-off {
      type decimal64 {
        fraction-digits 4;
        range "0..1";
      }
      config false;
      description 
        "the roll-off factor (beta with values from 0 to 1) 
        identifies how the real signal shape exceed 
        the baud rate. If=0 it is exactly matching 
        the baud rate.If=1 the signal exceeds the 
        50% of the baud rate at each side.";             
    }
    leaf min-carrier-spacing {
      type frequency-ghz;
      config false;
      description
        "This attribute specifies the minimum nominal difference
        between the carrier frequencies of two homogeneous OTSis
        (which have the same optical characteristics but the central
        frequencies) such that if they are placed next to each other
        the interference due to spectrum overlap between them can be
        considered negligible.

        In case of heterogeneous OTSi it is up to path computation
        engine to determine the minimum distance between the carrier
        frequency of the two adjacent OTSi.";
    }
    leaf available-fec-type {
      type identityref {
        base fec-type;
      }
      config false;
      description "Available FEC";
    }
    leaf fec-code-rate {
      type decimal64 {
        fraction-digits 8;
        range "0..max";
      }
      config false;
      description "FEC-code-rate";
    }
    leaf fec-threshold {
      type decimal64 {
        fraction-digits 8;
        range "0..max";
      }
      config false;
      description
        "Threshold on the BER, for which FEC 
         is able to correct errors";
    }
    leaf in-band-osnr {
      type snr;
      config false;
      description
        "The OSNR defined within the bandwidth of the transmit 
        spectral excursion (i.e.,  between the nominal central 
        frequency of the channel and the -3.0dB points of the 
        transmitter spectrum furthest from the nominal central 
        frequency) measured at reference point Ss.
        
        The in-band OSNR is referenced to an optical bandwidth of 
        0.1nm @ 193.7 THz or 12.5 GHz.";
      reference
        "OIF-400ZR-01.0: Implementation Agreement 400ZR";
    }
    leaf out-of-band-osnr {
      type snr;
      config false;
      description
        "The ratio of the peak transmitter power to the integrated 
        power outside the transmitter spectral excursion.
        
        The spectral resolution of the measurement shall be better 
        than the maximum spectral width of the peak.
        
        The out-of-band OSNR is referenced to an optical bandwidth 
        of 0.1nm @ 193.7 THz or 12.5 GHz";
      reference
        "OIF-400ZR-01.0: Implementation Agreement 400ZR";
    }
    leaf tx-polarization-power-difference {
      type power-ratio;
      config false;
      description
        "The transmitter polarization dependent power difference 
        defined as the power difference between X and Y 
        polarizations";
      reference
        "OIF-400ZR-01.0: Implementation Agreement 400ZR";
    }
    leaf polarization-skew {
      type decimal64 {
        fraction-digits 2;
      }
      units "ps";
      config false;
      description
        "The X-Y skew, included as a fixed value in the receiver 
        polarization mode dispersion (PMD) tolerance limits.";
      reference
        "OIF-400ZR-01.0: Implementation Agreement 400ZR";
    }
  } // grouping common-explicit-mode    

  grouping common-standard-organizational-mode {
    description
      "Common attributes used by standard and organizational 
      transceiver's modes.";
    
    leaf-list line-coding-bitrate {
      type identityref {
        base line-coding;
      }
      config false;
      description
        "The list of the bit rate/line coding of the optical 
        tributary signal supported by the transceiver.

        Reporting this list is optional when the standard or 
        organization mode supports only one bit rate/line coding.";
      reference 
        "ITU-T G.698.2 section 7.1.2";
    }
  } // grouping common-standard-organizational-mode

  grouping transmitter-tuning-range {
    description
      "Transmitter tuning range (f_tx-min, f_tx-max)";

    leaf min-central-frequency {
      type frequency-thz;
      description
        "This parameter indicates the minimum frequency for the
        transmitter tuning range.";
    }
    leaf max-central-frequency {
      type frequency-thz;
      description
        "This parameter indicates the maximum frequency for the
        transmitter tuning range.";
    }

    leaf transceiver-tunability {
      type frequency-ghz;
      description
        "This parameter indicates the transmitter frequency fine
        tuning steps e.g 3.125GHz or 0.001GHz.";
    } 
  } // grouping transmitter-tuning-range

  grouping common-all-modes {
    description
      "Common attributes used by all transceiver's modes.";

    uses transmitter-tuning-range;
    leaf tx-channel-power-min {
      type power-dbm;
      config false;
      description "The minimum output power of this interface";
    }
    leaf tx-channel-power-max {
      type power-dbm;
      config false;
      description "The maximum output power of this interface";
    } 
    leaf rx-channel-power-min {
      type power-dbm;
      config false;
      description "The minimum input power of this interface";
    }
    leaf rx-channel-power-max {
      type power-dbm;
      config false;
      description "The maximum input power of this interface";
    }
    leaf rx-total-power-max {
      type power-dbm;
      config false;
      description
        "Maximum rx optical power for all the channels.
        
        It is applicable only to multi-channel modes.";
    }
  } // grouping common-all-modes

  grouping common-transceiver-configured-param {
    description
      "The configured parameters of an optical transceiver,
      that supplement the configured mode.";

    leaf line-coding-bitrate {
      type identityref {
        base line-coding;
      }
      config false;
      description
        "Bit rate/line coding of the optical tributary signal.
        
        Reporting this attribute is optional when the configured 
        mode supports only one bit rate/line coding.";
      reference 
        "ITU-T G.698.2 section 7.1.2";
    }
    leaf tx-channel-power {
      type power-dbm-or-null;
      description
        "The current channel transmit power, when the value is 
        known or an empty value when the value is not known.
        
        The empty value MUST NOT be used when this attribute is 
        configured.";
    }
    leaf rx-channel-power {
      type power-dbm-or-null;
      config false;
      description
        "The current channel received power, when the value is 
        known or an empty value when the value is not known.";
    }
    leaf rx-total-power {
      type power-dbm-or-null;
      config false;
      description
        "The current total received power, when the value is known 
        or an empty value when the value is not known.";
    }
  } // grouping for configured attributes out of mode

  grouping l0-tunnel-attributes {
    description
      "Parameters for Layer0 (WSON or Flexi-Grid) Tunnels.";
    leaf bit-stuffing {
      type boolean;
      description
        "Bit stuffing enabled/disabled.";
    }
    leaf wavelength-assignment {
      type identityref {
        base wavelength-assignment;
      }
      description "Wavelength Allocation Method";
    }
  }

  grouping frequency-range {
    description
      "This grouping defines the lower and upper bounds of a
      frequency range (e.g., a band).
        
      This grouping SHOULD NOT be used to define a frequency slot,
      which SHOULD be defined using the n and m values instead.";
    leaf lower-frequency {
      type frequency-thz;
      mandatory true;
      description
        "The lower frequency boundary of the
        frequency range.";
    }
    leaf upper-frequency {
      type frequency-thz;
      must '. > ../lower-frequency' {
        error-message
          "The upper frequency must be greater than the lower
          frequency.";
      }
      mandatory true;
      description
        "The upper frequency boundary of the
        frequency range.";
    }
  }

  grouping l0-path-constraints {
    description
      "Common attribute for Layer 0 path constraints to be used by
      Layer 0 computation.";
    leaf gsnr-margin {
      type snr {
        range 0..max;
      }
      default 0;
      description
        "An additional margin to be added to the OSNR-min of the
        transceiver when checking the estimated received Generalized
        SNR (GSNR).";
    }
  }

  grouping l0-path-properties {
    description
      "Common attribute for reporting the Layer 0 computed path
      properties.";
    leaf estimated-gsnr {
      type snr;
      config false;
      description
        "The estimate received GSNR for the computed path.";
    }
    leaf estimated-eol-gsnr {
      type snr;
      config false;
      description
        "The estimate received GSNR for the computed path
         degraded at the end of life.";
    }
    leaf estimated-lowest-gsnr {
      type snr;
      config false;
      description
        "The estimate lowest received GSNR for the computed path
         among all possible wavelength channels along the same
         path.";
    }
  }
}
]]></sourcecode></figure>

</section>
<section anchor="security-considerations"><name>Security Considerations</name>

<t>The YANG module specified in this document defines a schema for data
   that is designed to be accessed via network management protocols such
   as NETCONF <xref target="RFC6241"/> or RESTCONF <xref target="RFC8040"/>.  The lowest NETCONF layer
   is the secure transport layer, and the mandatory-to-implement secure
   transport is Secure Shell (SSH) <xref target="RFC6242"/>.  The lowest RESTCONF layer
   is HTTPS, and the mandatory-to-implement secure transport is TLS
   <xref target="RFC8446"/>.</t>

<t>The Network Configuration Access Control Model (NACM) <xref target="RFC8341"/>
   provides the means to restrict access for particular NETCONF or
   RESTCONF users to a preconfigured subset of all available NETCONF or
   RESTCONF protocol operations and content.  The NETCONF protocol over
   Secure Shell (SSH) specification <xref target="RFC6242"/> describes a method for
   invoking and running NETCONF within a Secure Shell (SSH) session as
   an SSH subsystem.</t>

<t>The objects in this YANG module are common data types and groupings.
   No object in this module can be read or written to.  These
   definitions can be imported and used by other Layer 0 specific
   modules.  It is critical to consider how imported definitions will be
   utilized and accessible via RPC operations, as the resultant schema
   will have data nodes that can be writable, or readable, and will have
   a significant effect on the network operations if used incorrectly or
   maliciously.  All of these considerations belong in the document that
   defines the modules that import from this YANG module.  Therefore, it
   is important to manage access to resultant data nodes that are
   considered sensitive or vulnerable in some network environments.</t>

<t>The security considerations spelled out in the YANG 1.1 specification
   <xref target="RFC7950"/> apply for this document as well.</t>

</section>
<section anchor="iana-considerations"><name>IANA Considerations</name>

<t>For the following URI in the "IETF XML Registry" <xref target="RFC3688"/>, IANA has updated the reference field to refer to this document:</t>

<figure><artwork><![CDATA[
   URI:  urn:ietf:params:xml:ns:yang:ietf-layer0-types
   Registrant Contact:  The IESG
   XML:  N/A; the requested URI is an XML namespace.
]]></artwork></figure>

<t>This document also adds an updated YANG module to the "YANG Module
Names" registry <xref target="RFC7950"/>:</t>

<figure><artwork><![CDATA[
   Name:  ietf-layer0-types
   Namespace:  urn:ietf:params:xml:ns:yang:ietf-layer0-types
   Prefix:  l0-types
   Reference:  RFC XXXX
]]></artwork></figure>

<t>RFC Editor Note: Please replace XXXX with the RFC number assigned to this document.</t>

</section>


  </middle>

  <back>


    <references title='Normative References'>

<reference anchor="ITU-T_G.698.2" >
  <front>
    <title>Amplified multichannel dense wavelength division multiplexing applications with single channel optical interfaces</title>
    <author >
      <organization>ITU-T Recommendation G.698.2</organization>
    </author>
    <date year="2018" month="November"/>
  </front>
  <seriesInfo name="ITU-T G.698.2" value=""/>
</reference>


<reference anchor='RFC7950' target='https://www.rfc-editor.org/info/rfc7950'>
  <front>
    <title>The YANG 1.1 Data Modeling Language</title>
    <author fullname='M. Bjorklund' initials='M.' role='editor' surname='Bjorklund'/>
    <date month='August' year='2016'/>
    <abstract>
      <t>YANG is a data modeling language used to model configuration data, state data, Remote Procedure Calls, and notifications for network management protocols. This document describes the syntax and semantics of version 1.1 of the YANG language. YANG version 1.1 is a maintenance release of the YANG language, addressing ambiguities and defects in the original specification. There are a small number of backward incompatibilities from YANG version 1. This document also specifies the YANG mappings to the Network Configuration Protocol (NETCONF).</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7950'/>
  <seriesInfo name='DOI' value='10.17487/RFC7950'/>
</reference>

<reference anchor='RFC6241' target='https://www.rfc-editor.org/info/rfc6241'>
  <front>
    <title>Network Configuration Protocol (NETCONF)</title>
    <author fullname='R. Enns' initials='R.' role='editor' surname='Enns'/>
    <author fullname='M. Bjorklund' initials='M.' role='editor' surname='Bjorklund'/>
    <author fullname='J. Schoenwaelder' initials='J.' role='editor' surname='Schoenwaelder'/>
    <author fullname='A. Bierman' initials='A.' role='editor' surname='Bierman'/>
    <date month='June' year='2011'/>
    <abstract>
      <t>The Network Configuration Protocol (NETCONF) defined in this document provides mechanisms to install, manipulate, and delete the configuration of network devices. It uses an Extensible Markup Language (XML)-based data encoding for the configuration data as well as the protocol messages. The NETCONF protocol operations are realized as remote procedure calls (RPCs). This document obsoletes RFC 4741. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='6241'/>
  <seriesInfo name='DOI' value='10.17487/RFC6241'/>
</reference>

<reference anchor='RFC8342' target='https://www.rfc-editor.org/info/rfc8342'>
  <front>
    <title>Network Management Datastore Architecture (NMDA)</title>
    <author fullname='M. Bjorklund' initials='M.' surname='Bjorklund'/>
    <author fullname='J. Schoenwaelder' initials='J.' surname='Schoenwaelder'/>
    <author fullname='P. Shafer' initials='P.' surname='Shafer'/>
    <author fullname='K. Watsen' initials='K.' surname='Watsen'/>
    <author fullname='R. Wilton' initials='R.' surname='Wilton'/>
    <date month='March' year='2018'/>
    <abstract>
      <t>Datastores are a fundamental concept binding the data models written in the YANG data modeling language to network management protocols such as the Network Configuration Protocol (NETCONF) and RESTCONF. This document defines an architectural framework for datastores based on the experience gained with the initial simpler model, addressing requirements that were not well supported in the initial model. This document updates RFC 7950.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8342'/>
  <seriesInfo name='DOI' value='10.17487/RFC8342'/>
</reference>

<reference anchor='RFC2119' target='https://www.rfc-editor.org/info/rfc2119'>
  <front>
    <title>Key words for use in RFCs to Indicate Requirement Levels</title>
    <author fullname='S. Bradner' initials='S.' surname='Bradner'/>
    <date month='March' year='1997'/>
    <abstract>
      <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
    </abstract>
  </front>
  <seriesInfo name='BCP' value='14'/>
  <seriesInfo name='RFC' value='2119'/>
  <seriesInfo name='DOI' value='10.17487/RFC2119'/>
</reference>

<reference anchor='RFC8174' target='https://www.rfc-editor.org/info/rfc8174'>
  <front>
    <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
    <author fullname='B. Leiba' initials='B.' surname='Leiba'/>
    <date month='May' year='2017'/>
    <abstract>
      <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
    </abstract>
  </front>
  <seriesInfo name='BCP' value='14'/>
  <seriesInfo name='RFC' value='8174'/>
  <seriesInfo name='DOI' value='10.17487/RFC8174'/>
</reference>

<reference anchor='RFC6205' target='https://www.rfc-editor.org/info/rfc6205'>
  <front>
    <title>Generalized Labels for Lambda-Switch-Capable (LSC) Label Switching Routers</title>
    <author fullname='T. Otani' initials='T.' role='editor' surname='Otani'/>
    <author fullname='D. Li' initials='D.' role='editor' surname='Li'/>
    <date month='March' year='2011'/>
    <abstract>
      <t>Technology in the optical domain is constantly evolving, and, as a consequence, new equipment providing lambda switching capability has been developed and is currently being deployed.</t>
      <t>Generalized MPLS (GMPLS) is a family of protocols that can be used to operate networks built from a range of technologies including wavelength (or lambda) switching. For this purpose, GMPLS defined a wavelength label as only having significance between two neighbors. Global wavelength semantics are not considered.</t>
      <t>In order to facilitate interoperability in a network composed of next generation lambda-switch-capable equipment, this document defines a standard lambda label format that is compliant with the Dense Wavelength Division Multiplexing (DWDM) and Coarse Wavelength Division Multiplexing (CWDM) grids defined by the International Telecommunication Union Telecommunication Standardization Sector. The label format defined in this document can be used in GMPLS signaling and routing protocols. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='6205'/>
  <seriesInfo name='DOI' value='10.17487/RFC6205'/>
</reference>

<reference anchor='RFC7699' target='https://www.rfc-editor.org/info/rfc7699'>
  <front>
    <title>Generalized Labels for the Flexi-Grid in Lambda Switch Capable (LSC) Label Switching Routers</title>
    <author fullname='A. Farrel' initials='A.' surname='Farrel'/>
    <author fullname='D. King' initials='D.' surname='King'/>
    <author fullname='Y. Li' initials='Y.' surname='Li'/>
    <author fullname='F. Zhang' initials='F.' surname='Zhang'/>
    <date month='November' year='2015'/>
    <abstract>
      <t>GMPLS supports the description of optical switching by identifying entries in fixed lists of switchable wavelengths (called grids) through the encoding of lambda labels. Work within the ITU-T Study Group 15 has defined a finer-granularity grid, and the facility to flexibly select different widths of spectrum from the grid. This document defines a new GMPLS lambda label format to support this flexi-grid.</t>
      <t>This document updates RFCs 3471 and 6205 by introducing a new label format.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7699'/>
  <seriesInfo name='DOI' value='10.17487/RFC7699'/>
</reference>

<reference anchor='RFC8795' target='https://www.rfc-editor.org/info/rfc8795'>
  <front>
    <title>YANG Data Model for Traffic Engineering (TE) Topologies</title>
    <author fullname='X. Liu' initials='X.' surname='Liu'/>
    <author fullname='I. Bryskin' initials='I.' surname='Bryskin'/>
    <author fullname='V. Beeram' initials='V.' surname='Beeram'/>
    <author fullname='T. Saad' initials='T.' surname='Saad'/>
    <author fullname='H. Shah' initials='H.' surname='Shah'/>
    <author fullname='O. Gonzalez de Dios' initials='O.' surname='Gonzalez de Dios'/>
    <date month='August' year='2020'/>
    <abstract>
      <t>This document defines a YANG data model for representing, retrieving, and manipulating Traffic Engineering (TE) Topologies. The model serves as a base model that other technology-specific TE topology models can augment.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8795'/>
  <seriesInfo name='DOI' value='10.17487/RFC8795'/>
</reference>

<reference anchor='RFC4203' target='https://www.rfc-editor.org/info/rfc4203'>
  <front>
    <title>OSPF Extensions in Support of Generalized Multi-Protocol Label Switching (GMPLS)</title>
    <author fullname='K. Kompella' initials='K.' role='editor' surname='Kompella'/>
    <author fullname='Y. Rekhter' initials='Y.' role='editor' surname='Rekhter'/>
    <date month='October' year='2005'/>
    <abstract>
      <t>This document specifies encoding of extensions to the OSPF routing protocol in support of Generalized Multi-Protocol Label Switching (GMPLS). [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='4203'/>
  <seriesInfo name='DOI' value='10.17487/RFC4203'/>
</reference>


<reference anchor='I-D.ietf-teas-rfc8776-update' target='https://datatracker.ietf.org/doc/html/draft-ietf-teas-rfc8776-update-09'>
   <front>
      <title>Common YANG Data Types for Traffic Engineering</title>
      <author fullname='Italo Busi' initials='I.' surname='Busi'>
         <organization>Huawei</organization>
      </author>
      <author fullname='Aihua Guo' initials='A.' surname='Guo'>
         <organization>Futurewei Technologies</organization>
      </author>
      <author fullname='Xufeng Liu' initials='X.' surname='Liu'>
         <organization>Alef Edge</organization>
      </author>
      <author fullname='Tarek Saad' initials='T.' surname='Saad'>
         <organization>Cisco Systems Inc.</organization>
      </author>
      <author fullname='Igor Bryskin' initials='I.' surname='Bryskin'>
         <organization>Individual</organization>
      </author>
      <date day='29' month='January' year='2024'/>
      <abstract>
	 <t>   This document defines a collection of common data types and groupings
   in YANG data modeling language.  These derived common types and
   groupings are intended to be imported by modules that model Traffic
   Engineering (TE) configuration and state capabilities.  This document
   obsoletes RFC 8776.

	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-ietf-teas-rfc8776-update-09'/>
   
</reference>

<reference anchor='RFC8363' target='https://www.rfc-editor.org/info/rfc8363'>
  <front>
    <title>GMPLS OSPF-TE Extensions in Support of Flexi-Grid Dense Wavelength Division Multiplexing (DWDM) Networks</title>
    <author fullname='X. Zhang' initials='X.' surname='Zhang'/>
    <author fullname='H. Zheng' initials='H.' surname='Zheng'/>
    <author fullname='R. Casellas' initials='R.' surname='Casellas'/>
    <author fullname='O. Gonzalez de Dios' initials='O.' surname='Gonzalez de Dios'/>
    <author fullname='D. Ceccarelli' initials='D.' surname='Ceccarelli'/>
    <date month='May' year='2018'/>
    <abstract>
      <t>The International Telecommunication Union Telecommunication standardization sector (ITU-T) has extended its Recommendations G.694.1 and G.872 to include a new Dense Wavelength Division Multiplexing (DWDM) grid by defining channel spacings, a set of nominal central frequencies, and the concept of the "frequency slot". Corresponding techniques for data-plane connections are known as "flexi-grid".</t>
      <t>Based on the characteristics of flexi-grid defined in G.694.1 and in RFCs 7698 and 7699, this document describes the Open Shortest Path First - Traffic Engineering (OSPF-TE) extensions in support of GMPLS control of networks that include devices that use the new flexible optical grid.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8363'/>
  <seriesInfo name='DOI' value='10.17487/RFC8363'/>
</reference>

<reference anchor='RFC8040' target='https://www.rfc-editor.org/info/rfc8040'>
  <front>
    <title>RESTCONF Protocol</title>
    <author fullname='A. Bierman' initials='A.' surname='Bierman'/>
    <author fullname='M. Bjorklund' initials='M.' surname='Bjorklund'/>
    <author fullname='K. Watsen' initials='K.' surname='Watsen'/>
    <date month='January' year='2017'/>
    <abstract>
      <t>This document describes an HTTP-based protocol that provides a programmatic interface for accessing data defined in YANG, using the datastore concepts defined in the Network Configuration Protocol (NETCONF).</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8040'/>
  <seriesInfo name='DOI' value='10.17487/RFC8040'/>
</reference>

<reference anchor='RFC6242' target='https://www.rfc-editor.org/info/rfc6242'>
  <front>
    <title>Using the NETCONF Protocol over Secure Shell (SSH)</title>
    <author fullname='M. Wasserman' initials='M.' surname='Wasserman'/>
    <date month='June' year='2011'/>
    <abstract>
      <t>This document describes a method for invoking and running the Network Configuration Protocol (NETCONF) within a Secure Shell (SSH) session as an SSH subsystem. This document obsoletes RFC 4742. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='6242'/>
  <seriesInfo name='DOI' value='10.17487/RFC6242'/>
</reference>

<reference anchor='RFC8446' target='https://www.rfc-editor.org/info/rfc8446'>
  <front>
    <title>The Transport Layer Security (TLS) Protocol Version 1.3</title>
    <author fullname='E. Rescorla' initials='E.' surname='Rescorla'/>
    <date month='August' year='2018'/>
    <abstract>
      <t>This document specifies version 1.3 of the Transport Layer Security (TLS) protocol. TLS allows client/server applications to communicate over the Internet in a way that is designed to prevent eavesdropping, tampering, and message forgery.</t>
      <t>This document updates RFCs 5705 and 6066, and obsoletes RFCs 5077, 5246, and 6961. This document also specifies new requirements for TLS 1.2 implementations.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8446'/>
  <seriesInfo name='DOI' value='10.17487/RFC8446'/>
</reference>

<reference anchor='RFC8341' target='https://www.rfc-editor.org/info/rfc8341'>
  <front>
    <title>Network Configuration Access Control Model</title>
    <author fullname='A. Bierman' initials='A.' surname='Bierman'/>
    <author fullname='M. Bjorklund' initials='M.' surname='Bjorklund'/>
    <date month='March' year='2018'/>
    <abstract>
      <t>The standardization of network configuration interfaces for use with the Network Configuration Protocol (NETCONF) or the RESTCONF protocol requires a structured and secure operating environment that promotes human usability and multi-vendor interoperability. There is a need for standard mechanisms to restrict NETCONF or RESTCONF protocol access for particular users to a preconfigured subset of all available NETCONF or RESTCONF protocol operations and content. This document defines such an access control model.</t>
      <t>This document obsoletes RFC 6536.</t>
    </abstract>
  </front>
  <seriesInfo name='STD' value='91'/>
  <seriesInfo name='RFC' value='8341'/>
  <seriesInfo name='DOI' value='10.17487/RFC8341'/>
</reference>




    </references>

    <references title='Informative References'>

<reference anchor="ITU-T_G.694.1" >
  <front>
    <title>Spectral grids for WDM applications: DWDM frequency grid</title>
    <author >
      <organization>ITU-T Recommendation G.694.1</organization>
    </author>
    <date year="2020" month="October"/>
  </front>
  <seriesInfo name="ITU-T G.694.1" value=""/>
</reference>
<reference anchor="ITU-T_G.694.2" >
  <front>
    <title>Spectral grids for WDM applications: CWDM wavelength grid</title>
    <author >
      <organization>ITU-T Recommendation G.694.2</organization>
    </author>
    <date year="2003" month="December"/>
  </front>
  <seriesInfo name="ITU-T G.694.2" value=""/>
</reference>


<reference anchor='RFC6163' target='https://www.rfc-editor.org/info/rfc6163'>
  <front>
    <title>Framework for GMPLS and Path Computation Element (PCE) Control of Wavelength Switched Optical Networks (WSONs)</title>
    <author fullname='Y. Lee' initials='Y.' role='editor' surname='Lee'/>
    <author fullname='G. Bernstein' initials='G.' role='editor' surname='Bernstein'/>
    <author fullname='W. Imajuku' initials='W.' surname='Imajuku'/>
    <date month='April' year='2011'/>
    <abstract>
      <t>This document provides a framework for applying Generalized Multi-Protocol Label Switching (GMPLS) and the Path Computation Element (PCE) architecture to the control of Wavelength Switched Optical Networks (WSONs). In particular, it examines Routing and Wavelength Assignment (RWA) of optical paths.</t>
      <t>This document focuses on topological elements and path selection constraints that are common across different WSON environments; as such, it does not address optical impairments in any depth. This document is not an Internet Standards Track specification; it is published for informational purposes.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='6163'/>
  <seriesInfo name='DOI' value='10.17487/RFC6163'/>
</reference>

<reference anchor='RFC7698' target='https://www.rfc-editor.org/info/rfc7698'>
  <front>
    <title>Framework and Requirements for GMPLS-Based Control of Flexi-Grid Dense Wavelength Division Multiplexing (DWDM) Networks</title>
    <author fullname='O. Gonzalez de Dios' initials='O.' role='editor' surname='Gonzalez de Dios'/>
    <author fullname='R. Casellas' initials='R.' role='editor' surname='Casellas'/>
    <author fullname='F. Zhang' initials='F.' surname='Zhang'/>
    <author fullname='X. Fu' initials='X.' surname='Fu'/>
    <author fullname='D. Ceccarelli' initials='D.' surname='Ceccarelli'/>
    <author fullname='I. Hussain' initials='I.' surname='Hussain'/>
    <date month='November' year='2015'/>
    <abstract>
      <t>To allow efficient allocation of optical spectral bandwidth for systems that have high bit-rates, the International Telecommunication Union Telecommunication Standardization Sector (ITU-T) has extended its Recommendations G.694.1 and G.872 to include a new Dense Wavelength Division Multiplexing (DWDM) grid by defining a set of nominal central frequencies, channel spacings, and the concept of the "frequency slot". In such an environment, a data-plane connection is switched based on allocated, variable-sized frequency ranges within the optical spectrum, creating what is known as a flexible grid (flexi-grid).</t>
      <t>Given the specific characteristics of flexi-grid optical networks and their associated technology, this document defines a framework and the associated control-plane requirements for the application of the existing GMPLS architecture and control-plane protocols to the control of flexi-grid DWDM networks. The actual extensions to the GMPLS protocols will be defined in companion documents.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7698'/>
  <seriesInfo name='DOI' value='10.17487/RFC7698'/>
</reference>

<reference anchor='RFC9093' target='https://www.rfc-editor.org/info/rfc9093'>
  <front>
    <title>A YANG Data Model for Layer 0 Types</title>
    <author fullname='H. Zheng' initials='H.' surname='Zheng'/>
    <author fullname='Y. Lee' initials='Y.' surname='Lee'/>
    <author fullname='A. Guo' initials='A.' surname='Guo'/>
    <author fullname='V. Lopez' initials='V.' surname='Lopez'/>
    <author fullname='D. King' initials='D.' surname='King'/>
    <date month='August' year='2021'/>
    <abstract>
      <t>This document defines a collection of common data types and groupings in the YANG data modeling language. These derived common types and groupings are intended to be imported by modules that model Layer 0 optical Traffic Engineering (TE) configuration and state capabilities such as Wavelength Switched Optical Networks (WSONs) and flexi-grid Dense Wavelength Division Multiplexing (DWDM) networks.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='9093'/>
  <seriesInfo name='DOI' value='10.17487/RFC9093'/>
</reference>

<reference anchor='RFC7446' target='https://www.rfc-editor.org/info/rfc7446'>
  <front>
    <title>Routing and Wavelength Assignment Information Model for Wavelength Switched Optical Networks</title>
    <author fullname='Y. Lee' initials='Y.' role='editor' surname='Lee'/>
    <author fullname='G. Bernstein' initials='G.' role='editor' surname='Bernstein'/>
    <author fullname='D. Li' initials='D.' surname='Li'/>
    <author fullname='W. Imajuku' initials='W.' surname='Imajuku'/>
    <date month='February' year='2015'/>
    <abstract>
      <t>This document provides a model of information needed by the Routing and Wavelength Assignment (RWA) process in Wavelength Switched Optical Networks (WSONs). The purpose of the information described in this model is to facilitate constrained optical path computation in WSONs. This model takes into account compatibility constraints between WSON signal attributes and network elements but does not include constraints due to optical impairments. Aspects of this information that may be of use to other technologies utilizing a GMPLS control plane are discussed.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7446'/>
  <seriesInfo name='DOI' value='10.17487/RFC7446'/>
</reference>

<reference anchor='RFC7581' target='https://www.rfc-editor.org/info/rfc7581'>
  <front>
    <title>Routing and Wavelength Assignment Information Encoding for Wavelength Switched Optical Networks</title>
    <author fullname='G. Bernstein' initials='G.' role='editor' surname='Bernstein'/>
    <author fullname='Y. Lee' initials='Y.' role='editor' surname='Lee'/>
    <author fullname='D. Li' initials='D.' surname='Li'/>
    <author fullname='W. Imajuku' initials='W.' surname='Imajuku'/>
    <author fullname='J. Han' initials='J.' surname='Han'/>
    <date month='June' year='2015'/>
    <abstract>
      <t>A Wavelength Switched Optical Network (WSON) requires certain key information fields be made available to facilitate path computation and the establishment of Label Switched Paths (LSPs). The information model described in "Routing and Wavelength Assignment Information Model for Wavelength Switched Optical Networks" (RFC 7446) shows what information is required at specific points in the WSON. Part of the WSON information model contains aspects that may be of general applicability to other technologies, while other parts are specific to WSONs.</t>
      <t>This document provides efficient, protocol-agnostic encodings for the WSON-specific information fields. It is intended that protocol- specific documents will reference this memo to describe how information is carried for specific uses. Such encodings can be used to extend GMPLS signaling and routing protocols. In addition, these encodings could be used by other mechanisms to convey this same information to a Path Computation Element (PCE).</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7581'/>
  <seriesInfo name='DOI' value='10.17487/RFC7581'/>
</reference>


<reference anchor='I-D.ietf-ccamp-dwdm-if-param-yang' target='https://datatracker.ietf.org/doc/html/draft-ietf-ccamp-dwdm-if-param-yang-10'>
   <front>
      <title>A YANG model to manage the optical interface parameters for an external transponder in a WDM network</title>
      <author fullname='Gabriele Galimberti' initials='G.' surname='Galimberti'>
         <organization>C</organization>
      </author>
      <author fullname='Dharini Hiremagalur' initials='D.' surname='Hiremagalur'>
         <organization>Juniper</organization>
      </author>
      <author fullname='Gert Grammel' initials='G.' surname='Grammel'>
         <organization>Juniper</organization>
      </author>
      <author fullname='Roberto Manzotti' initials='R.' surname='Manzotti'>
         <organization>Cisco</organization>
      </author>
      <author fullname='Dirk Breuer' initials='D.' surname='Breuer'>
         <organization>DEUTSCHE TELEKOM AG</organization>
      </author>
      <date day='23' month='October' year='2023'/>
      <abstract>
	 <t>   This memo defines a Yang model related to the Optical Transceiver
   parameters characterising coherent 100G and above interfaces.  100G
   and above Transceivers support coherent modulation, multiple
   modulation formats, multiple FEC codes including some not yet
   specified (or in phase of specification by) ITU-T G.698.2 or any
   other ITU-T recommendation.  Use cases are described in RFC7698.  Is
   to be noted that the Transceivers can be located on the Transponders
   (optical layer) or on the Router (in general packet layer) in form of
   Pluggable modules.

   The Yang model defined in this memo can be used for Optical
   Parameters monitoring and/or configuration of the endpoints of a
   multi-vendor IaDI optical link.  The use of this model does not
   guarantee interworking of transceivers over a DWDM.  Optical path
   feasibility and interoperability has to be determined by tools and
   algorithms outside the scope of this document.  The purpose of this
   model is to program interface parameters to consistently configure
   the mode of operation of transceivers.

	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-ietf-ccamp-dwdm-if-param-yang-10'/>
   
</reference>

<reference anchor='RFC3688' target='https://www.rfc-editor.org/info/rfc3688'>
  <front>
    <title>The IETF XML Registry</title>
    <author fullname='M. Mealling' initials='M.' surname='Mealling'/>
    <date month='January' year='2004'/>
    <abstract>
      <t>This document describes an IANA maintained registry for IETF standards which use Extensible Markup Language (XML) related items such as Namespaces, Document Type Declarations (DTDs), Schemas, and Resource Description Framework (RDF) Schemas.</t>
    </abstract>
  </front>
  <seriesInfo name='BCP' value='81'/>
  <seriesInfo name='RFC' value='3688'/>
  <seriesInfo name='DOI' value='10.17487/RFC3688'/>
</reference>




    </references>


<section anchor="changes-bis"><name>Changes from RFC 9093</name>

<t>To be added in a future revision of this draft.</t>

</section>
<section numbered="false" anchor="acknowledgments"><name>Acknowledgments</name>

<t>The authors and the working group give their sincere thanks to Robert
   Wilton for the YANG doctor review and Tom Petch for his comments
   during the model and document development.</t>

<t>This document was prepared using kramdown.</t>

</section>

    <section anchor="contributors" numbered="false" toc="include" removeInRFC="false">
        <name>Contributors</name>
    <contact initials="G." surname="Galimberti" fullname="Gabriele Galimberti">
      <organization>Cisco</organization>
      <address>
        <email>ggalimbe@cisco.com</email>
      </address>
    </contact>
    <contact initials="E." surname="Griseri" fullname="Enrico Griseri">
      <organization>Nokia</organization>
      <address>
        <email>Enrico.Griseri@nokia.com</email>
      </address>
    </contact>
    <contact initials="D." surname="Dhody" fullname="Dhruv Dhody">
      <organization>Huawei</organization>
      <address>
        <email>dhruv.ietf@gmail.com</email>
      </address>
    </contact>
    <contact initials="B. Y." surname="Yoon" fullname="Bin Yeong Yoon">
      <organization>ETRI</organization>
      <address>
        <email>byyun@etri.re.kr</email>
      </address>
    </contact>
    <contact initials="R." surname="Vilalta" fullname="Ricard Vilalta">
      <organization>CTTC</organization>
      <address>
        <email>ricard.vilalta@cttc.es</email>
      </address>
    </contact>
    <contact initials="Y." surname="Lee" fullname="Young Lee">
      <organization>Samsung</organization>
      <address>
        <email>younglee.tx@gmail.com</email>
      </address>
    </contact>
    <contact initials="V." surname="Lopez" fullname="Victor Lopez">
      <organization>Nokia</organization>
      <address>
        <email>victor.lopez@nokia.com</email>
      </address>
    </contact>
    </section>

  </back>

<!-- ##markdown-source:
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
GYbUAakA2LKFNiJzv81W3U7Ge3huRqhLex/sjjYxm3KPN7Z2ycqsRNpseaSD
u1qsSB0AIiLxo64TwTDpkxLAiywMP3GmJdmiZxh+qN3R5ovTfBWC7V4AP4qi
PuyG7x5wPuNePe2UQ1+aH/xneGh6/9Dvi57Wxes/KZMcv9jrsYGATqG21cXf
uBN5islPghNLaNA9/swFMfJ1Hnk6jzydzVYxICTSMtvvJxuE/Kxx6nTEomdt
Z3AuMXHa9dJPdrIVaToqvzALJx3oQLBGS8NqIMu1JgvNywPSB9Gl52jCY1d+
Fnck8ta7llFSPG1YED4kvRUXyu/43mkfna9yjmdIPHUL0N8MOG68XvmqztbW
TxOHW1BJPFSByqnl5fkoyDIQHcw4yfdtQDttm9rPqvuot5h2FqAq7Rz0rC3p
Q8zanU19Z+19Z5W+14QSYt2AkUV4Ofr34t/kb/9R7yI6iZaWPjNPnyrSPm6x
vzTqiezivN7I2655Ym6nznPzdGucnmdzO4f+Coze4n75hk1Uth9zghYfNhrm
EFl+7PecmgTeD3QV1eMW/aRGHD52G/tclEpjQwF/Mq2C1SzlFmjZJaSFqEoL
j2zw4dtVHvsl8T3L4A4iuCIJFovg29C09tNGZH/qrQLq7IrFm8KjUmvJqXoR
24yc5c2bjtaN6GDdVECZxIm2BFcFuavxZwFzpWV3WMvJv4asSb0cizdJ0/ZY
QcGuplp9SnUpdbqcIl1OhTYoz8Vqc0mFubSqvBWT/P+qK5tSXSUbLuvMrODG
rOLA2MlqMntGgerh3+sut8r8rupmylI3lcwZ2fmm3tG6i4WBQEzr+75hgrob
LaOMgBhhSKOafVFM/6h1gwVdoZtNpKJM5MMFPzndLmrdYG7FtV7reXqFJI6k
wOM/x+ezLp2C64WdslVGqnfqNlKRFkGti68T8YwnBdDDP55WdbGK7So3yCxW
q37l72+N02cOm4AOQDANX3nBNHNtE9vqrs2828yFpnMjB3fo3MzHzYwsFvOy
n1taOmqWae/YzNNLd+w+YgNvNzG3k3pYVeMA0fm+rsb9nFQT3A0RKw2jqZ/9
U9FvdndkqnE0mfRJLfTHYRzcVGFh9+2txu6jaZZipvYIAOVzfDwwdUy7cTiK
ZkH8eMcLYaQzGsGQ8cQydCsKTRucEus1t2prCdB08bU2E5inaDzIzY+LVZlI
+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
WtyGtDeQAQA=

-->

</rfc>

