<?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.5.26 (Ruby 2.7.2) -->


<!DOCTYPE rfc  [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">

]>

<?rfc comments="yes"?>

<rfc ipr="trust200902" docName="draft-ietf-ccamp-rfc9093-bis-00" category="std" consensus="true" obsoletes="9093" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title abbrev="Yang for Layer 0 Types">A YANG Data Model for Layer 0 Types</title>

    <author initials="H." surname="Zheng" fullname="Haomian Zheng">
      <organization>Huawei</organization>
      <address>
        <email>zhenghaomian@huawei.com</email>
      </address>
    </author>
    <author initials="Y." surname="Lee" fullname="Young Lee">
      <organization>Samsung</organization>
      <address>
        <email>younglee.tx@gmail.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="V." surname="Lopez" fullname="Victor Lopez">
      <organization>Nokia</organization>
      <address>
        <email>victor.lopez@nokia.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>
    <author initials="D." surname="Beller" fullname="Dieter Beller">
      <organization>Nokia</organization>
      <address>
        <email>dieter.beller@nokia.com</email>
      </address>
    </author>
    <author initials="S." surname="Belotti" fullname="Sergio Belotti">
      <organization>Nokia</organization>
      <address>
        <email>sergio.belotti@nokia.com</email>
      </address>
    </author>
    <author initials="I." surname="Busi" fullname="Italo Busi">
      <organization>Huawei</organization>
      <address>
        <email>italo.busi@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>

    <date year="2022" month="March" day="07"/>

    
    <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.698.2"/> and flexi-grid Dense
   Wavelength Division Multiplexing (DWDM) networks <xref target="RFC7698"/>
   <xref target="ITU-T_G.694.1"/>.</t>

<t>[Editors' Note]: This is the introduction from draft-ietf-ccamp-layer0-types-ext-01, to be reconciled with the introduction from RFC9093 above</t>

<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 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 aspect) for Layer 0 optical networks in
   model(s) defined outside of this document.</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>

<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 YANG data model in this document conforms to the Network
   Management Datastore Architecture defined in <xref target="RFC8342"/>.</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>RFCXXXX</c>
</texttable>

<t>RFC Editor Note:
Please replace XXXX with the RFC number assigned to this document.</t>

<t>The YANG module "ietf-layer0-types" (defined in <xref target="yang-code"/>) references
   <xref target="RFC4203"/>, <xref target="RFC6163"/>, <xref target="RFC6205"/>, <xref target="RFC7698"/>, <xref target="RFC7699"/>, <xref target="RFC8363"/>,
   <xref target="ITU-T_G.694.1"/>, and <xref target="ITU-T_G.694.2"/>.</t>

</section>
</section>
<section anchor="layer-0-types-module-contents"><name>Layer 0 Types Module Contents</name>

<t>This document defines a YANG module for common Layer 0 types, ietf-
   layer0-types.  This module is used for WSON and flexi-grid DWDM
   networks.  The "ietf-layer0-types" module contains the following YANG
   reusable types and groupings:</t>

<dl>
  <dt>
l0-grid-type  </dt>
  <dd>
    <t>A base YANG identity for the grid type as defined in <xref target="RFC6163"/> and
 <xref target="RFC7698"/>.</t>
  </dd>
  <dt>
dwdm-ch-spc-type  </dt>
  <dd>
    <t>A base YANG identity for the DWDM channel-spacing type as defined
 in <xref target="RFC6205"/>.</t>
  </dd>
  <dt>
cwdm-ch-spc-type  </dt>
  <dd>
    <t>A base YANG identity for the Coarse Wavelength Division
 Multiplexing (CWDM) channel-spacing type as defined in <xref target="RFC6205"/>.</t>
  </dd>
  <dt>
wson-label-start-end  </dt>
  <dd>
    <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>
  </dd>
  <dt>
wson-label-hop  </dt>
  <dd>
    <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>
  </dd>
  <dt>
l0-label-range-info  </dt>
  <dd>
    <t>A YANG grouping that defines the Layer 0 label range information
 applicable for WSON as defined in <xref target="RFC6205"/>.  This grouping is
 used in the flexi-grid DWDM by adding more flexi-grid-specific
 parameters.</t>
  </dd>
  <dt>
wson-label-step  </dt>
  <dd>
    <t>A YANG grouping that defines label steps for WSON as defined in
 <xref target="RFC8776"/>.</t>
  </dd>
  <dt>
flexi-grid-label-start-end  </dt>
  <dd>
    <t>The flexi-grid label range was defined in <xref target="RFC7698"/>, 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.</t>
  </dd>
  <dt>
flexi-grid-label-hop  </dt>
  <dd>
    <t>The flexi-grid label range was defined in <xref target="RFC7698"/>, and the
 generic topology model defines the label-hop in <xref target="RFC8795"/>.  This
 grouping shows the WSON-specific label-hop information.</t>
  </dd>
  <dt>
flexi-grid-label-range-info  </dt>
  <dd>
    <t>A YANG grouping that defines flexi-grid label range information as
 defined in <xref target="RFC7698"/> and <xref target="RFC8363"/>.</t>
  </dd>
  <dt>
flexi-grid-label-step  </dt>
  <dd>
    <t>A YANG grouping that defines flexi-grid label steps as defined in
 <xref target="RFC8776"/>.</t>
  </dd>
  <dt>
transceiver-capabilities  </dt>
  <dd>
    <t>a YANG grouping to define the transceiver capabilities (also called
   "modes") needed to determine optical signal compatibility.</t>
  </dd>
  <dt>
standard-mode  </dt>
  <dd>
    <t>a YANG grouping for ITU-T G.698.2 standard mode that guarantees
   interoperability.</t>
  </dd>
</dl>

<t>organizational-mode
   :a YANG grouping to define transponder operational mode supported by
   organizations or vendors.</t>

<dl>
  <dt>
common-explicit-mode  </dt>
  <dd>
    <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>
  </dd>
  <dt>
common-organizational-explicit-mode  </dt>
  <dd>
    <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>
  </dd>
  <dt>
cd-pmd-penalty  </dt>
  <dd>
    <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>
  </dd>
</dl>

</section>
<section anchor="yang-code"><name>YANG Module for Layer 0 Types</name>

<figure><artwork><![CDATA[
<CODE BEGINS> file "ietf-layer0-types@2022-03-07.yang"
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: Haomian Zheng
       <mailto:zhenghaomian@huawei.com>

     Editor: Young Lee
       <mailto:younglee.tx@gmail.com>

     Editor: Aihua Guo
       <mailto:aihuaguo.ietf@gmail.com>

     Editor: Victor Lopez
       <mailto:victor.lopez@nokia.com>

     Editor: Daniel King
       <mailto:d.king@lancaster.ac.uk>";

  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) 2022 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 Simplified
     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 9093; see
     the RFC itself for full legal notices.";

  revision 2022-03-07 {
    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 6163: Framework for GMPLS and Path Computation Element
       (PCE) Control of Wavelength Switched Optical Networks (WSONs),
       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency grid,
       ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
       CWDM wavelength grid";
  }

  identity flexi-grid-dwdm {
    base l0-grid-type;
    description
      "Flexi-grid";
    reference
      "RFC 7698: Framework and Requirements for GMPLS-Based Control
       of Flexi-Grid Dense Wavelength Division Multiplexing (DWDM)
       Networks,
       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency grid";
  }

  identity wson-grid-dwdm {
    base l0-grid-type;
    description
      "DWDM grid";
    reference
      "RFC 6163:Framework for GMPLS and Path Computation Element
       (PCE) Control of Wavelength Switched Optical Networks (WSONs),
       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency 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 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 {
    description
      "Flexi-grid channel-spacing type";
    reference
      "RFC 7698: Framework and Requirements for GMPLS-Based Control
       of Flexi-Grid Dense Wavelength Division Multiplexing (DWDM)
       Networks,
       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency grid";
  }

  identity flexi-ch-spc-6p25ghz {
    base flexi-ch-spc-type;
    description
      "6.25 GHz channel spacing";
  }

  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 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 modulation {
    description "base identity for modulation type";
  }

  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-State Quadrature Amplitude Modulation) modulation";
  }

  identity QAM16 {
    base modulation;
    description
      "QAM16 (Quadrature Amplitude Modulation)";
  }

  identity DP-QAM8 {
    base modulation;
    description
      "DP-QAM8 (Dual Polarization Quadrature Amplitude Modulation)";
  }

  identity DC-DP-QAM8 {
    base modulation;
    description
      "DC DP-QAM8 (Dual Carrier Dual Polarization Quadrature
       Amplitude Modulation)";
  }

  identity DP-QAM16 {
    base modulation;
    description
      "DP-QAM16 (Dual Polarization Quadrature Amplitude 
       Modulation)";
  }

  identity DC-DP-QAM16 {
    base modulation;
    description
      "DC DP-QAM16 (Dual Carrier 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
      "G-FEC (Generic-FEC)";
  }
  identity e-fec {
    base fec-type;
    description
      "E-FEC (Enhanced-FEC)";
  }
  identity no-fec {
    base fec-type;
    description
      "No FEC";
  }

  identity reed-solomon {
    base fec-type;
    description
      "Reed-Solomon error correction";
  }

  identity hamming-code {
    base fec-type;
    description
      "Hamming Code error correction";
  }

  identity golay {
    base fec-type;
      description "Golay error correction";
  } 

  identity line-coding {
    description
      "base line-coding class";
    reference 
      "ITU-T G.698.2-201811 section 7";
  }  

  identity line-coding-NRZ-2p5G {
    base line-coding;
    description 
      "ITU-T G.698.2-201811 section 7 table 8-1";
  }

  identity line-coding-NRZ-OTU1 {
    base line-coding;
    description
      "ITU-T G.698.2-201811 section 7 table 8-2";
  }

  identity line-coding-NRZ-10G {
    base line-coding;
    description
      "ITU-T G.698.2-201811 section 7 table 8-3/8-5";
  }

  identity line-coding-NRZ-OTU2 {
    base line-coding;
    description
      "ITU-T G.698.2-201811 section 7 table 8-4/8-6";
  }

  identity wavelength-assignment {
    description
      "Wavelength selection base";
    reference
      "RFC6163:Framework for GMPLS and Path Computation Element 
      (PCE) Control of Wavelength Switched Optical Networks (WSONs)";
  }

  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)";
  }

/*
 * 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 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 flexi-ch-spc-type.

       Note that the term 'channel spacing' can be substituted by the
       term 'nominal central frequency granularity' defined in
       clause 8 of ITU-T G.694.1.";
    reference
      "RFC 7698: Framework and Requirements for GMPLS-Based Control
       of Flexi-Grid Dense Wavelength Division Multiplexing (DWDM)
       Networks,
       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 7698: Framework and Requirements for GMPLS-Based Control
       of Flexi-Grid Dense Wavelength Division Multiplexing (DWDM)
       Networks.
       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency grid";
  }

  typedef operational-mode {
    type string;
    description
      "Organization/vendor specific mode that guarantees 
      interoperability.";
    reference "ITU-T G.698.2 (11/2018)";
  }

  typedef standard-mode {
    type string;
    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";
    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
      "RFC7581: Routing and Wavelength Assignment Information
       Encoding for Wavelength Switched Optical Networks";
  }

  typedef frequency-thz {
      type decimal64 {
        fraction-digits 6;
      }
      units THz;
      description
        "The DWDM frequency in THz, e.g., 193.112500";
      reference
        "RFC6205: Generalized Labels for
        Lambda-Switch-Capable (LSC) Label Switching Routers";
  }
  typedef frequency-ghz {
      type decimal64 {
        fraction-digits 3;
      }
      units GHz;
      description
        "The DWDM frequency in GHz, e.g., 193112.500";
      reference
        "RFC6205: Generalized Labels for
        Lambda-Switch-Capable (LSC) Label Switching Routers";
  }    

  typedef dbm-t {
    type int32;
    units ".01dbm";
    description
      "Amplifiers and Transceivers Power in dBm.";
  }

  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 know or
      an empty value when the value is not known.";
  }

  typedef power-in-db {
    type decimal-2-digits;
    units dB;
    description
      "The power in dB.";
  }

  typedef power-in-db-or-null {
    type union {
      type power-in-db;
      type empty;
    }
    description
      "The power in dB, when it is known or an empty value when the
      power 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.";
  }

/*
 * Groupings
 */

  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.";
    }
    reference
      "RFC 7698: Framework and Requirements for GMPLS-Based Control
       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 7698: Framework and Requirements for GMPLS-Based Control
       of Flexi-Grid Dense Wavelength Division Multiplexing (DWDM)
       Networks";
  }

  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 {
        list subcarrier-flexi-n {
          key "flexi-n";
          uses flexi-grid-frequency-slot;
          description
            "List of subcarrier channels for flexi-grid super
             channel.";
        }
      }
    }
    reference
      "RFC 7698: Framework and Requirements for GMPLS-Based Control
       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 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 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";
      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.";
    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;
      }
      case organizational-mode {
        container organizational-mode {
          description
            "The set of attributes for an organizational mode";
          uses organizational-mode;
          uses common-organizational-explicit-mode;
        }  // container organizational-mode
      }
      case explicit-mode {
        container explicit-mode {
            description
              "The set of attributes for an explicit mode";
          container supported-modes {
            description
              "Container for all the standard and organizational
                modes supported by the transceiver's explicit
                mode.";
            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.";
            }
          }  // container supported-modes
          uses common-explicit-mode;
          uses common-organizational-explicit-mode;
        }  // 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 {
      description
        "Transceiver's supported modes.";
      list supported-mode {
        key "mode-id";
        config false;
        description "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;
      }  // 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 cd-pmd-penalty {
    description "entries of table; triplet chromatic
    dispersion, polarization mode dispersion and
    associated penalty";

    leaf chromatic-dispersion {
      type union {
        type decimal64 {
          fraction-digits 2;
          range "0..max";
        }
        type empty;
      }
      units "ps/nm";
      config false;
      mandatory true;
      description "chromatic dispersion";
    }
    leaf polarization-mode-dispersion {
      type union {
        type decimal64 {
          fraction-digits 2;
          range "0..max";
        }
        type empty;
      }
      units "ps";
      config false;
      mandatory true;
      description "Polarization mode dispersion";
    }
    leaf penalty {
      type union {
        type decimal64 {
          fraction-digits 2;
          range "0..max";
        }
        type empty;
      }
      units "dB";
      config false;
      mandatory true;
      description "Associated penalty on the receiver";
    }
  }  

  grouping pdl-penalty {
    description
      "entries of table; pair of values polarization dependent loss
      and associated penalty";

    leaf max-polarization-dependent-loss {
      type power-in-db-or-null;
      config false;
      mandatory true;
      description
        "Maximum acceptable accumulate polarization dependent loss";
    }
    leaf penalty {
      type union {
        type uint8;
        type empty;
      }
      units "dB";
      config false;
      mandatory true;
      description "Associated penalty on the receiver";
    }
  }

/* 
 * 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-polarization-mode-dispersion {
      type decimal64 {
        fraction-digits 2;
        range "0..max";
      }
      units "ps";
      config false;
      description
        "Maximum acceptable accumulated polarization mode
         dispersion on the receiver";
    }
    leaf max-chromatic-dispersion {
      type decimal64 {
        fraction-digits 2;
        range "0..max";
      }
      units "ps/nm";
      config false;
      description
        "Maximum acceptable accumulated chromatic dispersion
         on the receiver";
    }
    list chromatic-and-polarization-dispersion-penalty {
      config false;
      description
        "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).";
      uses cd-pmd-penalty ;
    }
    leaf max-diff-group-delay  {
      type int32;
      config false;
      description "Maximum Differential group delay of this mode
                  for this lane";
    }
    list max-polarization-dependent-loss-penalty {
      config false;
      description
        "Optional penalty associated with the maximum acceptable 
        accumulated polarization dependent loss.
         This list of pair pdl and penalty can be used to
         sample the function pdl = f(penalty).";
      uses pdl-penalty ;
    }
    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;
      config false;
      description "min OSNR measured over 0.1 nm 
      resolution bandwidth:
      if received OSNR at minimum Rx-power is lower than MIN-OSNR,
      an increased level of bit-errors post-FEC needs 
      to be expected.";
      // change resolution BW from 12.5 GHz to 0.1 nm
    }
    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";
    }
  } // grouping common-explicit-mode    

  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) */

    leaf min-central-frequency {
      type frequency-thz;
      config false;
      description
        "This parameter indicates the minimum frequency for the
        transmitter tuning range.";
    }
    leaf max-central-frequency {
      type frequency-thz;
      config false;
      description
        "This parameter indicates the maximum frequency for the
        transmitter tuning range.";
    }

/* transmitter-tunability-grid */

    leaf central-frequency-step {
      type frequency-ghz;
      config false;
      description
        "This parameter indicates the transmitter tunability grid as
        the distance between two adjacent carrier frequencies of
        the transmitter tuning range.";
    } 

/* supported transmitter power range [p_tx-min, p_tx_max] */

    leaf tx-channel-power-min {
      type dbm-t;
      config false;
      description "The minimum output power of this interface";
    }
    leaf tx-channel-power-max {
      type dbm-t;
      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 dbm-t;
      config false;
      description "The minimum input power of this interface";
    }
    leaf rx-channel-power-max {
      type dbm-t;
      config false;
      description "The maximum input power of this interface";
    }

    leaf rx-total-power-max {
      type dbm-t;
      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 otsi-carrier-frequency {
      type union {
        type frequency-thz;
        type empty;
      }
      description
        "OTSi carrier frequency, equivalent to the
        actual configured transmitter frequency";
    }
    leaf tx-channel-power {
      type union {
        type dbm-t;
        type empty;
      }
      description "The current channel transmit power";
    }
    leaf rx-channel-power {
      type union {
        type dbm-t;
        type empty;
      }
      config false;
      description "The current channel received power ";
    }
    leaf rx-total-power {
      type union {
        type dbm-t;
        type empty;
      }
      config false;
      description "Current total received power";
    }
  } // grouping for configured attributes out of mode

  grouping l0-tunnel-attributes {
    description
      "Parameters for Layer0 (WSON or Flexi-Grid) Tunnels.";
    leaf fec-type {
      type identityref {
        base fec-type;
      }
      description
        "FEC type.";
    }
    leaf termination-type {
      type identityref {
        base term-type;
      }
      description
        "Termination type.";
    }
    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
      "The parameters that define a frequency range.";
    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.";
    }
  }
}
<CODE ENDS>
]]></artwork></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>IANA has assigned new URIs from the "IETF XML Registry" <xref target="RFC3688"/> as
   follows:</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 registers the following YANG module in 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 9093
]]></artwork></figure>

<t>[Editors' Note] Check the IANA considerations in other bis documents</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'><organization/></author>
<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'><organization/></author>
<author fullname='M. Bjorklund' initials='M.' role='editor' surname='Bjorklund'><organization/></author>
<author fullname='J. Schoenwaelder' initials='J.' role='editor' surname='Schoenwaelder'><organization/></author>
<author fullname='A. Bierman' initials='A.' role='editor' surname='Bierman'><organization/></author>
<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='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'><organization/></author>
<author fullname='G. Bernstein' initials='G.' role='editor' surname='Bernstein'><organization/></author>
<author fullname='W. Imajuku' initials='W.' surname='Imajuku'><organization/></author>
<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'><organization/></author>
<author fullname='R. Casellas' initials='R.' role='editor' surname='Casellas'><organization/></author>
<author fullname='F. Zhang' initials='F.' surname='Zhang'><organization/></author>
<author fullname='X. Fu' initials='X.' surname='Fu'><organization/></author>
<author fullname='D. Ceccarelli' initials='D.' surname='Ceccarelli'><organization/></author>
<author fullname='I. Hussain' initials='I.' surname='Hussain'><organization/></author>
<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 &quot;frequency slot&quot;.  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='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'><organization/></author>
<author fullname='J. Schoenwaelder' initials='J.' surname='Schoenwaelder'><organization/></author>
<author fullname='P. Shafer' initials='P.' surname='Shafer'><organization/></author>
<author fullname='K. Watsen' initials='K.' surname='Watsen'><organization/></author>
<author fullname='R. Wilton' initials='R.' surname='Wilton'><organization/></author>
<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='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'><organization/></author>
<author fullname='Y. Rekhter' initials='Y.' role='editor' surname='Rekhter'><organization/></author>
<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='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'><organization/></author>
<author fullname='D. Li' initials='D.' role='editor' surname='Li'><organization/></author>
<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'><organization/></author>
<author fullname='D. King' initials='D.' surname='King'><organization/></author>
<author fullname='Y. Li' initials='Y.' surname='Li'><organization/></author>
<author fullname='F. Zhang' initials='F.' surname='Zhang'><organization/></author>
<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='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'><organization/></author>
<author fullname='H. Zheng' initials='H.' surname='Zheng'><organization/></author>
<author fullname='R. Casellas' initials='R.' surname='Casellas'><organization/></author>
<author fullname='O. Gonzalez de Dios' initials='O.' surname='Gonzalez de Dios'><organization/></author>
<author fullname='D. Ceccarelli' initials='D.' surname='Ceccarelli'><organization/></author>
<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 &quot;frequency slot&quot;. Corresponding techniques for data-plane connections are known as &quot;flexi-grid&quot;.</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='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'><organization/></author>
<author fullname='I. Bryskin' initials='I.' surname='Bryskin'><organization/></author>
<author fullname='V. Beeram' initials='V.' surname='Beeram'><organization/></author>
<author fullname='T. Saad' initials='T.' surname='Saad'><organization/></author>
<author fullname='H. Shah' initials='H.' surname='Shah'><organization/></author>
<author fullname='O. Gonzalez de Dios' initials='O.' surname='Gonzalez de Dios'><organization/></author>
<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='RFC8776' target='https://www.rfc-editor.org/info/rfc8776'>
<front>
<title>Common YANG Data Types for Traffic Engineering</title>
<author fullname='T. Saad' initials='T.' surname='Saad'><organization/></author>
<author fullname='R. Gandhi' initials='R.' surname='Gandhi'><organization/></author>
<author fullname='X. Liu' initials='X.' surname='Liu'><organization/></author>
<author fullname='V. Beeram' initials='V.' surname='Beeram'><organization/></author>
<author fullname='I. Bryskin' initials='I.' surname='Bryskin'><organization/></author>
<date month='June' year='2020'/>
<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.</t></abstract>
</front>
<seriesInfo name='RFC' value='8776'/>
<seriesInfo name='DOI' value='10.17487/RFC8776'/>
</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'><organization/></author>
<author fullname='M. Bjorklund' initials='M.' surname='Bjorklund'><organization/></author>
<author fullname='K. Watsen' initials='K.' surname='Watsen'><organization/></author>
<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'><organization/></author>
<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'><organization/></author>
<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'><organization/></author>
<author fullname='M. Bjorklund' initials='M.' surname='Bjorklund'><organization/></author>
<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='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'><organization/></author>
<author fullname='Y. Lee' initials='Y.' surname='Lee'><organization/></author>
<author fullname='A. Guo' initials='A.' surname='Guo'><organization/></author>
<author fullname='V. Lopez' initials='V.' surname='Lopez'><organization/></author>
<author fullname='D. King' initials='D.' surname='King'><organization/></author>
<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'><organization/></author>
<author fullname='G. Bernstein' initials='G.' role='editor' surname='Bernstein'><organization/></author>
<author fullname='D. Li' initials='D.' surname='Li'><organization/></author>
<author fullname='W. Imajuku' initials='W.' surname='Imajuku'><organization/></author>
<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'><organization/></author>
<author fullname='Y. Lee' initials='Y.' role='editor' surname='Lee'><organization/></author>
<author fullname='D. Li' initials='D.' surname='Li'><organization/></author>
<author fullname='W. Imajuku' initials='W.' surname='Imajuku'><organization/></author>
<author fullname='J. Han' initials='J.' surname='Han'><organization/></author>
<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 &quot;Routing and Wavelength                           Assignment Information Model for Wavelength Switched Optical Networks&quot; (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'>
   <front>
      <title>A YANG model to manage the optical interface parameters for an external transponder in a WDM network</title>
      <author fullname='Gabriele Galimberti'>
	 <organization>Cisco</organization>
      </author>
      <author fullname='Ruediger Kunze'>
	 <organization>Deutsche Telekom</organization>
      </author>
      <author fullname='Andreas Burk'>
	 <organization>Deutsche Telekom</organization>
      </author>
      <author fullname='Dharini Hiremagalur'>
	 <organization>Juniper</organization>
      </author>
      <author fullname='Gert Grammel'>
	 <organization>Juniper</organization>
      </author>
      <date day='12' month='July' year='2021'/>
      <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
   [ITU.G698.2] or any other ITU-T recommendation.  More context about
   the state of the Coherent transceivers is described in draft-many-
   coherent-DWDM-if-control.  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 means
   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-06'/>
   <format target='https://www.ietf.org/archive/id/draft-ietf-ccamp-dwdm-if-param-yang-06.txt' type='TXT'/>
</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'><organization/></author>
<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="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>
    </section>

  </back>

<!-- ##markdown-source:
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
AAA=

-->

</rfc>

