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


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

]>

<?rfc comments="yes"?>

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

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

    <date year="2022" month="October" day="21"/>

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

<ul empty="true"><li>
  <t>A YANG grouping that defines label steps for WSON as defined in
     <xref target="RFC8776"/>.</t>
</li></ul>

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

<ul empty="true"><li>
  <t>The flexi-grid label range was defined in <xref target="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>
</li></ul>

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

<ul empty="true"><li>
  <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>
</li></ul>

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

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

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

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

<t>transceiver-capabilities:</t>

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

<t>standard-mode:</t>

<ul empty="true"><li>
  <t>a YANG grouping for ITU-T G.698.2 standard mode that guarantees
   interoperability.</t>
</li></ul>

<t>organizational-mode:</t>

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

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

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

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

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

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

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

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

<figure><artwork><![CDATA[
<CODE BEGINS> file "ietf-layer0-types@2022-07-11.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:  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) 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 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 2022-10-20 {
    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 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 DC-DP-QAM8 {
    base modulation;
    description
      "DC DP-QAM8 (8 symbols Dual Carrier 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 DC-DP-QAM16 {
    base modulation;
    description
      "DC DP-QAM16 (16 symbols Dual Carrier 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
      "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.";
// 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
    reference
      "Section 2.5.2 of RFC YYYY: A YANG Data Model for Optical
      Impairment-aware Topology.";
  }

  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 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 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 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
        "OSNR penalty associated with the related optical
        impairment at 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-dispersion-penalty {
      config false;
      description
        "Optional penalty associated with a given accumulated
         chromatic dispersion (CD) value.
         This list of pair cd and penalty can be used to
         sample the function penalty = f(CD).";
      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";
      }
      uses penalty-value;
    }
    list polarization-dispersion-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 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";
      }
      uses penalty-value;
    }
    leaf max-diff-group-delay  {
      type uint32;
      units "ps";
      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).";
      leaf max-polarization-dependent-loss {
        type power-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;
      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";
    }
    leaf in-band-osnr {
      type snr;
      config false;
      description
        "The OSNR defined within the bandwidth of the transmit 
        spectral excursion (i.e.,  between the nominal central 
        frequency of the channel and the -3.0dB points of the 
        transmitter spectrum furthest from the nominal central 
        frequency) measured at reference point Ss.
        
        The in-band OSNR is referenced to an optical bandwidth of 
        0.1nm @ 193.7 THz or 12.5 GHz.";
      reference
        "OIF-400ZR-01.0: Implementation Agreement 400ZR";
    }
    leaf out-of-band-osnr {
      type snr;
      config false;
      description
        "The ratio of the peak transmitter power to the integrated 
        power outside the transmitter spectral excursion.
        
        The spectral resolution of the measurement shall be better 
        than the maximum spectral width of the peak.
        
        The out-of-band OSNR is referenced to an optical bandwidth 
        of 0.1nm @ 193.7 THz or 12.5 GHz";
      reference
        "OIF-400ZR-01.0: Implementation Agreement 400ZR";
    }
    leaf tx-polarization-power-difference {
      type power-in-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-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.";
    }

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

/* 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 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 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.";
    }
  }
}
<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>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'><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='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'><organization/></author>
<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'><organization/></author>
<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='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' initials='G.' surname='Galimberti'>
         <organization>Cisco</organization>
      </author>
      <author fullname='Ruediger Kunze' initials='R.' surname='Kunze'>
         <organization>Deutsche Telekom</organization>
      </author>
      <author fullname='Andreas Burk' initials='A.' surname='Burk'>
         <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='11' month='July' year='2022'/>
      <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.  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-07'/>
   <format target='https://www.ietf.org/archive/id/draft-ietf-ccamp-dwdm-if-param-yang-07.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="G." surname="Galimberti" fullname="Gabriele Galimberti">
      <organization>Cisco</organization>
      <address>
        <email>ggalimbe@cisco.com</email>
      </address>
    </contact>
    <contact initials="E." surname="Griseri" fullname="Enrico Griseri">
      <organization>Nokia</organization>
      <address>
        <email>Enrico.Griseri@nokia.com</email>
      </address>
    </contact>
    <contact initials="D." surname="Dhody" fullname="Dhruv Dhody">
      <organization>Huawei</organization>
      <address>
        <email>dhruv.ietf@gmail.com</email>
      </address>
    </contact>
    <contact initials="B. Y." surname="Yoon" fullname="Bin Yeong Yoon">
      <organization>ETRI</organization>
      <address>
        <email>byyun@etri.re.kr</email>
      </address>
    </contact>
    <contact initials="R." surname="Vilalta" fullname="Ricard Vilalta">
      <organization>CTTC</organization>
      <address>
        <email>ricard.vilalta@cttc.es</email>
      </address>
    </contact>
    <contact initials="Y." surname="Lee" fullname="Young Lee">
      <organization>Samsung</organization>
      <address>
        <email>younglee.tx@gmail.com</email>
      </address>
    </contact>
    <contact initials="V." surname="Lopez" fullname="Victor Lopez">
      <organization>Nokia</organization>
      <address>
        <email>victor.lopez@nokia.com</email>
      </address>
    </contact>
    </section>

  </back>

<!-- ##markdown-source:
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
6QAA

-->

</rfc>

