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

<!DOCTYPE rfc SYSTEM "rfc2629.dtd" [
]>

<?rfc toc="yes"?>
<?rfc sortrefs="yes"?>
<?rfc symrefs="yes"?>
<?rfc comments="yes"?>

<rfc ipr="trust200902" docName="draft-ietf-ccamp-rfc9093-bis-06" category="std" submissionType="IETF" obsoletes="9093">

  <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="2023" month="October" day="22"/>

    
    <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-overview"><name>Layer 0 Types Overview</name>

<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>

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

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

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

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

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

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

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

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

<t><list style='empty'>
  <t>TBD: add a description and a reference (also in YANG)</t>
</list></t>

<t>fec-type:</t>

<t><list style='empty'>
  <t>TBD: add a description and the list of references defined in YANG</t>
</list></t>

<t>line-coding:</t>

<t><list style='empty'>
  <t>TBD: add a description and the list of references defined in YANG</t>
</list></t>

<t>wavelength-assignment:</t>

<t><list style='empty'>
  <t>TBD: add a description and the list of references defined in YANG</t>
</list></t>

<t>term-type:</t>

<t><list style='empty'>
  <t>TBD: add a description and the list of references defined in YANG</t>
</list></t>

<t>otu-type:</t>

<t><list style='empty'>
  <t>TBD: add a description and the list of references defined in YANG</t>
</list></t>

<t>operational-mode:</t>

<t><list style='empty'>
  <t>TBD: add a description and the list of references defined in YANG</t>
</list></t>

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

<t><list style='empty'>
  <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>
</list></t>

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

<t><list style='empty'>
  <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>
</list></t>

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

<t><list style='empty'>
  <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>
</list></t>

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

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

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

<t><list style='empty'>
  <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>
</list></t>

<t><list style='empty'>
  <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>
</list></t>

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

<t><list style='empty'>
  <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>
</list></t>

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

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

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

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

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

<t><list style='empty'>
  <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>
</list></t>

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

<t><list style='empty'>
  <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>
</list></t>

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

<t><list style='empty'>
  <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>
</list></t>

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

<t><list style='empty'>
  <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>
</list></t>

<t>transceiver-capabilities:</t>

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

<t>standard-mode:</t>

<t><list style='empty'>
  <t>a YANG grouping for the standard modes defined in <xref target="ITU-T_G.698.2"/>.</t>
</list></t>

<t>organizational-mode:</t>

<t><list style='empty'>
  <t>a YANG grouping to define transponder operational mode supported by
   organizations or vendors.</t>
</list></t>

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

<t><list style='empty'>
  <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>
</list></t>

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

<t><list style='empty'>
  <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>
</list></t>

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

<t><list style='empty'>
  <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>
</list></t>

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

<t><list style='empty'>
  <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>
</list></t>

</section>
<section anchor="wson-label-and-label-range"><name>WSON Label and Label Range</name>

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

<figure title="Layer 0 Types YANG module" anchor="fig-te-yang"><sourcecode type="yang" markers="true" name="ietf-layer0-types@2023-10-04.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) 2023 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 2023-10-04 {
    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";
    }

  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";
    }

    identity dwdm-50ghz {
      base dwdm-ch-spc-type;
      description
        "50 GHz channel spacing";
    }

    identity dwdm-25ghz {
      base dwdm-ch-spc-type;
      description
        "25 GHz channel spacing";
    }

    identity dwdm-12p5ghz {
      base dwdm-ch-spc-type;
      description
        "12.5 GHz channel spacing";
    }

  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)";
    }

  identity flexi-slot-width-granularity {
    description
      "Flexi-grid slot width granularity";
  }

    identity flexi-swg-12p5ghz {
      base flexi-slot-width-granularity;
      description
        "12.5 GHz slot width granularity";
    }

  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";
    }

    identity random-wavelength-assignment {
      base wavelength-assignment;
      description
        "This WA method chooses an available
        wavelength randomly";
    }

    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)";
    }

  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-digits {
    type decimal64 {
      fraction-digits 2;
    }
    description
      "A decimal64 value with two digits.";
  }

  typedef decimal-2-digits-or-null {
    type union {
      type decimal-2-digits;
      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 gain-in-db {
    type decimal-2-digits {
      range "0..max";
    }
    units "dB";
    description
      "The gain in dB.";
  }

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

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

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

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

  typedef power-in-dbm-or-null {
    type union {
      type power-in-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-digits {
    type decimal64 {
      fraction-digits 5;
    }
    description
      "A decimal64 value with five digits.";
  }

  typedef decimal-5-digits-or-null {
    type union {
      type decimal-5-digits;
      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 decimal-16-digits {
    type decimal64 {
      fraction-digits 16;
    }
    description
      "A decimal64 value with sixteen digits.";
  }

  typedef decimal-16-digits-or-null {
    type union {
      type decimal-5-digits;
      type empty;
    }
    description
      "A decimal64 value with sixteen digits, when the value is 
      known or an empty value when the value 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 Recommendation G.694.1: 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 '../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 Recommendation G.694.1: 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";
    }
  }

 /* supported inverse multiplexing capabilities such as
    max. OTSiG:OTSi cardinality
    It is a transponder attribute not transceiver
  */

 /*    leaf multiplexing-cap {
      type uint32;
    config false;
      description "supported inverse multiplexing capabilities
       such as max. OTSiG:OTSi cardinality";
    }
  */

  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;
      }
      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-organizational-explicit-mode;
        }  // 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-organizational-explicit-mode;
          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.";
    }
  }

/* 
 * This grouping represent 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
 */

  grouping common-explicit-mode {
    description "Attributes capabilities related to 
    explicit mode of an optical transceiver";
    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 loss-in-db-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 loss-in-db-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-in-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-in-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 decimal-2-digits;
      units "dB";
      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 
      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-organizational-explicit-mode {
    description "Common capability attributes limit range 
    in case of operational mode and explicit mode. 
    These attributes are supported separately in 
    case of application codes";

/* transmitter tuning range (f_tx-min, f_tx-max) */
    uses transmitter-tuning-range;

/* supported transmitter power range [p_tx-min, p_tx_max] */

    leaf tx-channel-power-min {
      type power-in-dbm;
      config false;
      description "The minimum output power of this interface";
    }
    leaf tx-channel-power-max {
      type power-in-dbm;
      config false;
      description "The maximum output power of this interface";
    } 

/* supported receiver power range [p_rx-min, p_rx_max] */ 

     leaf rx-channel-power-min {
      type power-in-dbm;
      config false;
      description "The minimum input power of this interface";
    }
    leaf rx-channel-power-max {
      type power-in-dbm;
      config false;
      description "The maximum input power of this interface";
    }

    leaf rx-total-power-max {
      type power-in-dbm;
      config false;
      description "Maximum rx optical power for
      all the channels";
    }
  } // grouping common-organizational-explicit-mode

/* This grouping represent the list of configured parameters */
/* values independent of operational mode */

  grouping common-transceiver-configured-param {
    description "Capability of an optical transceiver";

    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-in-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-in-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-in-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-07'>
   <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='15' month='September' year='2023'/>
      <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-07'/>
   
</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-09'>
   <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>Cisco</organization>
      </author>
      <author fullname='Ruediger Kunze' initials='R.' surname='Kunze'>
         <organization>Deutsche Telekom</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>
      <date day='13' month='March' 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 by in phase of specification by) ITU-T G.698.2 or any
   other ITU-T recommendation.  Use cases are described in RFC7698.

   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-09'/>
   
</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:
H4sIAE40NWUAA+19a3cbOY7od/0KrufcG7nHJUt+JXE2s+3YefhMYnts9/b0
7O6ZU5YoqzalKm097Lgz3t9yf8v9ZRcA31Ws0iN20r03Pv2wJRIEARAEQBAM
gqAzTEdRcr3PymIcPOt0iqiI+T47YL8cnLxlR2ERsg/piMdsnGbsfXjHM9Zn
l3cznnc64dVVxm/22S9hcu35fpQOk3AKwEZZOC6CiMMIw2E4nQXZePi8/3w7
uIryoL/XSa/yNOYFz/cZftzJy6tplOdRmhQAaJ8dv75807lNs4/XWVrO9tnh
4cGHM/YzfACYs7f4YWcYFvw6ze72WV6MOtEs22dFVubFVr//vL/V6eRFmIz+
HsZpAgDvALtZtM/+rUiHGyxPsyLj4xx+u5uKX4bpdMqTIv8PmGRZTNJsv8NY
AP8yJqZ0wbPrKGWveJwWRURfpBlQ8ST9GIX0Z5YiHfkoKtKMPuDTMIoBPerZ
uxI9f0ywQw/GqwxwXACu7FWZW8DfleEtj1qhR9itdwXdfpxQaw/oI+AEsAlw
j3m2DOoj6oioQ8dGzN+F6TQKE/a3CU+uvchLcL9ig4lo3Yzt67yYALbvOTtP
y1+jIX0VJSArr3uVT2mc0wykkdvjcILQA5yp6Y8ptfAMdRABFuxtmRpob8qi
zDhgxi75cJKkcXodgfBY0EPsdF2mPZTvH6/xQx/NwySCRfTnyCbJT0l0w7M8
Ku5YOobFkwzDvOAuyXso4z/G6rteOOyVHzuwapMii67Koi6ab8OrDMbi8Esc
Ta94ZsvnYZQPU3uA62vR6schfuOjf5JFwxRWWQSS65V0CUk07MmGjeJxNMnK
G/hvOrprE44RNmun6asoYb/wFFTAL2maGGCvL8+PbVBXd3dl8iMHevUy3vuY
VcCcR8MwG7F/jeIwLkKLVJeXhzaYjNr1bkS7H4dFMeyRKNjAfklLwOc95wbO
RTjNS8l2CeoOW8Wc94pPjbP712hYoEpNZ/zXFqrfULNejM0smneSNJuGBcgX
isfx5U/B5d/f9vaeP+tt7VN3qef/RH8wdjCdxdE44iM2LeMiGk7CJAF5HfEk
5+w2vAF5Sq6LCaiAmwgVs+xGjWcx/4SKOJwBDNDD8HXObiNonUc4TaagpTOA
HMayb5SAPI/DoVxORs/qyRLa7JwLbTwiyEzOgtrBRxxpcsNRztlWf/CMPkcB
5DD4OFVAVK8OfuilzE5v4FBm7WLGh0UWxuw6i0Y57W8/H31wZgnSjB+NM/5f
JU+Gd9R0benpwNDWdE6BoWI2W/2W2YhONv5bK+B/iB9Z/F11AjY/jvhQ8aO/
3ToD4EcQBCy8ygHRYdHBxpeTKGdgOpS4AYMAjqOE5yyELRl2nSENCcoSUYDf
RmifoJEALZIRI/sAZI4kCrQD6H1hx1C7KdoxKKigTa9BZ/MejsZBwEeA3w3I
voSqASIYDZOFGSehTUbQtEjZFfw5nYHxAH9e3SH4MoZ+xSQsxFjKHkIwUvbZ
JdhC42gI2vIaJgbjAj7dy9frMHYyjq7LTFAVZwMmSwGLJ5yFV1EcFXLfycvh
hIU5+9kw7QIW23ACWJzKQU54geZSzro/X5ye5OsEbozLNEAGI5gjWtkWkCO5
stkHe013UcDXWSIB9jws0tYbO39zSAZcT7B1Go1GMe90/sCOYbMC6hD3CAIx
5fPnf4IeT5/v9u/vWYQ89rOJlbkgOH2D3V1aYa8NSS3x+zmfpvDHWZYO+Qj2
b3YYxjGYdZKlSVqArlOaCheGnB+bhgkMSNOaZSlYh2mca4qjNEnKIpRDB4kz
2Zx1T15fHp6evFmX89vb2hnc3wtRE/NW8xLcnKEE4eTzKSAJS6VA+b4qoxhM
5pqEA1Y30Qj+mHLUqlE+JaEA4ggZZilZS6LDOEunhLWGRp/7mBhJDi201ORy
QSj1Icx6E4OJiasV1rBWcWnBrKLrRC8tBOquR6G4rmBDQZZpMZErCsHUFtWY
h2i/5ci+WzBb8f9JmgSXr81XXd677m2w2eQuV7uTEofKmsxRo8Jqsl0dta7V
CgFKIgTCrgtthQIbsbQscmAcErSwKS/poyaHCx2tQYShhhDTx8HFDk2KzWXe
MC5RKDw6AQE1qoXPn/8FJXSwtw0r8PNnZzOET5BN7qdb9/cbFWUiNAkOs6wy
kcM/hZ35/h4B1DDwSWo4gs0s4bdEFkHeSCxkkBut8JUylive6CgxJmopWpRv
gJXjMqNFM+IFmFToBnIhfuDcamOH1Av5hIKFzjjIks+f72BdB+BOcyAdgMU2
eTmdhtmdFIrPn3HNXvMcHV8zu9oeVecwCiKYLXqOlhr6YFQWeus5WIOcHWTD
SVSAtJYZ1yJISKJKera9s0XD/+EP4NZk04j8mjti7ElaCL1IyJ3zMWqTVLFq
Z2dPywV9sPsMBWUsp/uR3zEw6gBPUtlyGghIzURID7YtrIGxP8jvEDwalJMK
OXLYAxNQCaRvwHK2ZiI2D5jJpRwdqALisfbhp4vLtQ3xf3ZySr+fv/7LT8fn
r4/w94t3B+/f6186ssXFu9Of3h+Z30zPw9MPH16fHInO8ClzPuqsfTj4ZU1M
be307PL49OTg/Vqdi6jlpN2Atu8s42g6hHlHzl2Q7NXh2f/9P4MdOcOtweA5
LU5i3ODpDvxxC46zGC1N4jv5J9D0rgNqhIcZQsG9BEwHjAfgxgf6Y5LeJgzk
nAO5kPNnGcjFJ2xLUZ4TIDU7AddDcP64gvwGuSUk/MSZJB1JRS52HEt606v/
RD2p9PqMxoG5legOiGWBwRh0usR3gF6eDqMQqUF+A7QR23wGCnqWJiMtFdrg
kgsc5vIPNRPx8w9nYXp//iHkGix2Dr3jfiA0rPiKwlQxql77c7c32Dl/hZ/O
5332hyK8CuQUc2F7v1w7U38jfTyzkMiv3Xc6COs1RVpw6YFPchbzMEfdM4vB
N6JxNFFo5KQk4xpoprdLd0dBi8uJxLHTG57dRPyW+O5+9UHQCYyZApVbqwlu
ExaXrNyenX1qQxAQwdhE7EmoSl9KDUFOCexFtT0FNgprI1ZWxFqNOWsKIgZE
wigRVtoYDJj0VpEbAWW8zMl08Bgg+zRpEAMcmsCKT/7EDtgV8kJIHvjCBW7O
StkRorQJhXldx+5t9XeFqhQelNRXe8+fK8U/vB1Ng+EkyGfDxQc9TMPMb7eL
Ydz99pD2W+l+w0DhkFZgO84Cu9Eq2JE3PGc4gad3TCEAyXB8veSQluScpLCr
gK1zCO3Q+X2jffO3WZiUcZhh7+7J4Zu360w6t40EsdklxsjjtAhuo1ExgeE0
PIXp5aujfTRQ0JUhlT7TzlwIIih1DuuCTk6ZtJXXBXTukrkFEs46jnJyEzRM
B3kSepJp+CSQAf4HBWwiBoHQQ6gpHnYItA8egSRpUT4G1BkXTkIYB7gJPjC1
c3BZ4vAKF1URZkXAk5EeAcCQBqXvGYW2gT2Nq9sYYNc8AU9JRM5hE5kJU0xs
4UrnE5Jm4E3xO7dNsGdgg+EaITCk45ViJZNDwEAMA+nBDG2IhI2GqnSDDNGl
Sa86/0k6+9ozhyFrs63MVEBqn64AU5kZbDriW8I+oAiZ1nqk8DQxKaxkY6e2
XXv61gACp4rTLPbaZtVPRK0CxN1adQA5B6MtSkmLiq47W/1t0dXmvTD7meUI
8OoGj0EzWBvYeopOi/la007AmIUZ2J6gEPKaPOQFny1EMTEpbJ43UELv08fB
ER08BAVYYnhW+ezp072gnGF0090NCFffwhTSac13royKrUbLKMCQUrrK0uyw
VnG1JNVDcwm1Qz5vdYXaEgaORzScaFuOYlDCjxHeM00WtFt4A241iWAiN+eh
3JxV4DySQSngYc4cZyiXcajt3gBBKf8VAxYbK4xCDkk4usFDMWV/Tl8ONuRU
pjxMZAAXvwGv00CtQrtjwumyPkDjQETEPI2DAVLI88UfBxT8VAM1yFdF8S0j
WopcRrTYEtLVrP4koMW0vVf91Wa5pBpsoIIto6FEs4Eqjat5QbVSw0BomNUV
C5rdfo3ixQNcsCvNMBMMwwXRpBzcHYKg2GKTc1S3BY8xauU1PSrOWvXrDQE3
VbHtaoiU5bAIwGxOczUF8tzYVQreDEUKAs95Bdqy6vzB0EitihWpwypSuSRF
sLeXFvDF16RCZdWsSgy/CbE4OQwafqqY778mcfRSXpUsCKBGlQVWC28QDvzm
8QkAu0wCQDDBJLCPEJVWC6u0SOWcRHDW9HYOIKXrCpjGwpNfw20jX8OgPh8p
I0CEdrmeFDqIuB+n0xlQUJxxCCxVINBxmqqoKVdfRw1pTFejOxkOSpem2XWY
RL/6HLOW6ePUMVoHU7fcOhpUsYsOfKsj5Bj0vwEFmCo7VcTHAv4JbfCoWBQB
yzEMC5HlA9PNeEwBUmho5VFEQNIoE+cScTSNCjyAAv7k4qTJYqPCgiZi7eD2
/l3GI3X0loPFrYx3cXbxL3r7Ekl8FCGKxgFZ5wEefii607CAC8hBUJQJABdr
v3HuVdfGAsAEAKGcpJ1GE1dnXtgepC2allNaEtPwE/0u+2lDa8M+A5RmkLHC
ZGvavR3mVWRoBV7KKKmzjCy+EtcoRCnVr+ZeTfpwelU2HuB6LJp5qfyvZfg3
HAWzKfwLKijG4BZ8tJjSwMhjIYYEIqOpi5OV3h/KtIiVyDlJ+LXof8iuQWLB
dBsOy2kppP7wiGZ/9uGopyPUapGocYejDQZ4b2jA4thIeycg0rOYa96XiXAt
VOuXbNw9PNrAMdbF2Rj5iO9pE8DBxW/nlF5IoX9z4IchdyLNBxMdryTL/jf8
MOzRUTHw2kHDZ8CLYFJWIKA26A1edERCGEZTOVsrs2QfO+4T1/L9T9N4P8n3
sdd+PTiOneURizrleIEctoWaNo41TLH15dUSCNp9hoVo+fNb9jO/2mfsnydF
Mcv3Nzfx6Afzdz7yjOSrB+A3b683Scw2ZYYZdHsP/Npn/4x5a0W6T9/+qNr/
qSOaiaMQgF5PUjU/CoRo03tVyUetwfIk69aBiUa9V9W83Bq0SmZuHRI16L1y
c3BrYOppsnVIDRmyfyKuWAFFwRn7gEVpU3X075zRuIcxMsaiEktMvpOwPMQa
suJIsJKsvCbG3tDhXj3HQKRVUIJZt3ZsIbp60wREthIFiLqNWUr10471apZT
LTWjJ1lwmM7usuh6UrDucB3T7LYpw5xdYr64DhKC8s1xUxcnDph4ISNquUyN
04kAQ6WJwYRGsLhX5zy74SM14jkfgeyTxlfhX1BKFN9Iy2woNDtYoZgqQOf8
G6QJRWdQJfhHWpLO14lLGxg1mKGlVaCCnJVZXoZJAezZMKdOeUlnsSptAFhI
BBVn9NKopP1BhDLOMeFBTfTVxREsWdEBs5IAMWAA4HwhYzI7vaEigaHfE+lv
v+fXQPozlKqcjKNztF/kpkHNj+QBo+zQVeqE0vY5N6pEYk2ew7oiKQmw0pMq
qcZJycgxbkgbhDqvfYGZHTLqKw9TwWDi8Zj09bgEBsaENiaIDXluxrKTC55g
UsGTDfF/TBHA31VyAf5OOQX6FwFCNhN5BeY3012nE+CflQyDJ8JdgBEPfnki
4jhPVJrBkyXSDAhINdeADXZYF0mBmQbr4lfMM1j3phlo6t2xxXINQFV1NjeZ
OObu7XvOtWFnKYHm9tE2DJnxaXrDsStNDjjCCZDqb+fnUN6pOSSXAjArr1Si
KzUQsGhvBkcO5aN7BxMASy4pJsEovFvvMAMS1UIw6Af9HdqW6+oWFS4RWcRv
RqSTmTnKUY2U8C10p4aA3FfwGAT9Z8FguxmPY3RZgYRyObRhgolPy2DS2fyh
w35gx+LYlVJQf9jEZaEPYu1z82YUFWx9aN6GJB5G7LO3GKEM4+hXLk2vXGI5
vRqFgchvCw7RqgZmy+7d9xeH6xvSUhNNUOWcg/IE2mx01D7rJCGz7mBrE3OV
1/fZIknTCog3d1qSDb/XJKKwABEJz/wlkZg41bbJ90J+UacfEIZG00P4aLc6
9YhsGspc6j0M+Zrp10bB0eoUPHpECmoAi0qgm8kPNOxvYsL/sjT03T/wk9CK
Q30BDd9oKPOIiAdajUREPSxAvUWFECWSrBqEoBxzBPS3QlRN0moGT7P6O2xK
jHlgNegs5EZyye+/jTIkom31k4oEVmnZKoXUXd0qkuT0cqiaxdTMocbUpW/C
IR9rVpbnJnGucoaINej3rye/urypUrGVNwCAvX33axt7qmPufuGQu0uPuLX7
ZSNu7S474mBr9oVjDrZ6c0etaPu65GMae4mxc/AK8Mr06EXTgjCavnlZ+PcY
OerezEPlGl5qyg2INdBirzefAxWsdFphsw548+VphG3a4kt2xJX2w4fQHosq
D4vILYzXTFiMu8twoYX1/qTNheSAUjqoK7O6tlAgv732r/U2VBZb9y24VOdN
LrBwfWuzZGuEj5NJa7VvXNxHZxd/dqdkerXb3dixexSNaU2Qp3o2wf4Xk2hc
sD/zO4r6GWgNevQvqyJAHbt/KcNRRne+Vhv+6CxYGQPVt3uEoY6zFFknwu/M
oKWbr0adgw/PVsLtGfRk3WdY/OIKrztadKJb4UU54uJcg2Ctt5BnVRRUXwuL
NkIZvDSI+fjBAIO91cSHenbh3wch0YpY6M42IotRiS1Hpu2tVckEPbvw74OQ
aUUsdGcbkccQpr2dVakEPbvw74NQaUUsdGcbkYehktlX+Dyf65W7D2HipMjD
1LmDb14fysbdN2l2i8kfr7MMNqxDvFRFxxDr4vpGpCOU8jIx3TfueXey6wBw
q+zOfAEL/K3MmWxChXXfBoDxeq8tNqKMsudPd9nNVq8v7bI+2mUKMCfAQwMY
92gNAssjAY8SDpzLCz7New0ikpcznq041wvs2zLTi6VmCubnzQCDC/2nMNfB
9sJznUTXE3YVFQEmWQljdOHpJ+mKcz9JUfCaiDpclaJFGGWU29FC1cP5ZD0A
h+cTO8CDLUXhp/3nQFygMFj5/efSyj+9/GmHxSkm3/AQFpWGoAuvNBFuVbqd
znjSMrlTmptc4nghT2bvaACv0pxvsMNJWI4mZRbROdC7dIgm//WET1n31eG7
dWRNK30O4xAPVwd7vZ3eTpVK27jm0BcaIJW2UA7RLkef6vTyxKBi0c3UqXlh
Ao2CCa8fFHwTO1YVuMM0QU86oQQaoBrrCumq5D2GCSO/kRkB1TDmSiodfosL
bglMBfSj6TxKS5h4wD/JkikXRwFhMdh6tkFnje/C6RT9VjpA192sDYYUOV3K
lzeJKUeBvOOh5PLupqL8LZ43sohO9jQMkanIji7eYc2wgocjUdLCpcxXWm8v
6nMUwI8eWExrw6g1sft4AmsOBM2lw0W3fp1HJlIvQN8z1PebCIpJUJQQJxI6
JBCRUIE5EyLBVONjblqq4VTKwtMe7kIWDShflN1s0z6MNBg8k9r3HsjnrkNr
YsHJ+d8C8PLfVo5RTIvWlYkJBQmgk3GwrRKc/q88S1kXoK77Z085bFd3hiFI
J0WPKiFwceQ5A2hsq7f7ti7cBoymzHZvq7dnU+b57nPctZ8hZcSu/Wy9SUNV
KQNLYfBNKaOykVR48FIk9WYF1twrWJphdi+IPSK6XpUrj2QtRMKnQMKKeH0J
EQd9I13fWIoAlYWF6OkDCtHWb1+ItkiItn6LQnR6+R4soODicHUqthKrLjjG
RREzhu03y+6oNiDIEMizIqmXlDvWKTpupusipWcxu5mRNaIBkDMZimRGpOU4
LTPP6O9DtIBgtPc+m7tBwgeLbSDtzHlzenw4+LrcUUyxjCPNHdz1T7FOm9ja
abclphwOBBd2sGwZtzp3xQwGi3PJdJXseiySm7QRX5mCZqPEyjPNuaqAhlxp
P9V59nyfXRBtkZav0dwVKY90ruIp0ye7V1Nm/acKUZYXwRg84LbJSOHxNmkV
I0xaRV1n7rkaGMLoFjl5fKTTBmSGLFjZPx+wrjW/Az3kOpvyYpLiyWEKPl3u
qFXfUCZ5L05veY4lzUb8U8MygtU7SqePQ49LOS8Xf+cmsG5soS9Qiu+aFj4P
gYlxGoLz8lXwFuIr3GsLTXT8dJ9JqK75ZtdI8ozn0QhDgHhTZUhxgETmU8K3
AnnjD0TJR4bVtEVBpww9SNYFv4wqwoK8Yh6nSrz2xwd1gY+WBEu6SFY5l/Ks
Q8uj2TdKzBys1hW/XHPeJUeIYTlAlyka31ZGnMkygqL6kaxy1nZuQ2DTolxl
MNglYfPy7qnrCw89Wm3oI2toSiRdbtTZaqOeWaOehXcole0Dm6CWLPzyJeFo
pLc/0Px1JLPuV6lZzRMT8HXAv9tjb68286YTBWzGVwTPcSvu9XfmDjBecYAx
DbD1dN4AW6vBx7y3PnBpLvgVCbQlCfR87gArEmhLEGh78LYF+PZqsLdZdwes
rcE83Lf5itKJHbs7O73duezd5isyGDvSEM/mDbGz2gA7SP9B79lcETpMVhsA
+nUT9gkcqV3Kj6mOYhQsAAtmYEdldEu1WeFRG8b/q8R0JLHLUgdyIdAikzc3
FRqnHy7I+MNbxmBS0OUdr54Sg+cyyyjAKvIm4UYpfBfL1tnjBRM1IFgYOd0x
FaMwNQpTo3R/3nz3axP90eWJYEjR91EQ6o5eTf2MqVYJWyI8qq6x4iUcWaUA
Y6LWPc5NcfVcMUvvWXRZXkXX5f8uzTUYeYFL1We2djeyD2lkFZsFr9ISB3tw
UwpIlLrMI1VxSuNq9XQrYipHVceVNe6iUkzT1qr8w63eroiXoDf2C/w03W85
dZ4fONY354PwFnfyS1kJR50Z+24tIfglby2xcIyHK7U3cOS0A3ODP1C1eOgy
NgLBO2x4iymfiBvV4IbAgOpSDt7TAfLqKzmF+FtklSolIw7Hk2Kw96LRysaS
aHTj+iaMS86enDxxizqpeg7FpFZcSS0JnSGo7swJIWsqxXS3wZ6Mn2zYlcWu
7kwCPhuzl2zwfHvQ7/f6Mp/4j+wElF8l35N1p+BalZk4E4Jm6yZ3WpwHVaB0
4e8efIB/X0JzxIAuMJKd9iRMwOPLapN6Iuw1UZUgF1cOsaaCLkCJuYLiqhyN
qgA8qaD7xJ2wWHmVHOBGeZdV2n7n+eZKSIffQEiNJ9wupZbH3CSgVtgDJHXn
6YAl00VENJmuVwVUdpaCOEyTG1TBVCFByqOFEEmiAuAXyEOPQNYlUcGoC2T1
JkabQH7dGxCPdDlFiaRMUf6fqTgxR/o3ri0Jxbo8VjLHN/BCvNKd+raAtlFr
Fwxaxferp+R/RQ0rKDG1xblcUp4/tMizyUY3kntg56g3iajV5CX7AKJ58fMC
komNmmTDn1T//y3jnaJaNvuxBIU6VvJdI1eVLsjQdE9bdO0tCy2Zt6Ps6YJR
QQQsFiJHUuV8pKsh62piaXYn8Qt0HcwmDquPVajan7u97drxTyNzXbT1+VCd
Srb7EugiH9kS9BIO16bjB1mAaLqU5BZiydwbTGBEjij3qRQVvuKMh6M7e94K
eTEVi+BUa+i7O1Rzhyym+j1sO0P4DihXCcBUOinXfaFl4nBf1rwRgrHu+uDz
XPCcf3e+f2fSphVxUOjbXvJVomE0DWMrOX+M79vhEh5F1xg+e24LWZngR2tg
Ya217s0V7Q+qArpsMCF0ZKoNtnbJWpNU9KF6vSyqex5U3y6P6lsH1QHearNQ
pZVh72FJthyWWx4sR69+7PcGybQZVXWWtC4P8HHNnaQRrMVzlH+mrRIyYAEY
eGqyLyyiNC5likAyIvPDsxcnWZBmQYK1hWxDLIlSEwYWm02SvbD/5tOZuhjY
qIoeGP0NEV78mKS3CZnZIPKEhrQH8VvZvUyoVc9jduLRr33SJmYD61RqWT1t
/Aw3u10T0neuKYqvLpTlcUGPiZJWf4NjrL1g1R8J5b46gBEbzxA77LAs0vFY
XLjDhGABvQnYdhuwbXYU5TNZlmpBgLttAHeBoUnwN8xfWx7yXhvkPS9kMj9h
I7rSNcTMT+2wsnnkp20jP2WvYIcMjpOcQvb4bKFvIs07MBlGuHePLHHL67Io
1UawpbTE6irFg8aBBUMuEMpiuQVXiSB4VkcVowWVQ7Xb0ppiLq5y7aOhIL6H
7Y+WONMevkcbuO1hx2VNauE6jMDMBtpeeZhQZZAqhrrW7/WmockDwv9q3d6+
AeF4uO2MXrUisyD9TYelKe8iI8ksbiko+hrKyk4VAotzJQSyGad5Po/U2OZr
klqgFxYFrH7pBTXQ3WC2IN1Nh5Xo3oDZSkxYhPLi9JDwnbbR/oVL3hYDxcyC
MJ/OGXRBstpdvoCwAqU51HTJKIHI/u3UVFTbXUl7766mEce4G81V37urqe/d
B1bfFrLN+lvCaObJYgpczWGwtxI7BnurTTGPPhUcz7znsUTj9Y154iLsY4sE
MG+ptLFFHAC/NU8o/7DZscp/ex4Rac41oHe0wFuzX+UCrMyTIbp+NkUG7oRv
Z5mHh7q32Euo5id+MZyk0VA8lGg7BA05FSKCSpVYqaLw/5bRXRoOM8lr5fso
3Vy8huCUtGOYcFs5Bxc/RNs1mewQYIofSguWgO32epviH43uhtVR/Pz7mluI
8N/X1tcc+P6pyQn+axhHVi1V6wFJ4DHO0uTDG8GzhFKV8N4XE7PbNo261BGV
i2/jCZSLZf3CJI272tmgi0FrYN1CQhHq3haLoUcgho8qEMOHFYjDJQRi+DgC
oWTAxbt+Sv77kAirMrjhEMXnNR2bHzXyeaZf80Dc7HteJc9nzfr9vfcVmyUU
rVTjnkK/TXUylBzvk1oTReA3GC+GvUV1Ny0rmRrjFp9bavX+ZnW57zBC/LQW
BqzCalzm741gqMSSaloKnbKqiKw49K9QaVd8yLZ2xf9BNkTYlpIDUIDqM/2t
rn7ffkACMPxaQvb194c5QtZUcrUK60uELJmCjEU9DjK21TfRZ/kzltpmwxxh
0Y1knLHYntTpl2r5+xC25q3G+xrYt95ctNw+WrKVHoFeF9je24ZZfDh7f8FO
L87eBJev7VuT+MKEehVtbOVhKBCNb4JUHj8/osfP65crPRsoPuTXuH+qqk/e
dyybt1GHHPXddGmnaBU3SI4lvsvp/IR0F9WFUmv18yJLXXTG8amzWujOaiQ8
ZENX3TS5Y/gzz7VpQ4tQW93FwZ8F3RxXI95XZ023Hj2TDuiNqry8UvcOvoAI
gGeg7xxsfQmJcqIRHrt/KZFIMqkqjJljvbsUlipFm/Q3oSxU0TnH19PA/haL
TWZP+fRRfdSagmqp665+/Ez+Egfzu6P2VRw1UMvfehdt3WGst1EbN5pKGE2/
+GhtN5J0ihhV2HKHke86ZT5KkiH5xLZa2Uu2VnkcYu2J//jWYvLagXkRzFio
KIuOlVoBbARQcdy761l4mxdZdVdaaq01nfGn1QJeuCKzrQYAlRD0vELPqvRs
SXQDtT7IFyrFM35XYJRgjNikwuY9sGsEeKCa8LLsJQUOl714fUtX5bU+22dv
snDK6R1ZzIs6B4UXZXLjQBkn0yvAO2bOEf8hyE2Wxq7V1Wxu2V3nWl42JYl/
uJtZpB+HwyLNquwT+coO5+Rp5cA+rWxg02A+Ww7Ezg2SjK+9jiuJzXaZ7Q0s
SUFbiftan/38qNXTfiiW0gRl6gR+aPKliXT1zhEWzomH8ulLJ3m6oQc58+xl
dRP0E/mHhsWzkICtYLw7ctwqUj45snt7RMqRqfDTI8kUXfF80mN/eslAdXrJ
+sQBSVVNgynP8/C6sr9+kA/UWuwj8FeoOnlYiNRhOhmiq7mw27t8rYtbr2Eh
PKbM12exhMzXO8+T+XqPJpn3CkGTzDtoHY9V9isfbfhm2MAnG4ZimY9LNAIe
5tVHsUG4VGkD+HtcsOq/FUvJfjl9sSNLfJx34TNL01qhp48q8Y9Hcsq/n0o2
+zZ1XxLk7/cdT/5+vsjWDmVUyQoAggs/K+np1yiBX37j/P1tOI5GHX5hbBIV
31dVcnKU79HGx4s2CqI8brTxezyx+vM9nvh7iyf+JlS5J0zXrM+PLe0dXuEV
UfVwciW/TotIXZu3BL4a33ptjcbpdA457r0ZfZZFqRN30y72sxdtIM9UP3A/
TNFZQ06ieRTTOzeyv70ku8cXh0ftr2Qgk3e2+uD6oNPT7PFYImDgk1cTnGVp
kQ7TuMbsLnlT6w45fjsGw8rZQHVT4RFSfr4n+9igvyf7fE/2kUT7nuzze0v2
+RaJOqrBVyiLpPeW5qzY9giddYq3aJxOYVbt6jF83GpNVcNYfttqhHyRRVz3
4KzHoXI54JVbyGRb1LFXUdkNUTqbDh/gY93dFEhv8pNU8eFwdMOzIsrlmtEQ
pi8HapVNeZjkqvRK5hQy97hfyYb7BIb5hqLOVBPZ0ysYIMHUFxqC1eKPAySt
Hro333b6ehV6RB/5vy9IUFMgHixBzVp4pn4DMaJx3VlPF1d4p6Aq0jelIzoJ
79ZKm7autOlyK23BwlK/HSlZRC1+aRahhuca4fMiaV6Kz4ug+aNnVZlwpa7q
LHpjUY3vuOObAW50qqrB8ecjv1P5FYmz+y+GWhM9iCbvcXxYsQYFRZa8wgAx
K9dG8ASdvLZnNRXQysZxUM6debeGbQqQlpiDOrGBSfmO5aTManf6i5FKtUNU
p+gPpRFMr8aZy6b2NMXFmdhqKr+vzXneNCsQvLNuis+1aJ/f4EaxeKzJbBWB
LlT16Oln39O9HjTdaykBtDovkt/lFUILxvf8ru/5Xd/zu77nd33P7/qe3zU3
v8t7722lU4qam2T5qCL02hDenXcuVqscXT8ccwwC2XJvtuXYBI0OUHOWhRNV
bT4bt8Vac8CJ7O/RwzC27dBwMvYlbjNbwXN2Dg1NQe8leaNrgM/hDLWr8uU7
+V3y2ytw4XNbemYwLMSboipgLwhnbTpqFnrDMKjLfBFQRU9OntibxhvcDj+F
U9A1GzJWFIozEFlEupExBobtGcAIih0b8lqK8+Vc/NqFYZiW8Qi3CrTdiecG
xnEiCtBiOGDDVPIhqCrmkU8UAE5TlU9qGiDgReUwJnBEFPY1O2/Oi0LV9HV4
CXvIlk3SCrPwjzhPZd2hMF+UklGig6JzBfsLr/Z+kUtstp3NHyxbJUpuYBlo
+RT9hyq/ACPpeQmLKRS0h+26x04vL6K3+/hffC9qhCKgFv0xsSMUrxtgEWVR
X06SGPd++mbIQYLRbqCXeQAftfhsLALAor4At7e0Gz2OYOMEnvneomJrS0xR
0VfOtG2WFinFq0J6C7cmNuf1KhI83S/Kqbo0kGpkv2SFSkKItRRmhaS94WOB
dHvgJ7lTS1u7o5RQnE5n0As0IqGXW4GIfIIPdmFl+vIaA1PyeTPncbNZhnXA
iUsg3Lk4hEVM92HFiXLaUj853WyqOFKl5w9qOb2tJJpb9EOZw3y0NLsDYGX7
u2PHwl7nhB6gIfRsnUBCSFXRfstiwy83qnXLQQdQJ1mL7BMeFUaFoLQbMVal
6SshY+fFgRfud5hwl6KGkk3cgZ0eThzV084bVW1v519HTfSV0stRx5LsqZWd
q8MzD9nqYeqWKa5ClmqfSlPFr0qfe8Y2N9vp5CO7A81L8KYWD01qRw7rRJbE
aJj9KhSzJ1lTJgvncRw6IfpQvq9t3s+And5Fp+rgihf7XG+7vsrVHLy9K4Ht
iiRU59YoMg6dlLBgEzy5B57VBaZTa0L6ruYONmrNR9pTnDGqm4qpV2g2DEX8
CvfBp8tdq+dn3CbEx8UGFUHVKpoO3cUD2jWGhtY5u8GEDvWVrddrd10WOhgy
Y/qGk5tFbkZyO1VXOJ364GeBk+jsX/bOOdDAG6kVk4j1sZzCtRVFZUgJNOq5
0fLpmc/umY+0JjEGuLW725hJ5SB3fFT3ZHzGiDc4R+qnwWQSP9IWERTddJZR
5a+12iL/I1urruIlUs0OxMjqwTkFR8qptoykRVTprQykava9fQFByU/17Zqq
GlW5BAJk7UtYbyEyTd+UqstenYX4Q3E80w3+qZOQiOiK+r9J+C+HZQbOTdFd
/4/GjrbFUyU9/rTdn9BFlOnVFVRmlARH+0XleaXc05lV9gZHk1XZVSVN670O
dbAqMaMnaFASFsFqwf3Ksz9VkfRJksd6+Z8jTJ7JPaBIeUzWpaXqMYRqQbwe
Sq48x/tk7ni2vLxjvm60CTqqxVyjxrF8fI+zNT5xUXt9jTqRXXFdhjBcwbmw
hEhVyysT2js+LvSJBtjT9ptsFDuil9goOE/+tj6ReRUcXQx/Du6KX7s36/L5
PWnHgr1nGeporeDmj90TbYlK9ooZZHjhSt23UnaWONH3EEJv4R53ck48xBhG
XqJVIkSGH83uo88ItaI+1qthgi2OoNpgc+sISTwN5hCi4c0ySQv/42RLkEM0
FK8A2U/eobcvsNHpH2a12ArfPGmXs+7B8XrDihRkqYeb29/ZU7P0N1p6svPf
4mvyvVqFZMahbXEXiOzFRvE4kP6mlcWiIskSgsx/1M6KTBM2568qhKc7UJIl
6/Z473qDHR5tsLMP+J+j9+s9R4p8KHqL3zdW7MefhidwxI/voRDDbA3Zqp1v
vqs+JeLn6RKRMNztTi9OzjWhwjxPh1HoxPZUCpM6qdbdzbtvTPpooKhIc7e9
g4NaVINYqmS/FqrNHxg93e54sxmXDqST0WcpWjUPzBT4wbzZZyYRR9NIFndy
NkRs3gVPjEhFh9FCfvCXQ/l/kKUN9hd1kE6QxMWtdex9nMhw3LgSw6iqP7IT
nb0BuwOOMkxRiSb7wjf1lQVryoB0nHhDEsESZ9pEPpOgYG3M9plxDNs6uiUY
ir+KoFGxxCVK07cWvVxUWb0CbHHQTQTGBDClLwzqOPkQVkROL7x5TmCMSFat
Bnnt4Glv0NuqK2bvlO0Xgs1rf9B0E6C1rt3mxO8MX85Ro3X1HTS8JNRfb5yw
BuJO3JoAZoKMovE4IKEKRiARd6z5QEVPZ5YvPxGVn3IE4yHZi4iu2MC4TIxL
04hk9F2EDcxTH4BwmHiuz+IMhpMsxdOOIcxFv8LmTMKnqlsUtV9N31dpsKnf
RVyBDOFwyGcFnT7Dr+VUpvXouTBrLt3DIytvME0cdevSBDXfcBQolf55WfRO
Z1IjNW0KoTpaNkjr3s3Ik1a3TlZJeys1jToYkCal6OzyqLASHZq0krxyc4o0
LhOxRlXPl2zcda42izoAo8q+3rCzt+7tc3b35v3dc9nQ2eOdsJdPvBpDhN7t
vjGxDZXJoWbSkcukue8f4c8Kj+3Y0yMD0jG0vCt6luLJuTRmKQrwdVf2gy9r
e0L2E9YIzuICWBbr89f3bPqtFnhtGnXs5690QN9Z6iuucRytssiRML+3Vf4Y
S/zMZhM+IO0sdSRcba1bIBZ4g+7R1vqIzzDUkRQBPRboLPX604cP5AjNWbuN
69hiBWJNXgRi3UXfcoFlPIq/7jJm/nXsxX6BZTyKv3DHhoFoJUsItdUM9PGu
5mZBeKA1tIwy19SzACCCK60HfbsXNz0cDdfEUqVpTL+VnaoPGoQYjU7v1PUm
+6g1SrS3bSaP/JfhLY+1DlyjkIMbrDTvdtce9FwCb+Wke9/s9r7WbTLoo7Fa
qCMBIyzYOeomfGTT+IkUgNedutmnAL7T6dLUeh21Ykz9KPf9w/FJIEIHIb6d
Osw4Pbps3Bo6fE7JmQzoTgQISZoXwZvXhyzhfJTL43lwz8Eb5aM6VX1ouBT2
vVa6lAeqbswK2LS4w9wijIjEYchOx/owxKCBoKJQzK9rwuyTi/yjqkXNZxrK
WbWaaT6KWumpPm0o3smdb9bMN2yq1KjqxRq1vErS96atUXyedfaA9se5IvEZ
IjEvHug8GYw/j2RrAC3+Ur3xJNSpJ8IxJ8zqBNhQ8fxFAga9gQu3mIC+maSx
Z7UaHX8VlqPAH0Cq4fNqtLxCfKXht6lwIzYqcmqpcEvoDTSZ54+YuXX+8rvp
VRpTRA55a/Yi8ZFpiBU9qC0yLcMwW0pJXabFrIwFS9W3Pau7SCGm9PJyeiXu
aIEjUoB6LSRga0OaoLkOdo2IglG2eJGvg1xjyDV1UlFlbs80yslUnvJRZF88
snCNMLme3IMwjm3plZMG4ZfjoVAwFZ/0RLCyNI6DdDx2hWARv3bH59cOamtj
nvwagSF7VaEjBbp7xYtQ6E5p4VEJkz6SbmBFpfRRUc4m6a00fWH6kgr5JER3
6NOQO5lU0ApXAclHjx2PX/blK9j8EwwPhJ2G8jJGQx/oMhDiLblLI+QuV3f7
/0sFSXVPXKmiTGZEp97M/vHpDlVzwXspylzDv578usIO61wzUHffcufqrLpJ
MZLxUyuFTt2OpmQkWZfBLnSDc79NgS/T9JonPC1zSl03uQJdUelmEt5IXRFO
TTwZFhAKHs9whQ1zBjiKkcTlB0s89YjrIk+ezgwjIvwdHXXP4nAI/E/4pwLl
h+ifYhK2w106jVeWxajkqroR7D9TsunicGbPeSr3WnsjQ65mNNR1DKsFC+YY
Z8Y6kZlg4RSHKlIAS7oNQgkvovpy6PCMJ9dUbaVaekVxC9VRmFg31y3e1Cim
r9Mgl8LRf4ZIWkLGE7M3+8eYD5dzDlSHZTXE2oEueASbWx0lhIvKzbOZLaLH
nvn0mC8+NxdPwM4g4sdT78zfDk974StkZLTg1WtwFNCYFgsSTQlr1wQlgTzA
QlFpBnZsIS5Re26ogb5CLydIwbdqdLaW8gDIK1Ll5XA7kN6fdqa0DIsdtDCI
56qgGijnUgahRI07Z3VUr4o1LxPljYg7X5wF273+6JXwzvTNM6NSJEKY1aXV
yLjMMBlHFuRabPh141mCXqt4hewiN8aS/uWS1BnxQlAwsrwmOnq1DlkdUmoQ
4L+C+/ojGzzf7j1ll+9+VXUl596TPD1+E+z0+387D/qDXn+fHaPfgYfdwiY7
uM44/cmokSfvpCzAEnhoQaIzb5PUEX50GCT8KGmW4UZwnVVDV9gAUEMN7wic
4a8tag1M0Q2tuIDESTKZKKOvPYGgFnYmL7mJzi1/BdBZDDi/Bgws6i4jGhoG
jNAqGo8pGUUlbCucTWOZeHVrsCUV6cqulitIrth4A5pCWCy8LO9VaLJQGFm1
hkox/ZWUzC/+0Gn+mDR2CJx/5LdfcPD1AAdcSPG/Br8wxASrXgzjciToF8rX
W6Wf7oa9G2LO/rOjIo15RlaTyMZ5HO1276ScerNocK126qk2bVfNmnPaDkVG
m5XZQzEhvIfcfKVJ0c25uqGFQ+R2f+vsG/vqCZkCC2TjWLuym5bTmqVs2e7n
1uUkFYTDXG0V+NNhI01cu6ynk91o55zKbO808U/jIZKGvHLXJlL1+15C2wVF
iXFWUTZsTqqt1I+ihzRbu+O/gwIHawdMTfot/LTuZEKSuyvMIFNgrsnhLYzD
2+zczkJ8T5Hy6q3LXcZdcp+vsK6dOVrenkVDNtNXQltu+l+CtrWbWlnv0FaV
7Z8fYFgecRstC3kQdIO5wBbrIeRYlQNr7m7tvhXGBVY4H1h25z2rCXaToPoU
atutUl8qo1SlQ/O2gaVVac+QIk5dI+Pm13ItUeO6Fx9En0tfhr5RTTlHyhY8
vtOhUzVE7YYPLqnNHxolwbsMMccTgZq7bx5KCriVC3WO/SwG+LeZHgB/+zsM
8B8yidTYce5RAoayv/TkSGwMamWDmTsrlSWmUvwi9WCF17SsoBR+eiiU5Kpd
DCVWobK2aCokzjSJM01iJvcr/3nNwxOZXgVbnMZ1jB6cxoth5KBUpEX4sAip
c/zsk1Vp7Vbc8JXt1e1yVcZ23n7dprFIYBbJS7culGhFnePKhP4yyA5qW3sx
Pv3lzwV37k/pQQIaxKtPjSJty/c2bPrWJudKCd91/7tiRDoVfuqWpMUuDeEr
244NyrF5jVSPfJtP9sXdSh1T0+G7WdPZre6/SpaYPxZi9/7w08UlOzm91Ifn
ElyVTxqAYY/HJqyqusUptlx+RIWKbpLBg1PRO09Lfz7yLGmkBeZYyR5eeY6u
JkZT21qSlq2Gr32lorBB9QExsJ9QBqzGjX7TmVHJ4q2RO571WZfev4W/Tc2t
dXZJULV/ri6FgFdXjse1Q8KrNIUW7S9qoILTvXmC8f7R5ijK6RcP383bI0GY
o76jkMeiKtnbu6qcnR3Dqit2EMeptHc/8GKS2rkOldKV2nmZ57I6m6ddGy/W
+TWgc+G3q7RMRqIQiexs3BlpXotrMiHFTtdriscd6uLd6U/vjxy1Q0d7iAAG
uJwy6eq9C3FGI7temcd3ylwVlxNl6aZmUwevKhw54kITW8pdXfKKn6CcGYAo
h7uj2DZ14wr9PLJGlF8OVVUUGGsCV2ZqVwNuqgVMExAMN8N6S8xqGbF6e54G
vV+NhlUUVqBh7UlDPFoOTI3CFoVUDSAatcT66oTagLGK+VypK2CqsXWS7T6B
mCdoc2fXVc/EPvVRp57i0LOuJUQB0X4rMQ9gGqNRpCxZMaLAGD4Xq66Qp43k
J1UIbOcu0eYxnPDhR7XceF5E09By1kbexwnxsKX7Fv67Pp9BooJLe2ElL3+c
IkoVBpDdX0xkfzOEwxM9meD6wc7eFEyLPkgMVaPHwc6jAAxKPI2/EVpmfY/w
bHAkDmOJ+6JeVhyNfcrL4I5qIi8eA30BeblZhCA61+SGzlLYgvF83374W72u
EsapFCXMzTHdq5y679x3/ht+Op/32R9gCkHBg7sQu0ZFzF+uKUG8pEvxvxyc
vBUZa3ytk6dlNuSUPgEL8yPYPy/XUDuuMeubBEZ/uRbxYhzEZBiJN4x+3Opv
bQeDftDf6eFwa7CaOn9gFxxMRvQuD2VGjjg2I4cSKWeNbyp+iyMk2J1H6bAk
c0YZAiHLYb1PQ5FuHBa09YskI3ovDAwYXc0Mc/dzVII3UcgSUeUU1T5sMARz
Jp8mFcVLEVCYs5PXl4enJ2/Y58//dP7mcG9rZ3B/jzbf+esL+4tn/Z3+/X1P
zEEyXXUlqiA4maGYIwl0gYesEA02dO6C3onAfg8idYYlu3WUyqOeAPFCQLuY
cBCY7sXFu3WD61YVJY21jdO7y8uziwWHd8e+fH+BMCQJdnb2YDzNSVlHFhlN
hrk8hCMm4IdFlsZ0FQnQPjk4/KDwfraNNO4INXgTjVSAXby5luLxPGjVYSH5
SZyfhaAtsQ5+pqku4jl6wrD7iSo5IRaWs5yFvLxS1RKBgOYdtwY4SkhM/CUn
ymFJGyCTJLfqbFqLyrU+bqksXEEfm3eqkgXJ+ZQMahWnipKblDY5HDsDnwN/
V6PKXJzQOxoXiayiNC+YSfAp0eAODNGp4V569Z98WOR65dnrUpSoEUU5YMnJ
chqIidosReLLSSrBaCgSgEyEB2uNzuJuM4xU467fk+H2DmNWvQ99hQikUURe
Q/XKIVaFwWxBvZ3aZVfEaHlPpQcDLWU8KNUJgZSaquHaY95GlOeBgMoiEhXF
cVwhdqSWUZGcnx1asrCh0gdASsH2CXHhkIJCMASRMiqJbEk6UgUN5fyQECh8
9FAsUkf8gaPqvsQ2imOR0MAAfDxGGst8MaXYLPmMxoJYUSKTxDA0RWI0DTFW
mZZ5fAdUAvdNWlc51wSSMLDgLtaIFINoPYzYa2aplSrILtUwkVblVLmCJLgN
TmiacSzzKPWR6BJSVEHqZ7XWxfKXhK0SMRTa0Ur1zLFGdgEbL9XlKWM0/JBv
mGyeTg2teHITZSm5urlZArnaqiqkABGLY7xLVBaKHjSpQW/gLmajG58+34Xt
gQ6E7kwhA01FkJlbgNnDDfL44OSgtjm+kRaDKS/10/mxGnzt+PXlG/bXD+/Z
Ob+OQDnercGw/wLDbu89e3Z/vyFgTkJMYR2JAh8kofqqTsTjkaDtWKVaWejt
d4T9ALOBUfdhOWTJPu73+xRFzvc/TeP9JN/HXX6/ZgeQ9hR4IdOokuuw2Bck
Pn598RYbAPLwycnmwQuJGvhMOSJK00TdQvNDU4Nef+oJjDqXLhmxEjs4DdRe
TdVWXNKVWKPP6FIb75wgzDUYUpDOYZg1c2wGKHqnd6LQWoU2Z0D06BP0jB2C
Sd7si8cz/wo/csr452vwl0AiTtICGpzFeH8MvQtMpaamplgPtpY3IkQ4RzlU
Ft1A7IIgYFfh8GOHjER5PyK4ivJ7FMlDeV+CFjFCfN5/vg3Et5w02m7GZVFS
rVVZXV6d8oyycIyjAGyBCx+9XCNDeo3gHwwxvgdLSlTQ1AswLGHLy3JtmeBa
RdkXJULwMit+HGX45uIQC6qh3/+RtMR5CsOQQvk5igv5yoleqTDzgjTsTcRv
CfwlzOyM4wMQ2JAeGoANjrBB7VZmym2bksGCXSxbFIzzdCZJyWQgSX99C+sO
TA6QBx0I+giiMaLY9/8D4+AIIi0uAQA=

-->

</rfc>

