<?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.9 (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-01" 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="H." surname="Zheng" fullname="Haomian Zheng">
      <organization>Huawei</organization>
      <address>
        <email>zhenghaomian@huawei.com</email>
      </address>
    </author>
    <author initials="Y." surname="Lee" fullname="Young Lee">
      <organization>Samsung</organization>
      <address>
        <email>younglee.tx@gmail.com</email>
      </address>
    </author>
    <author initials="A." surname="Guo" fullname="Aihua Guo">
      <organization>Futurewei Technologies</organization>
      <address>
        <email>aihuaguo.ietf@gmail.com</email>
      </address>
    </author>
    <author initials="V." surname="Lopez" fullname="Victor Lopez">
      <organization>Nokia</organization>
      <address>
        <email>victor.lopez@nokia.com</email>
      </address>
    </author>
    <author initials="D." surname="King" fullname="Daniel King">
      <organization>University of Lancaster</organization>
      <address>
        <email>d.king@lancaster.ac.uk</email>
      </address>
    </author>
    <author initials="D." surname="Beller" fullname="Dieter Beller">
      <organization>Nokia</organization>
      <address>
        <email>dieter.beller@nokia.com</email>
      </address>
    </author>
    <author initials="S." surname="Belotti" fullname="Sergio Belotti">
      <organization>Nokia</organization>
      <address>
        <email>sergio.belotti@nokia.com</email>
      </address>
    </author>
    <author initials="I." surname="Busi" fullname="Italo Busi">
      <organization>Huawei</organization>
      <address>
        <email>italo.busi@huawei.com</email>
      </address>
    </author>
    <author initials="E." surname="Le Rouzic" fullname="Esther Le Rouzic">
      <organization>Orange</organization>
      <address>
        <email>esther.lerouzic@orange.com</email>
      </address>
    </author>

    <date year="2022" month="July" day="11"/>

    
    <workgroup>CCAMP Working Group</workgroup>
    

    <abstract>


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

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



    </abstract>



  </front>

  <middle>


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

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

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

<t>[Editors' Note]: This is the introduction from draft-ietf-ccamp-layer0-types-ext-01, to be reconciled with the introduction from RFC9093 above</t>

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

<t>This document introduces a collection of common data types derived
   from the built-in YANG data types.  The derived types and groupings
   are designed to be the common types applicable for modeling Traffic
   Engineering (TE) features as well as non-TE features (e.g., physical
   network configuration aspect) for Layer 0 optical networks in
   model(s) defined outside of this document.</t>

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

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

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

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

<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: Haomian Zheng
       <mailto:zhenghaomian@huawei.com>

     Editor: Young Lee
       <mailto:younglee.tx@gmail.com>

     Editor: Aihua Guo
       <mailto:aihuaguo.ietf@gmail.com>

     Editor: Victor Lopez
       <mailto:victor.lopez@nokia.com>

     Editor: Daniel King
       <mailto:d.king@lancaster.ac.uk>";

  description
    "This module defines Optical Layer 0 types.  This module
     provides groupings that can be applicable to Layer 0
     Fixed Optical Networks (e.g., CWDM (Coarse Wavelength
     Division Multiplexing) and DWDM (Dense Wavelength Division
     Multiplexing)) and flexi-grid optical networks.

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

     Redistribution and use in source and binary forms, with
     or without modification, is permitted pursuant to, and
     subject to the license terms contained in, the 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-07-11 {
    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 6;
    }
    units THz;
    description
      "The DWDM frequency in THz, e.g., 193.112500";
  }
  typedef frequency-ghz {
    type decimal64 {
      fraction-digits 3;
    }
    units GHz;
    description
      "The DWDM frequency in GHz, e.g., 193112.500";
  }    

  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 int32;
      config false;
      description "Maximum Differential group delay of this mode
                  for this lane";
    }
    list max-polarization-dependent-loss-penalty {
      config false;
      description
        "Optional penalty associated with the maximum acceptable 
        accumulated polarization dependent loss.
         This list of pair pdl and penalty can be used to
         sample the function pdl = f(penalty).";
      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";
    }
  } // 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>IANA has assigned new URIs from the "IETF XML Registry" <xref target="RFC3688"/> as
   follows:</t>

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

<t>This document registers the following YANG module in the "YANG Module
   Names" registry <xref target="RFC7950"/>.</t>

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

<t>[Editors' Note] Check the IANA considerations in other bis documents</t>

</section>


  </middle>

  <back>


    <references title='Normative References'>

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




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



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



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



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



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



<reference anchor='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'>
	 <organization>Cisco</organization>
      </author>
      <author fullname='Ruediger Kunze'>
	 <organization>Deutsche Telekom</organization>
      </author>
      <author fullname='Andreas Burk'>
	 <organization>Deutsche Telekom</organization>
      </author>
      <author fullname='Dharini Hiremagalur'>
	 <organization>Juniper</organization>
      </author>
      <author fullname='Gert Grammel'>
	 <organization>Juniper</organization>
      </author>
      <date day='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="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="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>
    </section>

  </back>

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

-->

</rfc>

