<?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-03" 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="23"/>

    
    <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-23 {
    description
      "To be updated";
    reference
      "RFC XXXX: A YANG Data Model for Layer 0 Types";
  }
  revision 2021-08-13 {
    description
      "Initial version";
    reference
      "RFC 9093: A YANG Data Model for Layer 0 Types";
  }

/*
 * Identities
 */

  identity l0-grid-type {
    description
      "Layer 0 grid type";
    reference
      "RFC 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-pol-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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
n0H7KvcdtGneO312+zI+h+v8vYWKIwypOMp1i/E86C5wO0i1qA+yQM4+NGQ1
d/2fe1XWMFrx1XY8kQNc84TwrlQEVVhWLfihUgSVehF1PVV2PRffsp3n4i8o
iEjQUAGQ8i5/E/NE22RMChH8cmr36ywRF6ldw2k0DnCfpHbxDLQu7HLQup2e
keCRr7FcqmzJ3TESDHVc+DYqYaye/E2o368yUfziBZTlvRiNN+EsCiNWrxhZ
Ipio6XNfm2K7UJXazqrXLX9e4Md8orvdvGpsVZN/qqKuhXIvywuoKq5F7MaR
aOXCixopuJo/VFbSrFx1Qc/aBT1bVdBLVg7+C8rzMwW1SogVN3NhwMktoYWB
poYgU1WTbHWtL5Tc0ZpqkKZmXfCFp75vyF/suWpJIhp7Txx4J+9BKclQTMgq
HBf0V9f9jtjLSrPXb1GNl1uhl4apcvOXvLNH3W5k6LhlqBwBAaXz8vYESzoL
NN14sryAupQaGb328yjx1e4KLnuapKUkdAeZD8JRNBrHVJpa1aDCG2fQl1kx
Y+IWmyFIkoPBLa1p1gWlEAjA9ooFiKXEsBix1NfpAq6lqxYa46CNZfTVauu6
ldzWWYulJEyYWEwpjP0Ar+WtylJUv9tiFOq50e92Z/69c2AbMusvI6MDcegC
eIV4zdi4Mt+Zex628DwN8h0r99TQMQ9K1GVT84oyzGyr+1fwS7MCn7hYbx7i
7dxRIC+KssvxG5rQypd9W1ujufn9dcOgWlLj8PK9fXmoC8ajvJvj5pCUUCtb
t9e3ifhy6pitZf79F9QyqqN+1mXffctggezk8DMbKh0l5c14lvmT6hruzL+v
ClMVak9S7uei+phqJGhzMvhoFSnXFdA98X35kVDvykojod584UioN2kcCU6d
aBoJFdJOx2qfBB9tufrZIDILiBKfS2CEAmtb6mgsGDZv2iD+doey/rPECnzt
oHDdZzdWWCKi1RQ3W5ieaDqh28pRWN6Ffdx3yY2WRLgVkVpq557BeStQqg4J
XyIHgXfMN0Z1kBDDiQhjGecx8IpwDrMiPotCT4818cSW4FfI1dBpT3rPCjNv
0TUMoOqLtl1GB2QyGQbDs/NntgF7ixb6ni5k3FL3PYqQprwDslFIBhDTwwUk
SjRb8h5568fFNLarRqCu1VRnpncNIKfy6ixcI26VZaMEVq0Iy4s5OfVWnmtm
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
AhTpAAA=

-->

</rfc>

