<?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.7.24 (Ruby 3.2.3) -->


<!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-13" category="std" consensus="true" submissionType="IETF" obsoletes="9093" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title abbrev="L0 Common YANG Types">Common YANG Data Types for Layer 0 Networks</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="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>

    <date year="2025" month="March" day="17"/>

    
    <workgroup>CCAMP Working Group</workgroup>
    

    <abstract>


<?line 194?>

<t>This document defines a collection of common data types, identities, and groupings
in the YANG data modeling language. 
These common types and groupings, derived from the built-in YANG data types, identities,
and groupings are intended to be imported by modules that model Layer 0
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 by replacing the YANG module it contained with a new revision that includes additional YANG data types, identities and groupings.</t>



    </abstract>



  </front>

  <middle>


<?line 205?>

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

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

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

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

<t>This document obsoletes <xref target="RFC9093"/> by replacing it in its entirety. It
provides a new revision of the YANG module contained in that RFC,
and retains the data types previously defined, but also adds new type
definitions to the YANG module.
For further details, see <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.
<?line -6?></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 module.</t>

<texttable title="Prefixes and corresponding YANG module" anchor="tab-prefixes">
      <ttcol align='left'>Prefix</ttcol>
      <ttcol align='left'>YANG module</ttcol>
      <ttcol align='left'>Reference</ttcol>
      <c>te-types</c>
      <c>ietf-te-types</c>
      <c>[RFCYYYY]</c>
      <c>l0-types</c>
      <c>ietf-layer0-types</c>
      <c>RFC XXXX</c>
</texttable>

<ul empty="true"><li>
  <t>RFC Editor Note:
Please replace XXXX with the RFC number assigned to this document.
Please replace YYYY with the RFC number assigned to <xref target="I-D.ietf-teas-rfc8776-update"/>.
Please remove this note.</t>
</li></ul>

</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 YANG data types, identities and groupings:</t>

<dl>
  <dt>l0-grid-type:</dt>
  <dd>
    <t>A base YANG identity for the grid type as defined in <xref target="RFC6205"/> and <xref target="RFC7699"/>.</t>
  </dd>
  <dt>cwdm-ch-spc-type:</dt>
  <dd>
    <t>A base YANG identity for the Coarse Wavelength Division
Multiplexing (CWDM) channel-spacing type as defined in <xref target="RFC6205"/>.</t>
  </dd>
  <dt>dwdm-ch-spc-type:</dt>
  <dd>
    <t>A base YANG identity for the DWDM channel-spacing type as defined
in <xref target="RFC6205"/>.</t>
  </dd>
  <dt>flexi-ncfg-type:</dt>
  <dd>
    <t>A base YANG identity for the DWDM flexi-grid Nominal Central Frequency Granularity (NCFG) 
type as defined in <xref target="RFC7699"/>.</t>
  </dd>
</dl>

<ul empty="true"><li>
  <t>Note that the only value for NCFG standardized in <xref target="ITU-T_G.694.1"/> is 6.25GHz.</t>
</li></ul>

<dl>
  <dt>flexi-slot-width-granularity:</dt>
  <dd>
    <t>A base YANG identity for the DWDM flexi-grid Slot Width Granularity (SWG) type, as defined in <xref target="RFC7699"/>.</t>
  </dd>
  <dt/>
  <dd>
    <t>Note that the only value for SWG standardized in <xref target="ITU-T_G.694.1"/> is 12.5GHz.</t>
  </dd>
  <dt>fec-type:</dt>
  <dd>
    <t>A base YANG identity from which specific FEC (Forward Error Correction) type identities are derived.</t>
  </dd>
  <dt>line-coding:</dt>
  <dd>
    <t>A base YANG identity from which specific identities defining the bit rate/line coding of optical tributary signals are derived.</t>
  </dd>
  <dt>wavelength-assignment:</dt>
  <dd>
    <t>A base YANG identity from which for Wavelength selection method, as defined in <xref target="RFC7689"/>.</t>
  </dd>
  <dt>operational-mode:</dt>
  <dd>
    <t>A YANG data type used to identify an organization (e.g., vendor) specific mode for transceiver capability description, as defined in Section 2.5.2 of <xref target="I-D.ietf-ccamp-optical-impairment-topology-yang"/></t>
  </dd>
  <dt>wson-label-start-end:</dt>
  <dd>
    <t>The WSON label range was defined in <xref target="RFC6205"/>, and the generic
topology model defines the label-start/label-end in <xref target="RFC8795"/>.
This grouping shows the WSON-specific label-start and label-end
information. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt>wson-label-hop:</dt>
  <dd>
    <t>The WSON label range was defined in <xref target="RFC6205"/>, and the generic
topology model defines the label-hop in <xref target="RFC8795"/>.  This grouping
shows the WSON-specific label-hop information. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt>l0-label-range-info:</dt>
  <dd>
    <t>A YANG grouping that defines the Layer 0 label range information
applicable for WSON as defined in <xref target="RFC6205"/>. The label range info is defined per priority <xref target="RFC4203"/>.</t>
  </dd>
  <dt/>
  <dd>
    <t>This grouping is used in the flexi-grid DWDM by adding more flexi-grid-specific
parameters. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt>wson-label-step:</dt>
  <dd>
    <t>A YANG grouping that defines label steps for WSON as defined in
<xref target="I-D.ietf-teas-rfc8776-update"/>. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt>flexi-grid-label-start-end:</dt>
  <dd>
    <t>The flexi-grid label range was defined in <xref target="RFC7699"/>, and the
generic topology model defines the label-start/label-end in
<xref target="RFC8795"/>.</t>
  </dd>
  <dt/>
  <dd>
    <t>This grouping shows the flexi-grid-specific label-
start and label-end information which is used to describe the range of available nominal central frequencies. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt/>
  <dd>
    <t>As described in section 3.1 of <xref target="RFC8363"/>, the range of available nominal central frequencies are advertised for m=1, which means that for an available central frequency n, the frequency slot from central frequency n-1 to central frequency n+1 is available.</t>
  </dd>
  <dt>flexi-grid-label-hop:</dt>
  <dd>
    <t>The flexi-grid label range was defined in <xref target="RFC8363"/>, and the
generic topology model defines the label-hop in <xref target="RFC8795"/>.</t>
  </dd>
  <dt/>
  <dd>
    <t>This grouping shows the WSON-specific label-hop information. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt>flexi-grid-label-range-info:</dt>
  <dd>
    <t>A YANG grouping that defines flexi-grid label range information as
defined in <xref target="RFC8363"/>. See <xref target="label-range"/> for more details. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt>flexi-grid-label-step:</dt>
  <dd>
    <t>A YANG grouping that defines flexi-grid label steps as defined in
<xref target="I-D.ietf-teas-rfc8776-update"/>. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt>wdm-label-start-end:</dt>
  <dd>
    <t>A YANG grouping that combines the definition of label-start/label-end information
that was defined separately in wson-label-start-end and flexi-grid-label-start-end,
to support optical network scenarios that contain both fixed- and flexi-grid
links. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt>wdm-label-hop:</dt>
  <dd>
    <t>A YANG grouping that combines the definition of label hop information
that was defined separately in wson-label-hop and flexi-grid-label-hop,
to support optical network scenarios that contain both fixed- and flexi-grid
links. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt>wdm-label-range-info:</dt>
  <dd>
    <t>A YANG grouping that combines the definition of label range information
that was defined separately in wson-label-range-info and flexi-grid-label-range-info,
to support optical network scenarios that contain both fixed- and flexi-grid
links. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt>wdm-label-step:</dt>
  <dd>
    <t>A YANG grouping that combines the definition of label step information
defined separately in wson-label-step and flexi-grid-label-step,
to support optical network scenarios that contain both fixed- and flexi-grid
links. See <xref target="label-range"/> for more details.</t>
  </dd>
  <dt>transceiver-capabilities:</dt>
  <dd>
    <t>A YANG grouping to define the transceiver capabilities (also called
"modes") needed to determine optical signal compatibility.</t>
  </dd>
  <dt>standard-mode:</dt>
  <dd>
    <t>A YANG grouping for the standard modes defined in <xref target="ITU-T_G.698.2"/>.</t>
  </dd>
  <dt>organizational-mode:</dt>
  <dd>
    <t>A YANG grouping to define transponder operational mode supported by
organizations or vendors, as defined in <xref target="I-D.ietf-ccamp-optical-impairment-topology-yang"/>.</t>
  </dd>
  <dt>explicit-mode:</dt>
  <dd>
    <t>A YANG grouping to define the list of attributes related to optical
impairments limits in case of transceiver explicit mode, as defined in <xref target="I-D.ietf-ccamp-optical-impairment-topology-yang"/>.</t>
  </dd>
  <dt/>
  <dd>
    <t>Note that the the actual portion of the spectrum occupied by an OTSi is not explicitly reported within the explicit-mode parameters because it can be calculated using the available-baud-rate, the roll-off and the min-carrier-spacing attributes.</t>
  </dd>
  <dt>transceiver-tuning-range:</dt>
  <dd>
    <t>A YANG grouping that defines the transceiver tuning range, which
includes the minimum and maximum tuning frequency, as well as the
frequency tuning granularity.</t>
  </dd>
  <dt>common-organizational-explicit-mode:</dt>
  <dd>
    <t>A YANG grouping to define the common capabilities attributes limit
range in case of operational mode and explicit mode.</t>
  </dd>
  <dt>modulation:</dt>
  <dd>
    <t>A base YANG identity to define the different modulation types, as defined in <xref target="ITU-T_G.Sup39"/></t>
  </dd>
  <dt>snr:</dt>
  <dd>
    <t>A YANG data type used to represent an (Optical) Signal to Noise Ratio measured over 0.1 nm resolution bandwidth, as defined in <xref target="ITU-T_G.977.1"/></t>
  </dd>
  <dt>psd:</dt>
  <dd>
    <t>A YANG data type used to represent a Power Spectral Density (PSD), as defined in <xref target="ITU-T_G.9700"/></t>
  </dd>
  <dt>penalty-value:</dt>
  <dd>
    <t>A YANG grouping to define the penalty value for multiple penalty types, such as Chromatic Dispersion (CD), Polarization Mode Dispersion (PMD), as defined in <xref target="ITU-T_G.666"/> or Polarization Dependent Loss(PDL)</t>
  </dd>
  <dt>switching-wson-lsc:</dt>
  <dd>
    <t>A YANG identity for the Wavelength Switched Optical Network Lambda-Switch Capable (WSON-LSC) interface switching capability as defined in <xref target="RFC7688"/>.</t>
  </dd>
  <dt>switching-flexi-grid-lsc:</dt>
  <dd>
    <t>A YANG identity for the Flexi-Grid Lambda-Switch Capable (Flexi-Grid-LSC) interface switching capability as defined in <xref target="RFC8363"/>.</t>
  </dd>
</dl>

<t>It is worth noting that there is an inheritance relationship between the Lambda-Switch Capable (LSC) switching capability, defined in <xref target="RFC3471"/>, and the WSON-LSC and Flexi-Grid-LSC, defined respectively in <xref target="RFC7688"/> and <xref target="RFC8363"/>. As a consequence, the 'switching-wson-lsc' and 'switching-flexi-grid-lsc' YANG identities are defined as derived identities from the 'switching-lsc', defined in <xref target="I-D.ietf-teas-rfc8776-update"/>.</t>

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

<t>As described in <xref target="RFC6205"/> and <xref target="RFC7699"/>, the WDM label represents the frequency slot assigned to a WDM Label Switched Path (LSP) on a given WDM Link, which models an Optical Multiplex Section (OMS) Media Channel Group (MCG) as described in <xref target="I-D.ietf-ccamp-optical-impairment-topology-yang"/>.</t>

<t>The same WDM label shall be assigned to the same WDM LSP on all the WDM Links on a regen-free LSP path or path segment.</t>

<t>A frequency slot is defined in <xref target="ITU-T_G.694.1"/> as a contiguous frequency range characterized by its nominal central frequency and slot width. The frequency range allocated to a frequency slot is unavailable to other frequency slots.</t>

<t>The definition of the frequency slot depends on the WDM grid type:</t>

<t><list style="symbols">
  <t>In case of CWDM fixed-grid, defined in <xref target="ITU-T_G.694.2"/>, the frequency slot is defined by a fixed CWDM channel spacing (cwdm-ch-spc-type) and by the nominal central wavelength which is computed as described in <xref target="RFC6205"/>. The formula in <xref target="RFC6205"/> is copied here for reader convenience:</t>
</list></t>

<figure><artwork><![CDATA[
      lambda = 1471 nm + n * channel spacing (measured in nm)
]]></artwork></figure>

<ul empty="true"><li>
  <t>where 'n' is defined in <xref target="RFC6205"/> as integer (positive, negative, or 0)</t>
</li></ul>

<t><list style="symbols">
  <t>In case of DWDM fixed-grid, defined in <xref target="ITU-T_G.694.1"/>, the frequency slot is defined by a fixed DWDM channel spacing (dwdm-ch-spc-type) and by the nominal central frequency, which is computed as described in <xref target="RFC6205"/>. The formula in <xref target="RFC6205"/> is copied here for reader convenience:</t>
</list></t>

<figure><artwork><![CDATA[
      f = 193100.000 GHz + n * channel spacing (measured in GHz)
]]></artwork></figure>

<ul empty="true"><li>
  <t>where 'n' is defined in <xref target="RFC6205"/> as integer (positive, negative, or 0)</t>
</li></ul>

<t><list style="symbols">
  <t>In case of DWDM flexible-grid, defined in <xref target="ITU-T_G.694.1"/>, the frequency slot is defined by the slot width and by the nominal central frequency, which are computed, based on the slot width granularity (SWG, fixed at 12.5GHz in <xref target="ITU-T_G.694.1"/>), and of the nominal central frequency granularity (NCFG, fixed at 6.25GHz in <xref target="ITU-T_G.694.1"/>) respectively, as described in <xref target="RFC7698"/> and <xref target="RFC7699"/>. The formulas in <xref target="RFC7699"/> can be generalized as follows:</t>
</list></t>

<figure><artwork><![CDATA[
      SW = m * SWG (measured in GHz)
      f = 193100.000 GHz + N * NCFG (measured in GHz)
]]></artwork></figure>

<ul empty="true"><li>
  <t>where 'n' is defined in <xref target="RFC7699"/> as integer (positive, negative, or 0) and 'm' is defined in <xref target="RFC7698"/> as an integer greater than or equal to 1.</t>
</li></ul>

<t>The definition of the channel spacing, NCFG and SWG in the YANG model have been generalized to support modelling of vendor-specific values (e.g., finer vendor-specific granularity for NCFG and SWG).</t>

<t>The WDM Label Range represents the frequency slots that are available for WDM LSPs to be set up over a given WDM Link.</t>

<t>The WDM Label Range is defined by augmenting the label-restriction list, defined in <xref target="I-D.ietf-teas-rfc8776-update"/>, with WDM technology-specific attributes, using the l0-label-range-info grouping (for WSON only models) or the flexi-grid-label-range-info grouping (for DWDM flexible-grid only models) or the wdm-label-range-info grouping (for models that supports both WSON and DWDM flexible-grid).</t>

<t>Each entry in the label-restriction list represents either the range of the available central wavelength values (in case of CWDM fixed-grid) or the range of the available nominal central frequencies values (in case of DWDM fixed or flexible grids): the grid-type attribute defines the type of grid for each entry of the list.</t>

<t>In case of DWDM flexible grid, each entry in the label-restriction
list represents also the range of the supported slot width values
based on the following attributes, defined based on concepts used in <xref target="RFC7699"/>:</t>

<t><list style="symbols">
  <t>slot-width-granularity, which represents the minimum space between slot widths;</t>
  <t>min-slot-width-factor: a multiplier of the slot width granularity, indicating the minimum slot width supported by each entry in the label-restriction list;</t>
  <t>max-slot-width-factor: a multiplier of the slot width granularity, indicating the maximum slot width supported by each entry in the label-restriction list.</t>
</list></t>

<t>Each entry of the label-restriction list, as defined in <xref target="I-D.ietf-teas-rfc8776-update"/>, defines a label-start, a label-end, a label-step and a range-bitmap.</t>

<t>The label-start and label-end definitions, when used for representing WDM labe range, are augmented with WDM technology-specific attributes, using the wson-label-start-end grouping (for WSON only models) or the flexi-grid-label-start-end grouping (for DWDM flexible-grid only models) or the wdm-label-start-end grouping (for models that supports both WSON and DWDM flexible-grid).</t>

<t>The label-step definition, when used for representing WDM labe range, are augmented with WDM technology-specific attributes, using the wson-label-step grouping (for WSON only models) or the flexi-grid-label-step grouping (for DWDM flexible-grid only models) or the wdm-label-step grouping (for models that supports both WSON and DWDM flexible-grid). The label-step definition for WDM depends on the WDM grid type:</t>

<t><list style="symbols">
  <t>For CWDM and DWDM fixed grids, it describes the channel spacing, as defined in <xref target="RFC6205"/>;</t>
  <t>For DWDM flexible grids, it describes the nominal central frequency granularity (e.g., 6,25 GHz) as well as the multiplier for the supported values of n, as defined in <xref target="RFC7699"/>.</t>
</list></t>

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

<t>This YANG module references <xref target="RFC6205"/>, <xref target="RFC7689"/>, <xref target="RFC7699"/>, <xref target="RFC7698"/>, <xref target="RFC8363"/>, <xref target="RFC8363"/>, <xref target="RFC9093"/>, <xref target="ITU-T_G.666"/>, <xref target="ITU-T_G.694.1"/>, <xref target="ITU-T_G.694.2"/>, <xref target="ITU-T_G.698.2"/>, <xref target="ITU-T_G.709"/>, <xref target="ITU-T_G.709.2"/>, <xref target="ITU-T_G.709.3"/>, <xref target="ITU-T_G.959.1"/> <xref target="ITU-T_G.975"/>, <xref target="ITU-T_G.975.1"/>, <xref target="ITU-T_G.977.1"/>, <xref target="ITU-T_G.9700"/> and <xref target="OIF_400ZR"/>.</t>

<figure title="Layer 0 Types YANG module" anchor="fig-yang-code"><sourcecode type="yang" markers="true" name="ietf-layer0-types@2025-02-25.yang"><![CDATA[
module ietf-layer0-types {
  yang-version 1.1;
  namespace "urn:ietf:params:xml:ns:yang:ietf-layer0-types";
  prefix l0-types;

  import ietf-te-types {
    prefix te-types;
    reference
      "RFC YYYY: Common YANG Data Types for Traffic Engineering";
  }
  // RFC Editor: replace YYYY with actual RFC number assigned to 
  // [I-D.ietf-teas-rfc8776-update] and remove this note

  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) 2025 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 2025-02-25 {
    description
      "To be updated";
    reference
      "RFC XXXX: A YANG Data Model for Layer 0 Types";
  }

  revision 2021-08-13 {
    description
      "Initial version";
    reference
      "RFC 9093: A YANG Data Model for Layer 0 Types";
  }

/*
 * Identities
 */

  identity l0-grid-type {
    description
      "Layer 0 grid type";
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable 
      (LSC), Label Switching Routers,

       ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
       CWDM wavelength grid";
  }

    identity wson-grid-cwdm {
      base l0-grid-type;
      description
        "CWDM grid";
      reference
        "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
        Label Switching Routers,

        ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
        CWDM wavelength grid";
    }

    identity wson-grid-dwdm {
      base l0-grid-type;
      description
        "DWDM grid";
      reference
        "RFC 6205: Generalized Labels for Lambda-Switch-Capable 
        (LSC), Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

    identity flexi-grid-dwdm {
      base l0-grid-type;
      description
        "Flexi-grid";
      reference
        "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
        Switch Capable (LSC) Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

  identity cwdm-ch-spc-type {
    description
      "CWDM channel-spacing type";
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers,
       
       ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
       CWDM wavelength grid";
  }

    identity cwdm-20nm {
      base cwdm-ch-spc-type;
      description
        "20nm channel spacing";
      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";
      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-50ghz {
      base dwdm-ch-spc-type;
      description
        "50 GHz channel spacing";
      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-25ghz {
      base dwdm-ch-spc-type;
      description
        "25 GHz channel spacing";
      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-12p5ghz {
      base dwdm-ch-spc-type;
      description
        "12.5 GHz channel spacing";
      reference
        "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
        Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

  identity flexi-ch-spc-type {
    status deprecated;
    description
      "Flexi-grid channel-spacing type";
  }

    identity flexi-ch-spc-6p25ghz {
      base flexi-ch-spc-type;
      status deprecated;
      description
        "6.25 GHz channel spacing";
    }

  identity flexi-ncfg-type {
    description
      "Flexi-grid Nominal Central Frequency Granularity (NCFG) 
      type";
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers,

      ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
      DWDM frequency grid";
  }

    identity flexi-ncfg-6p25ghz {
      base flexi-ncfg-type;
      description
        "6.25 GHz Nominal Central Frequency Granularity (NCFG)";
      reference
        "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
        Switch Capable (LSC) Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

  identity flexi-slot-width-granularity {
    description
      "Flexi-grid slot width granularity";
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers,

      ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
      DWDM frequency grid";
  }

    identity flexi-swg-12p5ghz {
      base flexi-slot-width-granularity;
      description
        "12.5 GHz slot width granularity";
      reference
        "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
        Switch Capable (LSC) Label Switching Routers,

        ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
        DWDM frequency grid";
    }

  identity modulation {
    description "base identity for modulation type";
  }

    identity DPSK {
      base modulation;
      description
        "DPSK (Differential Phase Shift Keying) modulation";
    }

    identity QPSK {
      base modulation;
      description
        "QPSK (Quadrature Phase Shift Keying) modulation";
    }

    identity DP-QPSK {
      base modulation;
      description
        "DP-QPSK (Dual Polarization Quadrature
        Phase Shift Keying) modulation";
    }

    identity QAM8 {
      base modulation;
      description
        "8QAM (8 symbols Quadrature Amplitude Modulation)";
    }

    identity DP-QAM8 {
      base modulation;
      description
        "DP-QAM8 (8 symbols Dual Polarization Quadrature Amplitude
        Modulation)";
    }

    identity QAM16 {
      base modulation;
      description
        "QAM16 (16 symbols Quadrature Amplitude Modulation)";
    }

    identity DP-QAM16 {
      base modulation;
      description
        "DP-QAM16 (16 symbols Dual Polarization Quadrature Amplitude 
        Modulation)";
    }

    identity QAM32 {
      base modulation;
      description
        "QAM32 (32 symbols Quadrature Amplitude Modulation)";
    }

    identity DP-QAM32 {
      base modulation;
      description
        "DP-QAM32 (32 symbols Dual Polarization Quadrature Amplitude
        Modulation)";
    }

    identity QAM64 {
      base modulation;
      description
        "QAM64 (64 symbols Quadrature Amplitude Modulation)";
    }

    identity DP-QAM64 {
      base modulation;
      description
        "DP-QAM64 (64 symbols Dual Polarization Quadrature Amplitude
        Modulation)";
    }

  identity fec-type {
    description
      "Base identity from which specific FEC
      (Forward Error Correction) type identities are derived.";
  }

    identity g-fec {
      base fec-type;
      description
        "Generic Forward Error Correction (G-FEC).";
      reference
        "ITU-T G.975 v2.0 (10/2000): Forward error correction for 
        submarine systems.";
    }

    identity super-fec {
      base fec-type;
      description
        "Super Forward Error Correction (S-FEC).";
      reference
        "ITU-T G.975.1 v1.2 (07/2013): Forward error correction for 
        high bit-rate DWDM submarine systems.";
    }

    identity no-fec {
      base fec-type;
      description
        "No FEC";
    }

    identity sc-fec {
      base fec-type;
      description
        "Staircase Forward Error Correction (SC-FEC).";
      reference
        "Annex A of ITU-T G.709.2 v1.1 (09/2020):OTU4 long-reach 
        interface.";
    }

    identity o-fec {
      base fec-type;
      description
        "Open Forward Error Correction (O-FEC) which reuses the 
        Bose, Chaudhuri and Hocquenghem (BCH) FEC.";
      reference
        "Clause 16.4.4 of ITU-T G.709.3 v2.1 (11/2022): Flexible OTN 
        long-reach interfaces;

        Annex E of ITU-T G.709.3 v2.1 (11/2022): Flexible OTN 
        long-reach interfaces.";
    }

    identity c-fec {
      base fec-type;
      description
        "Concatenated FEC (C-FEC) that combines an outer Staircase 
        Forward Error Correction (SC-FEC) code and an inner 
        double-extended SD-FEC (128,119) Hamming code.
        
        More details are provided in clause 15/G.709.3 where it is 
        called DSH instead of concatenated FEC.";
      reference
        "Annex A of ITU-T G.709.2 v1.1 (09/2020):OTU4 long-reach 
        interface;
        
        Annex D of ITU-T G.709.3 v2.1 (11/2022): Flexible OTN 
        long-reach interfaces;
        
        Clause 15 of ITU-T G.709.3 v2.1 (11/2022): Flexible OTN 
        long-reach interfaces.";
    }

  identity line-coding {
    description
      "Base identity to defined the bit rate/line coding of optical 
      tributary signals.";
    reference 
      "Section 7.1.2 of ITU-T G.698.2 v3.0 (11/2018).";
  }  

    identity line-coding-NRZ-2p5G {
      base line-coding;
      description
        "The non return to zero (NRZ) bit rate/line coding used by 
        the optical tributary signal class NRZ 2.5G";
      reference 
        "Section 3.2.6 of ITU-T G.959.1 v8.0 (07/2018).";
    }

    identity line-coding-NRZ-OTU1 {
      base line-coding;
      description
        "The non return to zero (NRZ) bit rate/line coding used by 
        the Optical channel Transport Unit order 1 (OTU1) optical 
        tributary signals";
      reference 
        "Section 7.2.1.2 of ITU-T G.959.1 v8.0 (07/2018).";
    }

    identity line-coding-NRZ-10G {
      description
        "The non return to zero (NRZ) bit rate/line coding used by 
        the optical tributary signal class NRZ 10G";
      reference 
        "Section 3.2.7 of ITU-T G.959.1 v8.0 (07/2018).";
    }

    identity line-coding-NRZ-OTU2 {
      base line-coding;
      description
        "The non return to zero (NRZ) bit rate/line coding used by 
        the Optical channel Transport Unit order 2 (OTU2) optical 
        tributary signals";
      reference 
        "Section 7.2.1.2 of ITU-T G.959.1 v8.0 (07/2018).";
    }

    identity line-coding-OTL4.4-SC {
      base line-coding;
      description
        "The bit rate/line coding used by optical tributary 
        signals carrying a 100G Optical Transport Unit order 4 
        (OTU4) with Staircase Forward Error Correction (SC FEC) 
        from a group of four Optical Transport Lanes (OTL).";
      reference 
        "Section 3.2.1 of ITU-T G.698.2 v3.0 (11/2018).";
    }

    identity line-coding-FOIC1.4-SC {
      base line-coding;
      description
        "The bit rate/line coding used by optical tributary signals 
        carrying a FlexO Interface of order C1 with 4 lanes 
        (FOIC1.1) with Staircase Forward Error Correction 
        (SC FEC).";
      reference 
        "Section 3.2.1 of ITU-T G.698.2 v3.0 (11/2018).";
    }

  identity wavelength-assignment {
    description
      "Wavelength selection base";
    reference
      "RFC 7689: Signaling Extensions for Wavelength Switched 
      Optical Networks";
  }

    identity first-fit-wavelength-assignment {
      base wavelength-assignment;
      description
        "All the available wavelengths are numbered,
        and this WA (Wavelength Assignment) method chooses
        the available wavelength with the lowest index";
      reference
        "RFC 7689: Signaling Extensions for Wavelength Switched 
        Optical Networks";
    }

    identity random-wavelength-assignment {
      base wavelength-assignment;
      description
        "This WA method chooses an available
        wavelength randomly";
      reference
        "RFC 7689: Signaling Extensions for Wavelength Switched 
        Optical Networks";
    }

    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)";
      reference
        "RFC 7689: Signaling Extensions for Wavelength Switched 
        Optical Networks";
    }

    identity lower-first-wavelength-assignment {
      base wavelength-assignment;
      description
        "Allocate wavelengths in ascending order, beginning from the
        lowest frequency and progressing toward the highest frequency
        within the permissible frequency range.";
    }

    identity upper-first-wavelength-assignment {
      base wavelength-assignment;
      description
        "Allocate wavelengths in decending order, beginning from the
        highest frequency and progressing toward the lowest frequency
        within the permissible frequency range.";
    }

  identity type-power-mode {
    description
      "power equalization mode used within the 
       OMS and its elements";
  }

    identity power-spectral-density {
      base type-power-mode;
      description
        "all elements must use power spectral density (W/Hz)";
    }

    identity carrier-power {
      base type-power-mode;
      description
        "all elements must use power (dBm)";
    }

  identity switching-wson-lsc {
    base te-types:switching-lsc;
    description
      "Wavelength Switched Optical Network Lambda-Switch Capable
      (WSON-LSC).";
    reference
      "Section 3 of RFC 7688: GMPLS OSPF Enhancement for Signal and
      Network Element Compatibility for Wavelength Switched Optical
      Networks";
  }

  identity switching-flexi-grid-lsc {
    base te-types:switching-lsc;
    description
      "Flexi-grid Lambda-Switch Capable (Flexi-Grid-LSC).";
    reference
      "Section 4.1 of RFC 8363: GMPLS OSPF-TE Extensions in Support
      of Flexi-Grid Dense Wavelength Division Multiplexing (DWDM)
      Networks";
  }

/*
 * Typedefs
 */

  typedef dwdm-n {
    type int16;
    description
      "The given value 'N' is used to determine the nominal central
       frequency.

       The nominal central frequency, 'f', is defined by:
         f = 193100.000 GHz + N x channel spacing (measured in GHz),

       where 193100.000 GHz (193.100000 THz) is the ITU-T 'anchor
       frequency' for transmission over the DWDM grid, and where
       'channel spacing' is defined by the dwdm-ch-spc-type.";
    reference
      "RFC6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers,

       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency grid";
  }

  typedef cwdm-n {
    type int16;
    description
      "The given value 'N' is used to determine the nominal central
       wavelength.

       The nominal central wavelength is defined by:
         Wavelength = 1471 nm + N x channel spacing (measured in nm)

       where 1471 nm is the conventional 'anchor wavelength' for
       transmission over the CWDM grid, and where 'channel spacing'
       is defined by the cwdm-ch-spc-type.";
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers,

       ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
       CWDM wavelength grid";
  }

  typedef flexi-n {
    type int16;
    description
      "The given value 'N' is used to determine the nominal central
       frequency.

       The nominal central frequency, 'f', is defined by:
         f = 193100.000 GHz + N x NCFG (measured in GHz),

       where 193100.000 GHz (193.100000 THz) is the ITU-T 'anchor
       frequency' for transmission over the DWDM grid, and where
       NCFG is defined by the flexi-ncfg-type, or by the deprecated 
       flexi-ch-spc-type.";
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers,

       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency grid";
  }

  typedef flexi-m {
    type uint16;
    description
      "The given value 'M' is used to determine the slot width.

       A slot width is defined by:
         slot width = M x SWG (measured in GHz),

       where SWG is defined by the flexi-slot-width-granularity.";
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers,

       ITU-T G.694.1 (10/2020): Spectral grids for WDM applications:
       DWDM frequency grid";
  }

  typedef standard-mode {
    type string;
    description
      "Identifies an ITU-T G.698.2 standard application code.

      It MUST be a string with a format that follows the 
      nomenclature defined in section 5.3 of ITU-T G.698.2.";
    reference
      "ITU-T G.698.2 (11/2018)";
  }

  typedef organization-identifier {
    type string;
    description
      "vendor/organization identifier that uses a private mode
      out of already defined in G.698.2 ITU-T application-code";
    reference
      "Section 2.5.2 of RFC YYYY: A YANG Data Model for Optical
      Impairment-aware Topology.";
  }
// RFC Ed.: replace YYYY with actual RFC number and remove
// this note after draft-ietf-ccamp-optical-impairment-topology-yang
// is published as an RFC

  typedef operational-mode {
    type string;
    description
      "Identifies an organization (e.g., vendor) specific mode.
      
      The format of the string has to be defined by the 
      organization which is responsible for defining the 
      corresponding optical interface specification.";
    reference
      "Section 2.5.2 of RFC YYYY: A YANG Data Model for Optical
      Impairment-aware Topology.";
  }
// RFC Ed.: replace YYYY with actual RFC number and remove
// this note after draft-ietf-ccamp-optical-impairment-topology-yang
// is published as an RFC

  typedef frequency-thz {
    type decimal64 {
      fraction-digits 9;
    }
    units "THz";
    description
      "The DWDM frequency in THz, e.g., 193.112500000";
  }

  typedef frequency-ghz {
    type decimal64 {
      fraction-digits 6;
    }
    units "GHz";
    description
      "The DWDM frequency in GHz, e.g., 193112.500000";
  }    

  typedef snr {
    type decimal-2;
    units "dB@0.1nm";
    description
      "(Optical) Signal to Noise Ratio measured over 0.1 nm
      resolution bandwidth";
    reference
      "ITU-T G.977.1 (02/2021): Transverse compatible dense
      wavelength division multiplexing applications for repeatered
      optical fibre submarine cable systems";
  }

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

  typedef decimal-2-or-null {
    type union {
      type decimal-2;
      type empty;
    }
    description
      "A decimal64 value with two digits, when the value is known or
      an empty value when the value is not known.";
  }

  typedef power-gain {
    type decimal-2 {
      range "0..max";
    }
    units "dB";
    description
      "The gain in dB.";
  }

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

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

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

  typedef power-ratio {
    type decimal-2;
    units "dB";
    description
      "The power difference in dB.";
  }

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

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

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

  typedef decimal-5 {
    type decimal64 {
      fraction-digits 5;
    }
    description
      "A decimal64 value with five digits.";
  }

  typedef decimal-5-or-null {
    type union {
      type decimal-5;
      type empty;
    }
    description
      "A decimal64 value with five digits, when the value is known 
      or an empty value when the value is not known.";
  }

  typedef psd {
    type decimal64 {
      fraction-digits 16;
    }
    units "W/Hz";
    description
      "The power spectral density (PSD).
      
      Typical value : 3.9 E-14, resolution 0.1nW/MHz.";
    reference
      "ITU-T G.9700 (07/2019): Fast access to subscriber terminals
      (G.fast) - Power spectral density specification";
  }

  typedef psd-or-null {
    type union {
      type psd;
      type empty;
    }
    description
      "The power spectral density (PSD), when it is known or an
      empty value when the PSD is not known.";
  }

  typedef decimal-18 {
    type decimal64 {
      fraction-digits 18;
    }
    description
      "A decimal64 value with eighteen digits.";
  }

  typedef decimal-18-or-null {
    type union {
      type decimal-18;
      type empty;
    }
    description
      "A decimal64 value with eighteen digits, when the value is
      known or an empty value when the value is not known.";
  }

/*
 * Groupings
 */

  grouping wdm-label-start-end {
    description
      "The WDM label-start or label-end used to specify DWDM and
       CWDM label range.";

    choice grid-type {
      description
        "Label for fixed & flexi-DWDM or CWDM grid";
      case fixed-dwdm {
        leaf dwdm-n {
          when "derived-from-or-self(../../../grid-type,
                \"wson-grid-dwdm\")" {
            description
              "Valid only when grid type is DWDM.";
          }
          type l0-types:dwdm-n;
          description
            "The given value 'N' is used to determine the
             nominal central frequency.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case cwdm {
        leaf cwdm-n {
          when "derived-from-or-self(../../../grid-type,
                \"wson-grid-cwdm\")" {
            description
              "Valid only when grid type is CWDM.";
          }
          type l0-types:cwdm-n;
          description
            "The given value 'N' is used to determine the nominal
             central wavelength.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case flexi-grid {
        uses l0-types:flexi-grid-label-start-end;
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers";
  }

  grouping wdm-label-step {
    description
      "Label step information for fixed & flexi-DWDM or CWDM grid";
    choice l0-grid-type {
      description
        "Grid type: DWDM, CWDM, etc.";
      case fixed-dwdm {
        leaf wson-dwdm-channel-spacing {
          when "derived-from-or-self(../../grid-type,
                \"wson-grid-dwdm\")" {
            description
              "Valid only when grid type is DWDM.";
          }
          type identityref {
            base dwdm-ch-spc-type;
          }
          description
            "Label-step is the channel spacing (GHz), e.g., 100.000,
             50.000, 25.000, or 12.500 GHz for DWDM.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case cwdm {
        leaf wson-cwdm-channel-spacing {
          when "derived-from-or-self(../../grid-type,
                \"wson-grid-cwdm\")" {
            description
              "Valid only when grid type is CWDM.";
          }
          type identityref {
            base cwdm-ch-spc-type;
          }
          description
            "Label-step is the channel spacing (nm), i.e., 20 nm
             for CWDM, which is the only value defined for CWDM.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case flexi-grid {
        uses flexi-grid-label-step;
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers,
       ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
       CWDM wavelength grid,
       RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-Grid
       Dense Wavelength Division Multiplexing (DWDM) Networks";
  }

  grouping wdm-label-hop {
    description
      "Generic label-hop information for fixed & flexi-DWDM or
       CWDM grid";
    choice grid-type {
      description
        "Label for DWDM or CWDM grid";
      case fixed-dwdm {
        choice fixed-single-or-super-channel {
          description
            "single or super channel";
          case single {
            leaf dwdm-n {
              type l0-types:dwdm-n;
              description
                "The given value 'N' is used to determine the
                 nominal central frequency.";
            }
          }
          case multi {
            leaf-list subcarrier-dwdm-n {
              type l0-types:dwdm-n;
              min-elements 2;
              description
                "The given values 'N' are used to determine the
                 nominal central frequency for each subcarrier
                 channel.";
              reference
                "ITU-T G.694.1 (10/2020): Spectral grids for WDM
                applications: DWDM frequency grid";
            }
          }
        }
      }
      case cwdm {
        leaf cwdm-n {
          type l0-types:cwdm-n;
          description
            "The given value 'N' is used to determine the nominal
             central wavelength.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case flexi-grid {
        uses l0-types:flexi-grid-label-hop;
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers";
  }

  grouping wdm-label-range-info {
    description
      "WDM label range related information";
    uses l0-label-range-info;
    container flexi-grid {
      when "derived-from-or-self(../grid-type,
          \"flexi-grid-dwdm\")" {
        description
          "Applicable only when the grid type is flexi-grid-dwdm.";
      }
      description
        "flexi-grid definition";
      leaf slot-width-granularity {
        type identityref {
          base flexi-slot-width-granularity;
        }
        default "flexi-swg-12p5ghz";
        description
          "Minimum space between slot widths. Default is 12.500
           GHz.";
        reference
          "RFC 7698: Framework and Requirements for GMPLS-Based
           Control of Flexi-Grid Dense Wavelength Division
           Multiplexing (DWDM) Networks";
      }
      leaf min-slot-width-factor {
        type uint16 {
          range "1..max";
        }
        default "1";
        description
          "A multiplier of the slot width granularity, indicating
           the minimum slot width supported by an optical port.

           Minimum slot width is calculated by:
             Minimum slot width (GHz) =
               min-slot-width-factor * slot-width-granularity.";
        reference
          "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-
           Grid Dense Wavelength Division Multiplexing (DWDM)
           Networks";
      }
      leaf max-slot-width-factor {
        type uint16 {
          range "1..max";
        }
        must '. >= ../min-slot-width-factor' {
          error-message
            "Maximum slot width must be greater than or equal to
             minimum slot width.";
        }
        description
          "A multiplier of the slot width granularity, indicating
           the maximum slot width supported by an optical port.

           Maximum slot width is calculated by:
             Maximum slot width (GHz) =
               max-slot-width-factor * slot-width-granularity

           If specified, maximum slot width must be greater than or
           equal to minimum slot width.  If not specified, maximum
           slot width is equal to minimum slot width.";
        reference
          "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-
           Grid Dense Wavelength Division Multiplexing (DWDM)
           Networks";
      }
    }
  }

  grouping wson-label-start-end {
    description
      "The WSON label-start or label-end used to specify WSON label
       range.";
    choice grid-type {
      description
        "Label for DWDM or CWDM grid";
      case dwdm {
        leaf dwdm-n {
          when "derived-from-or-self(../../../grid-type,
                \"wson-grid-dwdm\")" {
            description
              "Valid only when grid type is DWDM.";
          }
          type l0-types:dwdm-n;
          description
            "The central frequency of DWDM.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case cwdm {
        leaf cwdm-n {
          when "derived-from-or-self(../../../grid-type,
                \"wson-grid-cwdm\")" {
            description
              "Valid only when grid type is CWDM.";
          }
          type l0-types:cwdm-n;
          description
            "Channel wavelength computing input.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers";
  }

  grouping wson-label-hop {
    description
      "Generic label-hop information for WSON";
    choice grid-type {
      description
        "Label for DWDM or CWDM grid";
      case dwdm {
        choice single-or-super-channel {
          description
            "single or super channel";
          case single {
            leaf dwdm-n {
              type l0-types:dwdm-n;
              description
                "The given value 'N' is used to determine the
                 nominal central frequency.";
            }
          }
          case super {
            leaf-list subcarrier-dwdm-n {
              type l0-types:dwdm-n;
              description
                "The given values 'N' are used to determine the
                 nominal central frequency for each subcarrier
                 channel.";
              reference
                "ITU-T G.694.1 (10/2020): Spectral grids for WDM
                applications: DWDM frequency grid";
            }
          }
        }
      }
      case cwdm {
        leaf cwdm-n {
          type l0-types:cwdm-n;
          description
            "The given value 'N' is used to determine the nominal
             central wavelength.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers";
  }

  grouping l0-label-range-info {
    description
      "Information about Layer 0 label range.";
    leaf grid-type {
      type identityref {
        base l0-grid-type;
      }
      description
        "Grid type";
    }
    leaf priority {
      type uint8;
      description
        "Priority in Interface Switching Capability Descriptor
         (ISCD).";
      reference
        "RFC 4203: OSPF Extensions in Support of Generalized
         Multi-Protocol Label Switching (GMPLS)";
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers";
  }

  grouping wson-label-step {
    description
      "Label step information for WSON";
    choice l0-grid-type {
      description
        "Grid type: DWDM, CWDM, etc.";
      case dwdm {
        leaf wson-dwdm-channel-spacing {
          when "derived-from-or-self(../../grid-type,
                \"wson-grid-dwdm\")" {
            description
              "Valid only when grid type is DWDM.";
          }
          type identityref {
            base dwdm-ch-spc-type;
          }
          description
            "Label-step is the channel spacing (GHz), e.g., 100.000,
             50.000, 25.000, or 12.500 GHz for DWDM.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
      case cwdm {
        leaf wson-cwdm-channel-spacing {
          when "derived-from-or-self(../../grid-type,
                \"wson-grid-cwdm\")" {
            description
              "Valid only when grid type is CWDM.";
          }
          type identityref {
            base cwdm-ch-spc-type;
          }
          description
            "Label-step is the channel spacing (nm), i.e., 20 nm
             for CWDM, which is the only value defined for CWDM.";
          reference
            "RFC 6205: Generalized Labels for Lambda-Switch-Capable
             (LSC) Label Switching Routers";
        }
      }
    }
    reference
      "RFC 6205: Generalized Labels for Lambda-Switch-Capable (LSC)
       Label Switching Routers,

       ITU-T G.694.2 (12/2003): Spectral grids for WDM applications:
       CWDM wavelength grid";
  }

  grouping flexi-grid-label-start-end {
    description
      "The flexi-grid label-start or label-end used to specify
       flexi-grid label range.";
    leaf flexi-n {
      type l0-types:flexi-n;
      description
        "The given value 'N' is used to determine the nominal
        central frequency.

        As described in section 3.1 of RFC 8363, the range of 
        available nominal central frequencies are advertised for 
        m=1, which means that for an available central frequency n, 
        the frequency slot from central frequency n-1 to central 
        frequency n+1 is available.";
    }
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers,
      
      RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-Grid 
      Dense Wavelength Division Multiplexing (DWDM) Networks";
  }

  grouping flexi-grid-frequency-slot {
    description
      "Flexi-grid frequency slot grouping.";
    uses flexi-grid-label-start-end;
    leaf flexi-m {
      type l0-types:flexi-m;
      description
        "The given value 'M' is used to determine the slot width.";
    }
    reference
      "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
      Switch Capable (LSC) Label Switching Routers";
  }

  grouping flexi-grid-label-hop {
    description
      "Generic label-hop information for flexi-grid";
    choice single-or-super-channel {
      description
        "single or super channel";
      case single {
        uses flexi-grid-frequency-slot;
      }
      case super {
        status deprecated;
        list subcarrier-flexi-n {
          key "flexi-n";
          status deprecated;
          uses flexi-grid-frequency-slot {
            status deprecated;
          }
          description
            "List of subcarrier channels for flexi-grid super
             channel.";
        }
      }
      case multi {
        container frequency-slots {
          description
            "The top level container for the list of frequency 
            slots used for flexi-grid super channel.";
          list frequency-slot {
            key "flexi-n";
            min-elements 2;
            uses flexi-grid-frequency-slot;
            description
              "List of frequency slots used for flexi-grid super 
              channel.";
          }
        }
      }
    }
    reference
      "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-Grid 
      Dense Wavelength Division Multiplexing (DWDM) Networks";
  }

  grouping flexi-grid-label-range-info {
    description
      "Flexi-grid-specific label range related information";
    uses l0-label-range-info;
    container flexi-grid {
      description
        "flexi-grid definition";
      leaf slot-width-granularity {
        type identityref {
          base flexi-slot-width-granularity;
        }
        default "flexi-swg-12p5ghz";
        description
          "Minimum space between slot widths. Default is 12.500
           GHz.";
        reference
          "RFC 8363: GMPLS OSPF-TE Extensions in Support of 
          Flexi-Grid Dense Wavelength Division Multiplexing (DWDM) 
          Networks";
      }
      leaf min-slot-width-factor {
        type uint16 {
          range "1..max";
        }
        default "1";
        description
          "A multiplier of the slot width granularity, indicating
           the minimum slot width supported by an optical port.

           Minimum slot width is calculated by:
             Minimum slot width (GHz) =
               min-slot-width-factor * slot-width-granularity.";
        reference
          "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-
           Grid Dense Wavelength Division Multiplexing (DWDM)
           Networks";
      }
      leaf max-slot-width-factor {
        type uint16 {
          range "1..max";
        }
        must '. >= ../min-slot-width-factor' {
          error-message
            "Maximum slot width must be greater than or equal to
             minimum slot width.";
        }
        description
          "A multiplier of the slot width granularity, indicating
           the maximum slot width supported by an optical port.

           Maximum slot width is calculated by:
             Maximum slot width (GHz) =
               max-slot-width-factor * slot-width-granularity

           If specified, maximum slot width must be greater than or
           equal to minimum slot width.  If not specified, maximum
           slot width is equal to minimum slot width.";
        reference
          "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-
           Grid Dense Wavelength Division Multiplexing (DWDM)
           Networks";
      }
    }
  }

  grouping flexi-grid-label-step {
    description
      "Label step information for flexi-grid";
    leaf flexi-grid-channel-spacing {
      type identityref {
        base flexi-ch-spc-type;
      }
      default "flexi-ch-spc-6p25ghz";
      status deprecated;
      description
        "Label-step is the nominal central frequency granularity
         (GHz), e.g., 6.25 GHz.";
      reference
        "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
         Switch Capable (LSC) Label Switching Routers";
    }
    leaf flexi-ncfg {
      type identityref {
        base flexi-ncfg-type;
      }
      default "flexi-ncfg-6p25ghz";
      description
        "Label-step is the nominal central frequency granularity
         (GHz), e.g., 6.25 GHz.";
      reference
        "RFC 7699: Generalized Labels for the Flexi-Grid in Lambda
         Switch Capable (LSC) Label Switching Routers";
    }
    leaf flexi-n-step {
      type uint8;
      description
        "This attribute defines the multiplier for the supported
         values of 'N'.

         For example, given a grid with a nominal central frequency
         granularity of 6.25 GHz, the granularity of the supported
         values of the nominal central frequency could be 12.5 GHz.
         In this case, the values of flexi-n should be even and this
         constraint is reported by setting the flexi-n-step to 2.

         This attribute is also known as central frequency
         granularity in RFC 8363.";
      reference
        "RFC 8363: GMPLS OSPF-TE Extensions in Support of Flexi-Grid
         Dense Wavelength Division Multiplexing (DWDM) Networks";
    }
  }

  grouping transceiver-mode {
    description
      "This grouping is intended to be used for reporting the
      information of a transceiver's mode.

      The attributes for the explicit mode shall be augmented when
      used with either:
      - the proper leafrefs, when explicit mode templates are used;
        or,
      - the explicit-mode grouping, when explicit mode templates
        are not used.

      The compatible-modes container shall be augmented with the 
      proper leafrefs when used: see for example the 
      transceiver-capabilities grouping below.";
    choice mode {
      config false;
      mandatory true;
      description
        "Indicates whether the transceiver's mode is a standard
          mode, an organizational mode or an explicit mode.";
      case G.698.2 {
        uses standard-mode;
        uses common-standard-organizational-mode;
        uses common-all-modes;
      }
      case organizational-mode {
        container organizational-mode {
          config false;
          description
            "The set of attributes for an organizational mode";
          uses organizational-mode;
          uses common-standard-organizational-mode;
          uses common-all-modes;
        }  // container organizational-mode
      }
      case explicit-mode {
        container explicit-mode {
          config false;
          description
            "The set of attributes for an explicit mode";
          // uses explicit-mode;
          uses common-all-modes;
          container compatible-modes {
            description
              "Container for all the standard and organizational
                modes supported by the transceiver's explicit
                mode.";
          }  // container compatible-modes
        }  // container explicit-mode
      } // end of case explicit-mode
    } // end of choice
  }

  grouping transceiver-capabilities {
    description
      "This grouping is intended to be used for reporting the
      capabilities of a transceiver.
      
      The attributes for the explicit mode shall be augmented when
      used with either:
      - the proper leafrefs, when explicit mode templates are used;
        or,
      - the explicit-mode grouping, when explicit mode templates
        are not used.";

    container supported-modes {
      presence
        "When present, it indicates that the modes supported by a 
        transceiver are reported.";
      config false;
      description
        "The top level container for the list supported 
        transceiver's modes.";
      list supported-mode {
        key "mode-id";
        config false;
        min-elements 1;
        description "The list of supported transceiver's modes.";
        leaf mode-id {
          type string { 
            length "1..255";
          }
          description "ID for the supported transceiver's mode.";
        }
        uses transceiver-mode {
          augment "mode/explicit-mode/explicit-mode/"
                + "compatible-modes" {
            description
              "Augments the compatible modes with the proper 
              leafrefs.";
            leaf-list supported-application-codes {
              type leafref {
                path "../../../../supported-mode/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 "../../../../supported-mode/mode-id";
              }
              must "../../../../"
                  + "supported-mode[mode-id=current()]/"
                  + "organizational-mode" {
                description
                  "The pointer is only for organizational modes
                  supported by transceiver.";
              }
              description
                "List of pointers to the organizational modes
                  supported by the transceiver's explicit mode.";
            }
          }
        }
      }  // list supported-modes
    }  // container supported-modes
  }  // grouping transceiver-capabilities

  grouping standard-mode {
    description
      "ITU-T G.698.2 standard mode that guarantees interoperability.
       It must be an string with the following format:
       B-DScW-ytz(v) where all these attributes are conformant
       to the ITU-T recomendation";

    leaf standard-mode {
      type standard-mode;
      config false;
      description
        "G.698.2 standard mode";
    }
  }

  grouping organizational-mode {
    description
      "Transponder operational mode supported by organizations or
       vendor";

    leaf operational-mode {
      type operational-mode;
      config false;
      description
        "configured organization- or vendor-specific
         application identifiers (AI) supported by the transponder";
    }
    leaf organization-identifier {
      type organization-identifier;
      config false;
      description
        "organization identifier that uses organizational
         mode";
    }
  }

  grouping penalty-value {
    description
      "A common definition of the OSNR penalty value used for
       describing multiple penalty types (.e.g, CD, PMD, PDL).";

    leaf penalty-value {
      type union {
        type decimal-2 {
          range "0..max";
        }
        type empty;
      }
      units "dB";
      config false;
      mandatory true;
      description
        "The OSNR penalty associated with the related optical 
        impairment at the receiver, when the value is known or an 
        empty value when the value is not known.";
    }
  }

  grouping explicit-mode {
    description
      "Attributes capabilities related to explicit transceiver's
      mode.
      
      This grouping also contains 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.";
    leaf line-coding-bitrate {
      type identityref {
        base line-coding;
      }
      config false;
      description
        "Bit rate/line coding of the optical tributary signal.";
      reference 
        "ITU-T G.698.2 section 7.1.2";
    }
    leaf bitrate {
      type uint16;
      units "Gbit/sec";
      config false;
      description
        "The gross bitrate (e.g., 100, 200) of the optical tributary
        signal.";
    }
    leaf max-diff-group-delay  {
      type decimal-2;
      units "ps";
      config false;
      description
        "Maximum Differential group delay of this mode for this 
        lane";
    }
    leaf max-chromatic-dispersion {
      type decimal-2 {
        range "0..max";
      }
      units "ps/nm";
      config false;
      description
        "Maximum acceptable accumulated chromatic dispersion (CD) 
        on the receiver at Rx-power reference point
        (rx-ref-channel-power) and in absence of other impairments";
      reference
        "Section 2.6.4 of RFC YYYY: A YANG Data Model for Optical
        Impairment-aware Topology.";
    }
// RFC Ed.: replace YYYY with actual RFC number and remove
// this note after draft-ietf-ccamp-optical-impairment-topology-yang
// is published as an RFC
    list cd-penalty {
      key cd-value;
      config false;
      description
        "Optional penalty associated with a given accumulated
        chromatic dispersion (CD) value measured in
        absence of other impairments.

        This list of pair CD and OSNR penalty can be used to
        sample the function OSNR penalty = f(CD).";
      leaf cd-value {
        type decimal-2;
        units "ps/nm";
        config false;
        mandatory true;
        description
          "The Chromatic Dispersion (CD).";
      }
      uses penalty-value;
      reference
        "Section 2.6.4 of RFC YYYY: A YANG Data Model for Optical
        Impairment-aware Topology.";
    }
// RFC Ed.: replace YYYY with actual RFC number and remove
// this note after draft-ietf-ccamp-optical-impairment-topology-yang
// is published as an RFC
    leaf max-polarization-mode-dispersion {
      type decimal-2 {
        range "0..max";
      }
      units "ps";
      config false;
      description
        "Maximum acceptable accumulated polarization mode
         dispersion (PMD) on the receiver at Rx-power reference point
         (rx-ref-channel-power) and in absence of other impairments";
      reference
        "ITU-T G.666 (02/2011): Characteristics of polarization
        mode dispersion compensators and of receivers that
        compensate for polarization mode dispersion

        Section 2.6.4 of RFC YYYY: A YANG Data Model for Optical
        Impairment-aware Topology.";
    }
// RFC Ed.: replace YYYY with actual RFC number and remove
// this note after draft-ietf-ccamp-optical-impairment-topology-yang
// is published as an RFC
    list pmd-penalty {
      key pmd-value;
      config false;
      description
        "Optional penalty associated with a given accumulated
        polarization mode dispersion (PMD) value measured in
        absence of other impairments.

        This list of pair PMD and OSNR penalty can be used to
        sample the function OSNR penalty = f(PMD).";
      leaf pmd-value {
        type decimal-2 {
          range "0..max";
        }
        units "ps";
        config false;
        mandatory true;
        description
          "The Polarization Mode Dispersion (PMD).";
      }
      uses penalty-value;
      reference
        "Section 2.6.4 of RFC YYYY: A YANG Data Model for Optical
        Impairment-aware Topology.";
    }
// RFC Ed.: replace YYYY with actual RFC number and remove
// this note after draft-ietf-ccamp-optical-impairment-topology-yang
// is published as an RFC
    leaf max-polarization-dependent-loss {
      type power-loss-or-null;
      config false;
      mandatory true;
      description
        "Maximum acceptable accumulated polarization dependent
         loss (PDL) on the receiver at Rx-power reference point
         (rx-ref-channel-power) and in absence of other impairments";
      reference
        "Section 2.6.4 of RFC YYYY: A YANG Data Model for Optical
        Impairment-aware Topology.";
    }
// RFC Ed.: replace YYYY with actual RFC number and remove
// this note after draft-ietf-ccamp-optical-impairment-topology-yang
// is published as an RFC
    list pdl-penalty {
      key pdl-value;
      config false;
      description
        "Optional penalty associated with a given accumulated 
        polarization dependent loss (PDL) value, measured in
        absence of other impairments.

        This list of pair PDL and OSNR penalty can be used to
        sample the function OSNR penalty = f(PDL).";
      leaf pdl-value {
        type power-loss;
        config false;
        mandatory true;
        description
          "Maximum acceptable accumulated polarization dependent
          loss (PDL).";
      }
      uses penalty-value;
      reference
        "Section 2.6.4 of RFC YYYY: A YANG Data Model for Optical
        Impairment-aware Topology.";
    }
// RFC Ed.: replace YYYY with actual RFC number and remove
// this note after draft-ietf-ccamp-optical-impairment-topology-yang
// is published as an RFC
    leaf available-modulation-type {
      type identityref {
        base modulation;
      }
      config false;
      description
        "Modulation type the specific transceiver in the list
         can support";
    }
    leaf min-OSNR {
      type snr;
      units "dBm";
      config false;
      description
        "min OSNR measured over 0.1 nm resolution bandwidth:
        if received OSNR at Rx-power reference point
        (rx-ref-channel-power) is lower than MIN-OSNR, an increased 
        level of bit-errors post-FEC needs to be expected";
    }
    leaf rx-ref-channel-power {
      type power-dbm;
      config false;
      description
        "The channel power used as reference for defining penalties 
        and min-OSNR";
    }
    list rx-channel-power-penalty {
      key rx-channel-power-value;
      config false;
      description
        "Optional penalty associated with a received power
        lower than rx-ref-channel-power.

        This list of pair power and OSNR penalty can be used to
        sample the function OSNR penalty = f(rx-channel-power).";
      leaf rx-channel-power-value {
        type power-dbm;
        units "dBm";
        config false;
        mandatory true;
        description
          "The Received Power.";
      }
      uses penalty-value;
    }
    leaf min-Q-factor {
      type decimal-2;
      units "dB";
      config false;
      description "min Qfactor at FEC threshold";
    }
    leaf available-baud-rate {
      type decimal64 {
        fraction-digits 1;
      }
      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-ratio;
      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 decimal-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 explicit-mode

  grouping common-standard-organizational-mode {
    description
      "Common attributes used by standard and organizational 
      transceiver's modes.";
    
    leaf-list line-coding-bitrate {
      type identityref {
        base line-coding;
      }
      config false;
      description
        "The list of the bit rate/line coding of the optical 
        tributary signal supported by the transceiver.

        Reporting this list is optional when the standard or 
        organization mode supports only one bit rate/line coding.";
      reference 
        "ITU-T G.698.2 section 7.1.2";
    }
  } // grouping common-standard-organizational-mode

  grouping transceiver-tuning-range {
    description
      "Transceiver tuning range (f-min, f-max, f-granularity)";

    leaf min-central-frequency {
      type frequency-thz;
      description
        "This parameter indicates the minimum frequency for the
        transceiver tuning range.";
    }
    leaf max-central-frequency {
      type frequency-thz;
      description
        "This parameter indicates the maximum frequency for the
        transceiver tuning range.";
    }

    leaf transceiver-tunability-granularity {
      type frequency-ghz;
      description
        "This parameter indicates the transceiver frequency fine
        tuning granularity e.g 3.125GHz or 0.001GHz.";
    }
  } // grouping transceiver-tuning-range

  grouping common-all-modes {
    description
      "Common attributes used by all transceiver's modes.";

    container transceiver-tuning-range {
      config false;
      description
        "Transceiver tuning range (f-min, f-max, f-granularity)";
      uses transceiver-tuning-range;
    }

    leaf tx-channel-power-min {
      type power-dbm;
      config false;
      description "The minimum output power of this interface";
    }
    leaf tx-channel-power-max {
      type power-dbm;
      config false;
      description "The maximum output power of this interface";
    } 
    leaf rx-channel-power-min {
      type power-dbm;
      config false;
      description "The minimum input power of this interface";
    }
    leaf rx-channel-power-max {
      type power-dbm;
      config false;
      description "The maximum input power of this interface";
    }
    leaf rx-total-power-max {
      type power-dbm;
      config false;
      description
        "Maximum rx optical power for all the channels.
        
        It is applicable only to multi-channel modes.";
    }
  } // grouping common-all-modes

  grouping common-transceiver-param {
    description
      "The common parameters of an optical transceiver,
      that supplement the configured mode.";

    uses common-transceiver-configured-param;
    uses common-transceiver-readonly-param;
  }

  grouping common-transceiver-configured-param {
    description
      "The configured parameters of an optical transceiver,
      that supplement the configured mode.";

    leaf line-coding-bitrate {
      type identityref {
        base line-coding;
      }
      description
        "Bit rate/line coding of the optical tributary signal.
        
        Support of this attribute is optional when the configured 
        mode supports only one bit rate/line coding.";
      reference 
        "ITU-T G.698.2 section 7.1.2";
    }
    leaf tx-channel-power {
      type power-dbm-or-null;
      description
        "The current channel transmit power, when the value is 
        known or an empty value when the value is not known.
        
        The empty value MUST NOT be used when this attribute is 
        configured.";
    }
  } // grouping for configured transceiver attributes out of mode

  grouping common-transceiver-readonly-param {
    description
      "The common read-only parameters of an optical transceiver,
      that supplement the configured mode.";

    leaf rx-channel-power {
      type power-dbm-or-null;
      config false;
      description
        "The current channel received power, when the value is 
        known or an empty value when the value is not known.";
    }
    leaf rx-total-power {
      type power-dbm-or-null;
      config false;
      description
        "The current total received power, when the value is known 
        or an empty value when the value is not known.";
    }
  } // grouping for read-only transceiver attributes out of mode

  grouping l0-tunnel-attributes {
    description
      "Parameters for Layer0 (WSON or Flexi-Grid) Tunnels.";

    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-extra-margin {
      type snr {
        range 0..max;
      }
      default 0;
      description
        "An additional margin to be added to the OSNR-min of the
        transceiver when checking the estimated received Generalized
        SNR (GSNR).";
    }
  }

  grouping l0-path-properties {
    description
      "Common attribute for reporting the Layer 0 computed path
      properties.";
    leaf estimated-gsnr {
      type snr;
      config false;
      description
        "The estimate received GSNR for the computed path.";
    }
    leaf estimated-eol-gsnr {
      type snr;
      config false;
      description
        "The estimate received GSNR for the computed path
         degraded at the end of life.";
    }
    leaf estimated-lowest-gsnr {
      type snr;
      config false;
      description
        "The estimate lowest received GSNR for the computed path
         among all possible wavelength channels along the same
         path.";
    }
  }
}
]]></sourcecode></figure>

</section>
<section anchor="security-considerations"><name>Security Considerations</name>

<t>This section is modeled after the template described in Section 3.7
of <xref target="I-D.ietf-netmod-rfc8407bis"/>.</t>

<t>The "ietf-layer0-types" YANG module define data models that are
designed to be accessed via YANG-based management protocols, such as
NETCONF <xref target="RFC6241"/> and RESTCONF <xref target="RFC8040"/>. These protocols have to
use a secure transport layer (e.g., SSH <xref target="RFC4252"/>, TLS <xref target="RFC8446"/>, and
QUIC <xref target="RFC9000"/>) and have to use mutual authentication.</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.</t>

<t>The YANG modules define a set of identities, types, and
groupings. These nodes are intended to be reused by other YANG
modules. The modules by themselves do not expose any data nodes that
are writable, data nodes that contain read-only state, or RPCs.
As such, there are no additional security issues related to
the YANG module that need to be considered.</t>

<t>Modules that use the groupings that are defined in this document
should identify the corresponding security considerations. For
example, reusing some of these groupings will expose privacy-related
information (e.g., 'node-example').</t>

</section>
<section anchor="iana-considerations"><name>IANA Considerations</name>

<t>This document requests IANA to update the following URIs in the "IETF XML Registry" <xref target="RFC3688"/> 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 requests IANA to register the following YANG modules in the "YANG Module Names" registry <xref target="RFC6020"/> within the "YANG Parameters" registry group.</t>

<figure><artwork><![CDATA[
   Name:  ietf-layer0-types
   Maintained by IANA?  N
   Namespace:  urn:ietf:params:xml:ns:yang:ietf-layer0-types
   Prefix:  l0-types
   Reference:  RFC XXXX
]]></artwork></figure>

<ul empty="true"><li>
  <t>RFC Editor Note: Please replace XXXX with the RFC number assigned to this document and remove this note.</t>
</li></ul>

</section>


  </middle>

  <back>


<references title='References' anchor="sec-combined-references">

    <references title='Normative References' anchor="sec-normative-references">

<reference anchor="ITU-T_G.666" target="https://www.itu.int/rec/T-REC-G.666">
  <front>
    <title>Characteristics of polarization mode dispersion compensators and of receivers that compensate for polarization mode dispersion"</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2011" month="February"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.666" value=""/>
</reference>
<reference anchor="ITU-T_G.694.1" target="https://www.itu.int/rec/T-REC-G.694.1">
  <front>
    <title>Spectral grids for WDM applications: DWDM frequency grid</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2020" month="October"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.694.1" value=""/>
</reference>
<reference anchor="ITU-T_G.694.2" target="https://www.itu.int/rec/T-REC-G.694.2">
  <front>
    <title>Spectral grids for WDM applications: CWDM wavelength grid</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2003" month="December"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.694.2" value=""/>
</reference>
<reference anchor="ITU-T_G.698.2" target="https://www.itu.int/rec/T-REC-G.698.2">
  <front>
    <title>Amplified multichannel dense wavelength division multiplexing applications with single channel optical interfaces</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2018" month="November"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.698.2" value=""/>
</reference>
<reference anchor="ITU-T_G.709" target="https://www.itu.int/rec/T-REC-G.709">
  <front>
    <title>Interfaces for the optical transport network</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2020" month="June"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.709" value=""/>
</reference>
<reference anchor="ITU-T_G.709.2" target="https://www.itu.int/rec/T-REC-G.709.2">
  <front>
    <title>OTU4 long-reach interface</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2020" month="September"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.709.2, Corrigendum 1" value=""/>
</reference>
<reference anchor="ITU-T_G.709.3" target="https://www.itu.int/rec/T-REC-G.709.3">
  <front>
    <title>Flexible OTN B100G long-reach interfaces</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2022" month="November"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.709.3, Amendment 1" value=""/>
</reference>
<reference anchor="ITU-T_G.959.1" target="https://www.itu.int/rec/T-REC-G.959.1">
  <front>
    <title>Optical transport network physical layer interfaces</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2018" month="July"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.959.1" value=""/>
</reference>
<reference anchor="ITU-T_G.975" target="https://www.itu.int/rec/T-REC-G.975">
  <front>
    <title>Forward error correction for submarine systems</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2000" month="October"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.975" value=""/>
</reference>
<reference anchor="ITU-T_G.975.1" target="https://www.itu.int/rec/T-REC-G.975.1">
  <front>
    <title>Forward error correction for high bit-rate DWDM submarine systems</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2013" month="July"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.975.1, Corrigendum 2" value=""/>
</reference>
<reference anchor="ITU-T_G.977.1" target="https://www.itu.int/rec/T-REC-G.977.1">
  <front>
    <title>Transverse compatible dense wavelength division multiplexing applications for repeatered optical fibre submarine cable systems</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2021" month="February"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.977.1" value=""/>
</reference>
<reference anchor="ITU-T_G.9700" target="https://www.itu.int/rec/T-REC-G.9700">
  <front>
    <title>Fast access to subscriber terminals (G.fast) - Power spectral density specification</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2019" month="July"/>
  </front>
  <seriesInfo name="ITU-T Recommendation G.9700" value=""/>
</reference>
<reference anchor="OIF_400ZR" target="https://www.oiforum.com/wp-content/uploads/OIF-400ZR-01.0_reduced2.pdf">
  <front>
    <title>Implementation Agreement 400ZR</title>
    <author >
      <organization>Optical Internetworking Forum</organization>
    </author>
    <date year="2020" month="March"/>
  </front>
  <seriesInfo name="OIF-400ZR-01.0 Implementation Agreement" value=""/>
</reference>


<reference anchor="RFC7950">
  <front>
    <title>The YANG 1.1 Data Modeling Language</title>
    <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
    <date month="August" year="2016"/>
    <abstract>
      <t>YANG is a data modeling language used to model configuration data, state data, Remote Procedure Calls, and notifications for network management protocols. This document describes the syntax and semantics of version 1.1 of the YANG language. YANG version 1.1 is a maintenance release of the YANG language, addressing ambiguities and defects in the original specification. There are a small number of backward incompatibilities from YANG version 1. This document also specifies the YANG mappings to the Network Configuration Protocol (NETCONF).</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7950"/>
  <seriesInfo name="DOI" value="10.17487/RFC7950"/>
</reference>
<reference anchor="RFC6241">
  <front>
    <title>Network Configuration Protocol (NETCONF)</title>
    <author fullname="R. Enns" initials="R." role="editor" surname="Enns"/>
    <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
    <author fullname="J. Schoenwaelder" initials="J." role="editor" surname="Schoenwaelder"/>
    <author fullname="A. Bierman" initials="A." role="editor" surname="Bierman"/>
    <date month="June" year="2011"/>
    <abstract>
      <t>The Network Configuration Protocol (NETCONF) defined in this document provides mechanisms to install, manipulate, and delete the configuration of network devices. It uses an Extensible Markup Language (XML)-based data encoding for the configuration data as well as the protocol messages. The NETCONF protocol operations are realized as remote procedure calls (RPCs). This document obsoletes RFC 4741. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="6241"/>
  <seriesInfo name="DOI" value="10.17487/RFC6241"/>
</reference>
<reference anchor="RFC7698">
  <front>
    <title>Framework and Requirements for GMPLS-Based Control of Flexi-Grid Dense Wavelength Division Multiplexing (DWDM) Networks</title>
    <author fullname="O. Gonzalez de Dios" initials="O." role="editor" surname="Gonzalez de Dios"/>
    <author fullname="R. Casellas" initials="R." role="editor" surname="Casellas"/>
    <author fullname="F. Zhang" initials="F." surname="Zhang"/>
    <author fullname="X. Fu" initials="X." surname="Fu"/>
    <author fullname="D. Ceccarelli" initials="D." surname="Ceccarelli"/>
    <author fullname="I. Hussain" initials="I." surname="Hussain"/>
    <date month="November" year="2015"/>
    <abstract>
      <t>To allow efficient allocation of optical spectral bandwidth for systems that have high bit-rates, the International Telecommunication Union Telecommunication Standardization Sector (ITU-T) has extended its Recommendations G.694.1 and G.872 to include a new Dense Wavelength Division Multiplexing (DWDM) grid by defining a set of nominal central frequencies, channel spacings, and the concept of the "frequency slot". In such an environment, a data-plane connection is switched based on allocated, variable-sized frequency ranges within the optical spectrum, creating what is known as a flexible grid (flexi-grid).</t>
      <t>Given the specific characteristics of flexi-grid optical networks and their associated technology, this document defines a framework and the associated control-plane requirements for the application of the existing GMPLS architecture and control-plane protocols to the control of flexi-grid DWDM networks. The actual extensions to the GMPLS protocols will be defined in companion documents.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7698"/>
  <seriesInfo name="DOI" value="10.17487/RFC7698"/>
</reference>
<reference anchor="RFC9093">
  <front>
    <title>A YANG Data Model for Layer 0 Types</title>
    <author fullname="H. Zheng" initials="H." surname="Zheng"/>
    <author fullname="Y. Lee" initials="Y." surname="Lee"/>
    <author fullname="A. Guo" initials="A." surname="Guo"/>
    <author fullname="V. Lopez" initials="V." surname="Lopez"/>
    <author fullname="D. King" initials="D." surname="King"/>
    <date month="August" year="2021"/>
    <abstract>
      <t>This document defines a collection of common data types and groupings in the YANG data modeling language. These derived common types and groupings are intended to be imported by modules that model Layer 0 optical Traffic Engineering (TE) configuration and state capabilities such as Wavelength Switched Optical Networks (WSONs) and flexi-grid Dense Wavelength Division Multiplexing (DWDM) networks.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="9093"/>
  <seriesInfo name="DOI" value="10.17487/RFC9093"/>
</reference>
<reference anchor="RFC8342">
  <front>
    <title>Network Management Datastore Architecture (NMDA)</title>
    <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
    <author fullname="J. Schoenwaelder" initials="J." surname="Schoenwaelder"/>
    <author fullname="P. Shafer" initials="P." surname="Shafer"/>
    <author fullname="K. Watsen" initials="K." surname="Watsen"/>
    <author fullname="R. Wilton" initials="R." surname="Wilton"/>
    <date month="March" year="2018"/>
    <abstract>
      <t>Datastores are a fundamental concept binding the data models written in the YANG data modeling language to network management protocols such as the Network Configuration Protocol (NETCONF) and RESTCONF. This document defines an architectural framework for datastores based on the experience gained with the initial simpler model, addressing requirements that were not well supported in the initial model. This document updates RFC 7950.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8342"/>
  <seriesInfo name="DOI" value="10.17487/RFC8342"/>
</reference>
<reference anchor="RFC2119">
  <front>
    <title>Key words for use in RFCs to Indicate Requirement Levels</title>
    <author fullname="S. Bradner" initials="S." surname="Bradner"/>
    <date month="March" year="1997"/>
    <abstract>
      <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="14"/>
  <seriesInfo name="RFC" value="2119"/>
  <seriesInfo name="DOI" value="10.17487/RFC2119"/>
</reference>
<reference anchor="RFC8174">
  <front>
    <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
    <author fullname="B. Leiba" initials="B." surname="Leiba"/>
    <date month="May" year="2017"/>
    <abstract>
      <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="14"/>
  <seriesInfo name="RFC" value="8174"/>
  <seriesInfo name="DOI" value="10.17487/RFC8174"/>
</reference>

<reference anchor="I-D.ietf-teas-rfc8776-update">
   <front>
      <title>Common YANG Data Types for Traffic Engineering</title>
      <author fullname="Italo Busi" initials="I." surname="Busi">
         <organization>Huawei</organization>
      </author>
      <author fullname="Aihua Guo" initials="A." surname="Guo">
         <organization>Futurewei Technologies</organization>
      </author>
      <author fullname="Xufeng Liu" initials="X." surname="Liu">
         <organization>Alef Edge</organization>
      </author>
      <author fullname="Tarek Saad" initials="T." surname="Saad">
         <organization>Cisco Systems Inc.</organization>
      </author>
      <author fullname="Igor Bryskin" initials="I." surname="Bryskin">
         <organization>Individual</organization>
      </author>
      <date day="21" month="February" year="2025"/>
      <abstract>
	 <t>   This document defines a collection of common data types, identities,
   and groupings in YANG data modeling language.  These derived common
   data types, identities and groupings are intended to be imported by
   other modules, e.g., those which model the Traffic Engineering (TE)
   configuration and state capabilities.

   This document obsoletes RFC 8776.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-ietf-teas-rfc8776-update-17"/>
   
</reference>
<reference anchor="RFC6205">
  <front>
    <title>Generalized Labels for Lambda-Switch-Capable (LSC) Label Switching Routers</title>
    <author fullname="T. Otani" initials="T." role="editor" surname="Otani"/>
    <author fullname="D. Li" initials="D." role="editor" surname="Li"/>
    <date month="March" year="2011"/>
    <abstract>
      <t>Technology in the optical domain is constantly evolving, and, as a consequence, new equipment providing lambda switching capability has been developed and is currently being deployed.</t>
      <t>Generalized MPLS (GMPLS) is a family of protocols that can be used to operate networks built from a range of technologies including wavelength (or lambda) switching. For this purpose, GMPLS defined a wavelength label as only having significance between two neighbors. Global wavelength semantics are not considered.</t>
      <t>In order to facilitate interoperability in a network composed of next generation lambda-switch-capable equipment, this document defines a standard lambda label format that is compliant with the Dense Wavelength Division Multiplexing (DWDM) and Coarse Wavelength Division Multiplexing (CWDM) grids defined by the International Telecommunication Union Telecommunication Standardization Sector. The label format defined in this document can be used in GMPLS signaling and routing protocols. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="6205"/>
  <seriesInfo name="DOI" value="10.17487/RFC6205"/>
</reference>
<reference anchor="RFC7699">
  <front>
    <title>Generalized Labels for the Flexi-Grid in Lambda Switch Capable (LSC) Label Switching Routers</title>
    <author fullname="A. Farrel" initials="A." surname="Farrel"/>
    <author fullname="D. King" initials="D." surname="King"/>
    <author fullname="Y. Li" initials="Y." surname="Li"/>
    <author fullname="F. Zhang" initials="F." surname="Zhang"/>
    <date month="November" year="2015"/>
    <abstract>
      <t>GMPLS supports the description of optical switching by identifying entries in fixed lists of switchable wavelengths (called grids) through the encoding of lambda labels. Work within the ITU-T Study Group 15 has defined a finer-granularity grid, and the facility to flexibly select different widths of spectrum from the grid. This document defines a new GMPLS lambda label format to support this flexi-grid.</t>
      <t>This document updates RFCs 3471 and 6205 by introducing a new label format.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7699"/>
  <seriesInfo name="DOI" value="10.17487/RFC7699"/>
</reference>
<reference anchor="RFC7689">
  <front>
    <title>Signaling Extensions for Wavelength Switched Optical Networks</title>
    <author fullname="G. Bernstein" initials="G." role="editor" surname="Bernstein"/>
    <author fullname="S. Xu" initials="S." surname="Xu"/>
    <author fullname="Y. Lee" initials="Y." role="editor" surname="Lee"/>
    <author fullname="G. Martinelli" initials="G." surname="Martinelli"/>
    <author fullname="H. Harai" initials="H." surname="Harai"/>
    <date month="November" year="2015"/>
    <abstract>
      <t>This document provides extensions to Generalized Multiprotocol Label Switching (GMPLS) signaling for control of Wavelength Switched Optical Networks (WSONs). Such extensions are applicable in WSONs under a number of conditions including: (a) when optional processing, such as regeneration, must be configured to occur at specific nodes along a path, (b) where equipment must be configured to accept an optical signal with specific attributes, or (c) where equipment must be configured to output an optical signal with specific attributes. This document provides mechanisms to support distributed wavelength assignment with a choice of distributed wavelength assignment algorithms.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7689"/>
  <seriesInfo name="DOI" value="10.17487/RFC7689"/>
</reference>

<reference anchor="I-D.ietf-ccamp-optical-impairment-topology-yang">
   <front>
      <title>A YANG Data Model for Optical Impairment-aware Topology</title>
      <author fullname="Dieter Beller" initials="D." surname="Beller">
         <organization>Nokia</organization>
      </author>
      <author fullname="Esther Le Rouzic" initials="E." surname="Le Rouzic">
         <organization>Orange</organization>
      </author>
      <author fullname="Sergio Belotti" initials="S." surname="Belotti">
         <organization>Nokia</organization>
      </author>
      <author fullname="Gabriele Galimberti" initials="G." surname="Galimberti">
         <organization>Individual</organization>
      </author>
      <author fullname="Italo Busi" initials="I." surname="Busi">
         <organization>Huawei Technologies</organization>
      </author>
      <date day="21" month="October" year="2024"/>
      <abstract>
	 <t>   In order to provision an optical connection through optical networks,
   a combination of path continuity, resource availability, and
   impairment constraints must be met to determine viable and optimal
   paths through the network.  The determination of appropriate paths is
   known as Impairment-Aware Routing and Wavelength Assignment (IA-RWA)
   for WSON, while it is known as Impairment-Aware Routing and Spectrum
   Assignment (IA-RSA) for SSON.

   This document provides a YANG data model for the impairment-aware TE
   topology in optical networks.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-ietf-ccamp-optical-impairment-topology-yang-17"/>
   
</reference>
<reference anchor="RFC8795">
  <front>
    <title>YANG Data Model for Traffic Engineering (TE) Topologies</title>
    <author fullname="X. Liu" initials="X." surname="Liu"/>
    <author fullname="I. Bryskin" initials="I." surname="Bryskin"/>
    <author fullname="V. Beeram" initials="V." surname="Beeram"/>
    <author fullname="T. Saad" initials="T." surname="Saad"/>
    <author fullname="H. Shah" initials="H." surname="Shah"/>
    <author fullname="O. Gonzalez de Dios" initials="O." surname="Gonzalez de Dios"/>
    <date month="August" year="2020"/>
    <abstract>
      <t>This document defines a YANG data model for representing, retrieving, and manipulating Traffic Engineering (TE) Topologies. The model serves as a base model that other technology-specific TE topology models can augment.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8795"/>
  <seriesInfo name="DOI" value="10.17487/RFC8795"/>
</reference>
<reference anchor="RFC4203">
  <front>
    <title>OSPF Extensions in Support of Generalized Multi-Protocol Label Switching (GMPLS)</title>
    <author fullname="K. Kompella" initials="K." role="editor" surname="Kompella"/>
    <author fullname="Y. Rekhter" initials="Y." role="editor" surname="Rekhter"/>
    <date month="October" year="2005"/>
    <abstract>
      <t>This document specifies encoding of extensions to the OSPF routing protocol in support of Generalized Multi-Protocol Label Switching (GMPLS). [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="4203"/>
  <seriesInfo name="DOI" value="10.17487/RFC4203"/>
</reference>
<reference anchor="RFC8363">
  <front>
    <title>GMPLS OSPF-TE Extensions in Support of Flexi-Grid Dense Wavelength Division Multiplexing (DWDM) Networks</title>
    <author fullname="X. Zhang" initials="X." surname="Zhang"/>
    <author fullname="H. Zheng" initials="H." surname="Zheng"/>
    <author fullname="R. Casellas" initials="R." surname="Casellas"/>
    <author fullname="O. Gonzalez de Dios" initials="O." surname="Gonzalez de Dios"/>
    <author fullname="D. Ceccarelli" initials="D." surname="Ceccarelli"/>
    <date month="May" year="2018"/>
    <abstract>
      <t>The International Telecommunication Union Telecommunication standardization sector (ITU-T) has extended its Recommendations G.694.1 and G.872 to include a new Dense Wavelength Division Multiplexing (DWDM) grid by defining channel spacings, a set of nominal central frequencies, and the concept of the "frequency slot". Corresponding techniques for data-plane connections are known as "flexi-grid".</t>
      <t>Based on the characteristics of flexi-grid defined in G.694.1 and in RFCs 7698 and 7699, this document describes the Open Shortest Path First - Traffic Engineering (OSPF-TE) extensions in support of GMPLS control of networks that include devices that use the new flexible optical grid.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8363"/>
  <seriesInfo name="DOI" value="10.17487/RFC8363"/>
</reference>
<reference anchor="RFC7688">
  <front>
    <title>GMPLS OSPF Enhancement for Signal and Network Element Compatibility for Wavelength Switched Optical Networks</title>
    <author fullname="Y. Lee" initials="Y." role="editor" surname="Lee"/>
    <author fullname="G. Bernstein" initials="G." role="editor" surname="Bernstein"/>
    <date month="November" year="2015"/>
    <abstract>
      <t>This document provides Generalized Multiprotocol Label Switching (GMPLS) Open Shortest Path First (OSPF) routing enhancements to support signal compatibility constraints associated with Wavelength Switched Optical Network (WSON) elements. These routing enhancements are applicable in common optical or hybrid electro-optical networks where not all the optical signals in the network are compatible with all network elements participating in the network.</t>
      <t>This compatibility constraint model is applicable to common optical or hybrid electro-optical systems such as optical-electronic-optical (OEO) switches, regenerators, and wavelength converters, since such systems can be limited to processing only certain types of WSON signals.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7688"/>
  <seriesInfo name="DOI" value="10.17487/RFC7688"/>
</reference>
<reference anchor="RFC3471">
  <front>
    <title>Generalized Multi-Protocol Label Switching (GMPLS) Signaling Functional Description</title>
    <author fullname="L. Berger" initials="L." role="editor" surname="Berger"/>
    <date month="January" year="2003"/>
    <abstract>
      <t>This document describes extensions to Multi-Protocol Label Switching (MPLS) signaling required to support Generalized MPLS. Generalized MPLS extends the MPLS control plane to encompass time-division (e.g., Synchronous Optical Network and Synchronous Digital Hierarchy, SONET/SDH), wavelength (optical lambdas) and spatial switching (e.g., incoming port or fiber to outgoing port or fiber). This document presents a functional description of the extensions. Protocol specific formats and mechanisms, and technology specific details are specified in separate documents. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="3471"/>
  <seriesInfo name="DOI" value="10.17487/RFC3471"/>
</reference>
<reference anchor="RFC8341">
  <front>
    <title>Network Configuration Access Control Model</title>
    <author fullname="A. Bierman" initials="A." surname="Bierman"/>
    <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
    <date month="March" year="2018"/>
    <abstract>
      <t>The standardization of network configuration interfaces for use with the Network Configuration Protocol (NETCONF) or the RESTCONF protocol requires a structured and secure operating environment that promotes human usability and multi-vendor interoperability. There is a need for standard mechanisms to restrict NETCONF or RESTCONF protocol access for particular users to a preconfigured subset of all available NETCONF or RESTCONF protocol operations and content. This document defines such an access control model.</t>
      <t>This document obsoletes RFC 6536.</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="91"/>
  <seriesInfo name="RFC" value="8341"/>
  <seriesInfo name="DOI" value="10.17487/RFC8341"/>
</reference>
<reference anchor="RFC6020">
  <front>
    <title>YANG - A Data Modeling Language for the Network Configuration Protocol (NETCONF)</title>
    <author fullname="M. Bjorklund" initials="M." role="editor" surname="Bjorklund"/>
    <date month="October" year="2010"/>
    <abstract>
      <t>YANG is a data modeling language used to model configuration and state data manipulated by the Network Configuration Protocol (NETCONF), NETCONF remote procedure calls, and NETCONF notifications. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="6020"/>
  <seriesInfo name="DOI" value="10.17487/RFC6020"/>
</reference>



    </references>

    <references title='Informative References' anchor="sec-informative-references">

<reference anchor="ITU-T_G.Sup39" >
  <front>
    <title>Optical system design and engineering considerations</title>
    <author >
      <organization>International Telecommunication Union</organization>
    </author>
    <date year="2016" month="February"/>
  </front>
  <seriesInfo name="ITU-T Supplement G.Sup39" value=""/>
</reference>


<reference anchor="RFC6163">
  <front>
    <title>Framework for GMPLS and Path Computation Element (PCE) Control of Wavelength Switched Optical Networks (WSONs)</title>
    <author fullname="Y. Lee" initials="Y." role="editor" surname="Lee"/>
    <author fullname="G. Bernstein" initials="G." role="editor" surname="Bernstein"/>
    <author fullname="W. Imajuku" initials="W." surname="Imajuku"/>
    <date month="April" year="2011"/>
    <abstract>
      <t>This document provides a framework for applying Generalized Multi-Protocol Label Switching (GMPLS) and the Path Computation Element (PCE) architecture to the control of Wavelength Switched Optical Networks (WSONs). In particular, it examines Routing and Wavelength Assignment (RWA) of optical paths.</t>
      <t>This document focuses on topological elements and path selection constraints that are common across different WSON environments; as such, it does not address optical impairments in any depth. This document is not an Internet Standards Track specification; it is published for informational purposes.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="6163"/>
  <seriesInfo name="DOI" value="10.17487/RFC6163"/>
</reference>
<reference anchor="RFC7446">
  <front>
    <title>Routing and Wavelength Assignment Information Model for Wavelength Switched Optical Networks</title>
    <author fullname="Y. Lee" initials="Y." role="editor" surname="Lee"/>
    <author fullname="G. Bernstein" initials="G." role="editor" surname="Bernstein"/>
    <author fullname="D. Li" initials="D." surname="Li"/>
    <author fullname="W. Imajuku" initials="W." surname="Imajuku"/>
    <date month="February" year="2015"/>
    <abstract>
      <t>This document provides a model of information needed by the Routing and Wavelength Assignment (RWA) process in Wavelength Switched Optical Networks (WSONs). The purpose of the information described in this model is to facilitate constrained optical path computation in WSONs. This model takes into account compatibility constraints between WSON signal attributes and network elements but does not include constraints due to optical impairments. Aspects of this information that may be of use to other technologies utilizing a GMPLS control plane are discussed.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7446"/>
  <seriesInfo name="DOI" value="10.17487/RFC7446"/>
</reference>
<reference anchor="RFC7581">
  <front>
    <title>Routing and Wavelength Assignment Information Encoding for Wavelength Switched Optical Networks</title>
    <author fullname="G. Bernstein" initials="G." role="editor" surname="Bernstein"/>
    <author fullname="Y. Lee" initials="Y." role="editor" surname="Lee"/>
    <author fullname="D. Li" initials="D." surname="Li"/>
    <author fullname="W. Imajuku" initials="W." surname="Imajuku"/>
    <author fullname="J. Han" initials="J." surname="Han"/>
    <date month="June" year="2015"/>
    <abstract>
      <t>A Wavelength Switched Optical Network (WSON) requires certain key information fields be made available to facilitate path computation and the establishment of Label Switched Paths (LSPs). The information model described in "Routing and Wavelength Assignment Information Model for Wavelength Switched Optical Networks" (RFC 7446) shows what information is required at specific points in the WSON. Part of the WSON information model contains aspects that may be of general applicability to other technologies, while other parts are specific to WSONs.</t>
      <t>This document provides efficient, protocol-agnostic encodings for the WSON-specific information fields. It is intended that protocol- specific documents will reference this memo to describe how information is carried for specific uses. Such encodings can be used to extend GMPLS signaling and routing protocols. In addition, these encodings could be used by other mechanisms to convey this same information to a Path Computation Element (PCE).</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="7581"/>
  <seriesInfo name="DOI" value="10.17487/RFC7581"/>
</reference>

<reference anchor="I-D.ietf-netmod-rfc8407bis">
   <front>
      <title>Guidelines for Authors and Reviewers of Documents Containing YANG Data Models</title>
      <author fullname="Andy Bierman" initials="A." surname="Bierman">
         <organization>YumaWorks</organization>
      </author>
      <author fullname="Mohamed Boucadair" initials="M." surname="Boucadair">
         <organization>Orange</organization>
      </author>
      <author fullname="Qin Wu" initials="Q." surname="Wu">
         <organization>Huawei</organization>
      </author>
      <date day="14" month="January" year="2025"/>
      <abstract>
	 <t>   This memo provides guidelines for authors and reviewers of
   specifications containing YANG modules, including IANA-maintained
   modules.  Recommendations and procedures are defined, which are
   intended to increase interoperability and usability of Network
   Configuration Protocol (NETCONF) and RESTCONF protocol
   implementations that utilize YANG modules.  This document obsoletes
   RFC 8407.

   Also, this document updates RFC 8126 by providing additional
   guidelines for writing the IANA considerations for RFCs that specify
   IANA-maintained modules.  The document also updates RFC 6020 by
   clarifying how modules and their revisions are handled by IANA.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-ietf-netmod-rfc8407bis-22"/>
   
</reference>
<reference anchor="RFC8040">
  <front>
    <title>RESTCONF Protocol</title>
    <author fullname="A. Bierman" initials="A." surname="Bierman"/>
    <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
    <author fullname="K. Watsen" initials="K." surname="Watsen"/>
    <date month="January" year="2017"/>
    <abstract>
      <t>This document describes an HTTP-based protocol that provides a programmatic interface for accessing data defined in YANG, using the datastore concepts defined in the Network Configuration Protocol (NETCONF).</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8040"/>
  <seriesInfo name="DOI" value="10.17487/RFC8040"/>
</reference>
<reference anchor="RFC4252">
  <front>
    <title>The Secure Shell (SSH) Authentication Protocol</title>
    <author fullname="T. Ylonen" initials="T." surname="Ylonen"/>
    <author fullname="C. Lonvick" initials="C." role="editor" surname="Lonvick"/>
    <date month="January" year="2006"/>
    <abstract>
      <t>The Secure Shell Protocol (SSH) is a protocol for secure remote login and other secure network services over an insecure network. This document describes the SSH authentication protocol framework and public key, password, and host-based client authentication methods. Additional authentication methods are described in separate documents. The SSH authentication protocol runs on top of the SSH transport layer protocol and provides a single authenticated tunnel for the SSH connection protocol. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="4252"/>
  <seriesInfo name="DOI" value="10.17487/RFC4252"/>
</reference>
<reference anchor="RFC8446">
  <front>
    <title>The Transport Layer Security (TLS) Protocol Version 1.3</title>
    <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
    <date month="August" year="2018"/>
    <abstract>
      <t>This document specifies version 1.3 of the Transport Layer Security (TLS) protocol. TLS allows client/server applications to communicate over the Internet in a way that is designed to prevent eavesdropping, tampering, and message forgery.</t>
      <t>This document updates RFCs 5705 and 6066, and obsoletes RFCs 5077, 5246, and 6961. This document also specifies new requirements for TLS 1.2 implementations.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8446"/>
  <seriesInfo name="DOI" value="10.17487/RFC8446"/>
</reference>
<reference anchor="RFC9000">
  <front>
    <title>QUIC: A UDP-Based Multiplexed and Secure Transport</title>
    <author fullname="J. Iyengar" initials="J." role="editor" surname="Iyengar"/>
    <author fullname="M. Thomson" initials="M." role="editor" surname="Thomson"/>
    <date month="May" year="2021"/>
    <abstract>
      <t>This document defines the core of the QUIC transport protocol. QUIC provides applications with flow-controlled streams for structured communication, low-latency connection establishment, and network path migration. QUIC includes security measures that ensure confidentiality, integrity, and availability in a range of deployment circumstances. Accompanying documents describe the integration of TLS for key negotiation, loss detection, and an exemplary congestion control algorithm.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="9000"/>
  <seriesInfo name="DOI" value="10.17487/RFC9000"/>
</reference>
<reference anchor="RFC3688">
  <front>
    <title>The IETF XML Registry</title>
    <author fullname="M. Mealling" initials="M." surname="Mealling"/>
    <date month="January" year="2004"/>
    <abstract>
      <t>This document describes an IANA maintained registry for IETF standards which use Extensible Markup Language (XML) related items such as Namespaces, Document Type Declarations (DTDs), Schemas, and Resource Description Framework (RDF) Schemas.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="81"/>
  <seriesInfo name="RFC" value="3688"/>
  <seriesInfo name="DOI" value="10.17487/RFC3688"/>
</reference>
<reference anchor="RFC8340">
  <front>
    <title>YANG Tree Diagrams</title>
    <author fullname="M. Bjorklund" initials="M." surname="Bjorklund"/>
    <author fullname="L. Berger" initials="L." role="editor" surname="Berger"/>
    <date month="March" year="2018"/>
    <abstract>
      <t>This document captures the current syntax used in YANG module tree diagrams. The purpose of this document is to provide a single location for this definition. This syntax may be updated from time to time based on the evolution of the YANG language.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="215"/>
  <seriesInfo name="RFC" value="8340"/>
  <seriesInfo name="DOI" value="10.17487/RFC8340"/>
</reference>



    </references>

</references>


<?line 2816?>

<section anchor="yang-tree"><name>The Complete Schema Trees</name>

<t>This appendix presents the complete tree of the Layer 0 Types data model. See <xref target="RFC8340"/> for an explanation of the symbols used. The data type of every leaf node is shown near the right end of the corresponding line.</t>

<figure anchor="fig-yang-tree"><artwork type="ascii-art"><![CDATA[
module: ietf-layer0-types

  grouping wdm-label-start-end:
    +-- (grid-type)?
       +--:(fixed-dwdm)
       |  +-- dwdm-n?    l0-types:dwdm-n
       +--:(cwdm)
       |  +-- cwdm-n?    l0-types:cwdm-n
       +--:(flexi-grid)
          +-- flexi-n?   l0-types:flexi-n
  grouping wdm-label-step:
    +-- (l0-grid-type)?
       +--:(fixed-dwdm)
       |  +-- wson-dwdm-channel-spacing?    identityref
       +--:(cwdm)
       |  +-- wson-cwdm-channel-spacing?    identityref
       +--:(flexi-grid)
          x-- flexi-grid-channel-spacing?   identityref
          +-- flexi-ncfg?                   identityref
          +-- flexi-n-step?                 uint8
  grouping wdm-label-hop:
    +-- (grid-type)?
       +--:(fixed-dwdm)
       |  +-- (fixed-single-or-super-channel)?
       |     +--:(single)
       |     |  +-- dwdm-n?               l0-types:dwdm-n
       |     +--:(multi)
       |        +-- subcarrier-dwdm-n*    l0-types:dwdm-n
       +--:(cwdm)
       |  +-- cwdm-n?                     l0-types:cwdm-n
       +--:(flexi-grid)
          +-- (single-or-super-channel)?
             +--:(single)
             |  +-- flexi-n?              l0-types:flexi-n
             |  +-- flexi-m?              l0-types:flexi-m
             x--:(super)
             |  x-- subcarrier-flexi-n* [flexi-n]
             |     +-- flexi-n?   l0-types:flexi-n
             |     +-- flexi-m?   l0-types:flexi-m
             +--:(multi)
                +-- frequency-slots
                   +-- frequency-slot* [flexi-n]
                      +-- flexi-n?   l0-types:flexi-n
                      +-- flexi-m?   l0-types:flexi-m
  grouping wdm-label-range-info:
    +-- grid-type?    identityref
    +-- priority?     uint8
    +-- flexi-grid
       +-- slot-width-granularity?   identityref
       +-- min-slot-width-factor?    uint16
       +-- max-slot-width-factor?    uint16
  grouping wson-label-start-end:
    +-- (grid-type)?
       +--:(dwdm)
       |  +-- dwdm-n?   l0-types:dwdm-n
       +--:(cwdm)
          +-- cwdm-n?   l0-types:cwdm-n
  grouping wson-label-hop:
    +-- (grid-type)?
       +--:(dwdm)
       |  +-- (single-or-super-channel)?
       |     +--:(single)
       |     |  +-- dwdm-n?              l0-types:dwdm-n
       |     +--:(super)
       |        +-- subcarrier-dwdm-n*   l0-types:dwdm-n
       +--:(cwdm)
          +-- cwdm-n?                    l0-types:cwdm-n
  grouping l0-label-range-info:
    +-- grid-type?   identityref
    +-- priority?    uint8
  grouping wson-label-step:
    +-- (l0-grid-type)?
       +--:(dwdm)
       |  +-- wson-dwdm-channel-spacing?   identityref
       +--:(cwdm)
          +-- wson-cwdm-channel-spacing?   identityref
  grouping flexi-grid-label-start-end:
    +-- flexi-n?   l0-types:flexi-n
  grouping flexi-grid-frequency-slot:
    +-- flexi-n?   l0-types:flexi-n
    +-- flexi-m?   l0-types:flexi-m
  grouping flexi-grid-label-hop:
    +-- (single-or-super-channel)?
       +--:(single)
       |  +-- flexi-n?              l0-types:flexi-n
       |  +-- flexi-m?              l0-types:flexi-m
       x--:(super)
       |  x-- subcarrier-flexi-n* [flexi-n]
       |     +-- flexi-n?   l0-types:flexi-n
       |     +-- flexi-m?   l0-types:flexi-m
       +--:(multi)
          +-- frequency-slots
             +-- frequency-slot* [flexi-n]
                +-- flexi-n?   l0-types:flexi-n
                +-- flexi-m?   l0-types:flexi-m
  grouping flexi-grid-label-range-info:
    +-- grid-type?    identityref
    +-- priority?     uint8
    +-- flexi-grid
       +-- slot-width-granularity?   identityref
       +-- min-slot-width-factor?    uint16
       +-- max-slot-width-factor?    uint16
  grouping flexi-grid-label-step:
    x-- flexi-grid-channel-spacing?   identityref
    +-- flexi-ncfg?                   identityref
    +-- flexi-n-step?                 uint8
  grouping transceiver-mode:
    +--ro (mode)
       +--:(G.698.2)
       |  +--ro standard-mode?              standard-mode
       |  +--ro line-coding-bitrate*        identityref
       |  +--ro transceiver-tuning-range
       |  |  +--ro min-central-frequency?
       |  |  |       frequency-thz
       |  |  +--ro max-central-frequency?
       |  |  |       frequency-thz
       |  |  +--ro transceiver-tunability-granularity?
       |  |          frequency-ghz
       |  +--ro tx-channel-power-min?       power-dbm
       |  +--ro tx-channel-power-max?       power-dbm
       |  +--ro rx-channel-power-min?       power-dbm
       |  +--ro rx-channel-power-max?       power-dbm
       |  +--ro rx-total-power-max?         power-dbm
       +--:(organizational-mode)
       |  +--ro organizational-mode
       |     +--ro operational-mode?           operational-mode
       |     +--ro organization-identifier?
       |     |       organization-identifier
       |     +--ro line-coding-bitrate*        identityref
       |     +--ro transceiver-tuning-range
       |     |  +--ro min-central-frequency?
       |     |  |       frequency-thz
       |     |  +--ro max-central-frequency?
       |     |  |       frequency-thz
       |     |  +--ro transceiver-tunability-granularity?
       |     |          frequency-ghz
       |     +--ro tx-channel-power-min?       power-dbm
       |     +--ro tx-channel-power-max?       power-dbm
       |     +--ro rx-channel-power-min?       power-dbm
       |     +--ro rx-channel-power-max?       power-dbm
       |     +--ro rx-total-power-max?         power-dbm
       +--:(explicit-mode)
          +--ro explicit-mode
             +--ro transceiver-tuning-range
             |  +--ro min-central-frequency?
             |  |       frequency-thz
             |  +--ro max-central-frequency?
             |  |       frequency-thz
             |  +--ro transceiver-tunability-granularity?
             |          frequency-ghz
             +--ro tx-channel-power-min?       power-dbm
             +--ro tx-channel-power-max?       power-dbm
             +--ro rx-channel-power-min?       power-dbm
             +--ro rx-channel-power-max?       power-dbm
             +--ro rx-total-power-max?         power-dbm
             +--ro compatible-modes
  grouping transceiver-capabilities:
    +--ro supported-modes!
       +--ro supported-mode* [mode-id]
          +--ro mode-id?                          string
          +--ro (mode)
             +--:(G.698.2)
             |  +--ro standard-mode?              standard-mode
             |  +--ro line-coding-bitrate*        identityref
             |  +--ro transceiver-tuning-range
             |  |  +--ro min-central-frequency?
             |  |  |       frequency-thz
             |  |  +--ro max-central-frequency?
             |  |  |       frequency-thz
             |  |  +--ro transceiver-tunability-granularity?
             |  |          frequency-ghz
             |  +--ro tx-channel-power-min?       power-dbm
             |  +--ro tx-channel-power-max?       power-dbm
             |  +--ro rx-channel-power-min?       power-dbm
             |  +--ro rx-channel-power-max?       power-dbm
             |  +--ro rx-total-power-max?         power-dbm
             +--:(organizational-mode)
             |  +--ro organizational-mode
             |     +--ro operational-mode?           operational-mode
             |     +--ro organization-identifier?
             |     |       organization-identifier
             |     +--ro line-coding-bitrate*        identityref
             |     +--ro transceiver-tuning-range
             |     |  +--ro min-central-frequency?
             |     |  |       frequency-thz
             |     |  +--ro max-central-frequency?
             |     |  |       frequency-thz
             |     |  +--ro transceiver-tunability-granularity?
             |     |          frequency-ghz
             |     +--ro tx-channel-power-min?       power-dbm
             |     +--ro tx-channel-power-max?       power-dbm
             |     +--ro rx-channel-power-min?       power-dbm
             |     +--ro rx-channel-power-max?       power-dbm
             |     +--ro rx-total-power-max?         power-dbm
             +--:(explicit-mode)
                +--ro explicit-mode
                   +--ro transceiver-tuning-range
                   |  +--ro min-central-frequency?
                   |  |       frequency-thz
                   |  +--ro max-central-frequency?
                   |  |       frequency-thz
                   |  +--ro transceiver-tunability-granularity?
                   |          frequency-ghz
                   +--ro tx-channel-power-min?       power-dbm
                   +--ro tx-channel-power-max?       power-dbm
                   +--ro rx-channel-power-min?       power-dbm
                   +--ro rx-channel-power-max?       power-dbm
                   +--ro rx-total-power-max?         power-dbm
                   +--ro compatible-modes
                      +--ro supported-application-codes*
                      |       -> ../../../../supported-mode/mode-id
                      +--ro supported-organizational-modes*
                              -> ../../../../supported-mode/mode-id
  grouping standard-mode:
    +--ro standard-mode?   standard-mode
  grouping organizational-mode:
    +--ro operational-mode?          operational-mode
    +--ro organization-identifier?   organization-identifier
  grouping penalty-value:
    +--ro penalty-value    union
  grouping explicit-mode:
    +--ro line-coding-bitrate?                identityref
    +--ro bitrate?                            uint16
    +--ro max-diff-group-delay?               decimal-2
    +--ro max-chromatic-dispersion?           decimal-2
    +--ro cd-penalty* [cd-value]
    |  +--ro cd-value         decimal-2
    |  +--ro penalty-value    union
    +--ro max-polarization-mode-dispersion?   decimal-2
    +--ro pmd-penalty* [pmd-value]
    |  +--ro pmd-value        decimal-2
    |  +--ro penalty-value    union
    +--ro max-polarization-dependent-loss     power-loss-or-null
    +--ro pdl-penalty* [pdl-value]
    |  +--ro pdl-value        power-loss
    |  +--ro penalty-value    union
    +--ro available-modulation-type?          identityref
    +--ro min-OSNR?                           snr
    +--ro rx-ref-channel-power?               power-dbm
    +--ro rx-channel-power-penalty* [rx-channel-power-value]
    |  +--ro rx-channel-power-value    power-dbm
    |  +--ro penalty-value             union
    +--ro min-Q-factor?                       decimal-2
    +--ro available-baud-rate?                decimal64
    +--ro roll-off?                           decimal64
    +--ro min-carrier-spacing?                frequency-ghz
    +--ro available-fec-type?                 identityref
    +--ro fec-code-rate?                      decimal64
    +--ro fec-threshold?                      decimal64
    +--ro in-band-osnr?                       snr
    +--ro out-of-band-osnr?                   snr
    +--ro tx-polarization-power-difference?   power-ratio
    +--ro polarization-skew?                  decimal-2
  grouping common-standard-organizational-mode:
    +--ro line-coding-bitrate*   identityref
  grouping transceiver-tuning-range:
    +-- min-central-frequency?                frequency-thz
    +-- max-central-frequency?                frequency-thz
    +-- transceiver-tunability-granularity?   frequency-ghz
  grouping common-all-modes:
    +--ro transceiver-tuning-range
    |  +--ro min-central-frequency?                frequency-thz
    |  +--ro max-central-frequency?                frequency-thz
    |  +--ro transceiver-tunability-granularity?   frequency-ghz
    +--ro tx-channel-power-min?       power-dbm
    +--ro tx-channel-power-max?       power-dbm
    +--ro rx-channel-power-min?       power-dbm
    +--ro rx-channel-power-max?       power-dbm
    +--ro rx-total-power-max?         power-dbm
  grouping common-transceiver-param:
    +-- line-coding-bitrate?   identityref
    +-- tx-channel-power?      power-dbm-or-null
    +--ro rx-channel-power?      power-dbm-or-null
    +--ro rx-total-power?        power-dbm-or-null
  grouping common-transceiver-configured-param:
    +-- line-coding-bitrate?   identityref
    +-- tx-channel-power?      power-dbm-or-null
  grouping common-transceiver-readonly-param:
    +--ro rx-channel-power?   power-dbm-or-null
    +--ro rx-total-power?     power-dbm-or-null
  grouping l0-tunnel-attributes:
    +-- wavelength-assignment?   identityref
  grouping frequency-range:
    +-- lower-frequency    frequency-thz
    +-- upper-frequency    frequency-thz
  grouping l0-path-constraints:
    +-- gsnr-extra-margin?   snr
  grouping l0-path-properties:
    +--ro estimated-gsnr?          snr
    +--ro estimated-eol-gsnr?      snr
    +--ro estimated-lowest-gsnr?   snr
]]></artwork></figure>

</section>
<section anchor="changes-bis"><name>Changes from RFC 9093</name>

<t>This version adds new identities, data types, and groupings to the 'ietf-layer0-types' YANG module.</t>

<t>The following new YANG identities have been added to the 'ietf-layer0-types' module:</t>

<t><list style="symbols">
  <t>cwdm-ch-spc-type</t>
  <t>flexi-ncfg-type</t>
  <t>flexi-ncfg-6p25gh</t>
  <t>modulation</t>
  <t>DPSK</t>
  <t>QPSK</t>
  <t>DP-QPSK</t>
  <t>QAM8</t>
  <t>DP-QAM8</t>
  <t>QAM16</t>
  <t>DP-QAM16</t>
  <t>QAM32</t>
  <t>DP-QAM32</t>
  <t>QAM64</t>
  <t>DP-QAM64</t>
  <t>fec-type</t>
  <t>g-fec</t>
  <t>super-fec</t>
  <t>no-fec</t>
  <t>sc-fec</t>
  <t>o-fec</t>
  <t>c-fec</t>
  <t>line-coding</t>
  <t>line-coding-NRZ-2p5G</t>
  <t>line-coding-NRZ-OTU1</t>
  <t>line-coding-NRZ-10G</t>
  <t>line-coding-NRZ-OTU2</t>
  <t>line-coding-OTL4.4-SC</t>
  <t>line-coding-FOIC1.4-SC</t>
  <t>wavelength-assignment</t>
  <t>first-fit-wavelength-assignment</t>
  <t>random-wavelength-assignment</t>
  <t>least-loaded-wavelength-assignment</t>
  <t>lower-first-wavelength-assignment</t>
  <t>upper-first-wavelength-assignment</t>
  <t>type-power-mode</t>
  <t>power-spectral-density</t>
  <t>carrier-power</t>
  <t>switching-wson-lsc</t>
  <t>switching-flexi-grid-lsc</t>
</list></t>

<t>The following new YANG data types have been added to the 'ietf-layer0-types' module:</t>

<t><list style="symbols">
  <t>Standard-mode</t>
  <t>Organization-identifier</t>
  <t>Operational-mode</t>
  <t>frequency-thz</t>
  <t>frequency-ghz</t>
  <t>snr</t>
  <t>snr-or-null</t>
  <t>fiber-type</t>
  <t>decimal-2</t>
  <t>decimal-2-or-null</t>
  <t>power-gain</t>
  <t>power-gain-or-null</t>
  <t>power-loss</t>
  <t>power-loss-or-null</t>
  <t>power-ratio</t>
  <t>power-ratio-or-null</t>
  <t>power-dbm</t>
  <t>power-dbm-or-null</t>
  <t>decimal-5</t>
  <t>decimal-5-or-null</t>
  <t>psd</t>
  <t>psd-or-null</t>
</list></t>

<t>The following new YANG groupings have been added to the 'ietf-layer0-types' module:</t>

<t><list style="symbols">
  <t>wdm-label-start-end</t>
  <t>wdm-label-step</t>
  <t>wdm-label-hop</t>
  <t>wdm-label-range-info</t>
  <t>transceiver-mode</t>
  <t>transceiver-capabilities</t>
  <t>standard-mode</t>
  <t>organizational-mode</t>
  <t>penalty-value</t>
  <t>explicit-mode</t>
  <t>common-standard-organizational-mode</t>
  <t>transceiver-tuning-range</t>
  <t>common-all-mode</t>
  <t>common-transceiver-param</t>
  <t>common-transceiver-configured-param</t>
  <t>common-transceiver-readonly-param</t>
  <t>l0-tunnel-attributes</t>
  <t>frequency-range</t>
  <t>l0-path-constraints</t>
  <t>l0-path-properties</t>
</list></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 to Adrian Farrel and Tom Petch for their 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="H." surname="Zheng" fullname="Haomian Zheng">
      <organization>Huawei</organization>
      <address>
        <email>zhenghaomian@huawei.com</email>
      </address>
    </contact>
    <contact initials="D." surname="King" fullname="Daniel King">
      <organization>University of Lancaster</organization>
      <address>
        <email>d.king@lancaster.ac.uk</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>
    <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>
    <contact initials="R." surname="Manzotti" fullname="Roberto Manzotti">
      <organization>Cisco</organization>
      <address>
        <email>rmanzott@cisco.com</email>
      </address>
    </contact>
    <contact initials="G." surname="Grammel" fullname="Gert Grammel">
      <organization>Juniper</organization>
      <address>
        <email>ggrammel@juniper.net</email>
      </address>
    </contact>
    </section>

  </back>

<!-- ##markdown-source:
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
1B5RTcD/D+W6p7y6pAEA

-->

</rfc>

