## Open ZR+ MSA

## Technical Specification

## Change History

| REV No. | Date | Description |
| :---: | :---: | :---: |
| 1.0 | 4-Sep-2020 | First release publication |

Chair: Atul Srivastava, NTT Electronics<br>Co-Chair: Tom Williams, Acacia Communications<br>Editor: David Lewis, Lumentum

Member companies at the time of publication:

| Acacia Communications |
| :--- |
| Arista Networks |
| Cisco |
| Fujitsu Optical Components |
| Innolight |
| Juniper Networks |
| Lumentum |
| NTT Electronics |

Limitation on use of Information:

This specification is provided "AS IS" with NO WARRANTIES whatsoever and therefore the provision of this specification does not include any warranty of merchantability, noninfringement, fitness for a particular purpose, or any other warranty otherwise arising out of any proposal, specification or sample. The authors further disclaim all liability, including liability for infringement of any proprietary rights, relating to use of information in this specification. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted herein.

Permissions:

You are authorized to download, reproduce and distribute this document. All other rights are reserved. The provision of this document should not be construed as the granting of any right to practice, make, use or otherwise develop products that are based on the document. Any and all IP rights related to this document and the designs disclosed within, except for the rights expressly mentioned above, are reserved by the respective owners of those IP rights.

## Contents

1 Scope and Introduction ..... 5
1.1 400ZR+ Format ..... 6
$1.2300 Z R+$ Format ..... 6
1.3 200ZR+ Format ..... 6
1.4 100ZR+ Format ..... 7
1.5 OpenZR+ Supported Client Modes ..... 7
2 OpenZR+ Block Diagram ..... 8
3 ZR frame structure ..... 9
3.1 257-bit Blocks ..... 9
3.2 ZR400 Frame ..... 10
3.3 ZR400 Frame ..... 10
3.4 ZR300 Frame ..... 10
3.5 ZR200 Frame ..... 11
3.6 ZR100 Frame ..... 12
3.7 Framing Overhead ..... 12
3.8 Media Slot Identifier (MSI) / Tributary Slot Identifier (TSI) ..... 14
4 Datapath Processing. ..... 15
4.1 OpenZR+ Multiplexing/Demultiplexing (ZRMAP/ZRDEMAP) ..... 15
4.2 GMP Definition. ..... 16
4.3 GMP Blocks ..... 16
4.4 Mapping of client traffic into ZR400 ..... 16
4.5 Generic Mapping Procedure Principles ..... 17
4.6 Stuffing Locations ..... 20
5 Multiplexing ..... 20
5.1 ZR400 Frame Structure ..... 21
5.1.1 400G Container Multiplexing ..... 22
5.1.2 1×400G Data Multiplexing ..... 23
5.1.3 $\quad 2 \times 200 \mathrm{G}$ Data Multiplexing ..... 23
5.1.4 $4 \times 100 \mathrm{G}$ Data Multiplexing ..... 23
5.2 ZR300 Frame Structure ..... 24
5.2.1 300G Container Multiplexing ..... 24
5.2.2 3×100G Data Multiplexing ..... 25
5.3 ZR200 Frame Structure ..... 26
5.3.1 200G Container Multiplexing ..... 26
5.3.2 1×200G Data Multiplexing ..... 28
5.3.3 $\quad 2 \times 100 \mathrm{G}$ Data Multiplexing ..... 28
OpenZR+ MSA Specification, version 1.0
5.4 ZR100 frame structure ..... 28
5.4.1 100G Container Multiplexing ..... 29
5.4.2 1x100G Data Multiplexing ..... 29
6 ZRx adaptation to OFEC ..... 31
6.1 Padding Insertion/Removal ..... 31
6.2 ZR400 adaptation to ZR400-OFEC-16QAM ..... 31
6.3 ZR300 adaptation to ZR300-OFEC-8QAM ..... 32
6.4 ZR200 adaptation to ZR200-OFEC-QPSK ..... 33
6.5 ZR100 adaptation to OFEC input blocks ..... 34
6.6 Frame Synchronous Scrambling ..... 35
7 Open Forward Error Correction (OFEC) ..... 36
7.1 OFEC encoding codec ..... 36
7.2 Encoding ..... 39
7.3 Encoder interface ..... 39
7.4 Formal encoder definition ..... 41
7.5 Decoding ..... 42
7.6 OFEC Interleaver ..... 42
7.7 OFEC Interleaver architecture ..... 42
7.8 Intra-block interleaving ..... 42
7.9 Inter-block interleaving ..... 43
8 Symbol Mapping and Polarization Distribution ..... 45
8.1 Symbol mapping ..... 45
8.2 DP-16QAM Symbols ..... 45
8.3 8QAM Symbols ..... 46
8.4 QPSK Symbols ..... 47
9 DSP Framing ..... 48
9.1 DSP super-frame ..... 48
9.2 DSP sub-frame ..... 48
9.3 FAW Sequence ..... 50
9.4 Training Sequence ..... 51
9.5 Pilot Sequence ..... 51
10 Frame Expansion Rate ..... 56
11 Optical Specifications ..... 57
11.1 OpenZR+ DWDM amplified application: ..... 57
OpenZR+ MSA Specification, version 1.0
11.1.1 DWDM link specifications (black link methodology) ..... 57
11.1.2 Transmitter Optical Specifications ..... 58
11.1.3 Receiver Optical Specifications ..... 61
11.2 OpenZR+, Single wavelength, Unamplified: ..... 63
11.3 Optical Parameter Definitions ..... 63
11.3.1 Receiver Optical Signal-to-noise Ratio Tolerance ..... 63
11.3.2 Tx spectral excursion ..... 63
11.3.3 Out-of-Band OSNR (OOB OSNR) ..... 64
11.3.4 Differential Group Delay (DGD) ..... 64
11.3.5 Ripple. ..... 64
11.3.6 Optical return loss at Ss ..... 65
11.3.7 Discrete reflectance between Ss and Rs ..... 65
11.3.8 Polarization Dependent Loss (PDL) ..... 65
11.3.9 Polarization rotation speed. ..... 65
11.3.10 Inter-channel crosstalk ..... 65
11.3.11 Interferometric crosstalk ..... 66
11.3.12 I-Q offset ..... 66
12 Appendix - Host interfaces (informative) ..... 67
12.1 400GE Clients ..... 67
12.2 200GE Clients ..... 69
12.3 100GE Clients ..... 70
12.4 Client signal processing ..... 73

## 1 Scope and Introduction

OpenZR+ defines specifications for 100-400G single-wavelength optical ports for transceiver/transponder, muxceiver/muxponder (TRXR/TRPN, MUXR/MUXP) node functions and for switch/router optical ports.


Figure 1-1: OpenZR+ Architecture reference
The architecture, shown in Figure 1-1 includes client sub-layers for up to four 100GBASER clients, up to two 200GBASE-R clients and a single 400GBASE-R client. Client data and alignment markers are extracted and re-timed to the line side clock domain using the general mapping protocol (GMP). Retimed data plus GMP timing information is then mapped into one of the OpenZR+ frame formats. Those frames are multiplexed and OFEC encoded and become the payload of a DSP frame with DP-16QAM, DP-8QAM, or DPQPSK symbols.

Note: this specification makes no assumption about the allocation of functions on a line card or optical modules (albeit, a typical module will provide a transceiver/muxceiver function for Ethernet signals 100G and beyond).
Table 1-1 lists possible combinations of clients and network lane interfaces included in this specification.

Table 1-1: Transceiver/Transponder (TRXR/TRXP) functions

|  |  | Host Lane Interfaces * |  |  | Network Lane Interface |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |
| 400ZR+ | 400G | 1 | 2 | 4 | ZR400-OFEC-16QAM |
| 300ZR+ | 300G |  |  | 3 | ZR300-OFEC-8QAM |
| 200ZR+ | 200G |  | 1 | 2 | ZR200-OFEC-QPSK |
| 100ZR+ | 100G |  |  | 1 | ZR100-OFEC-QPSK |

* Only clients from one column may be multiplexed to a network interface, i.e., no mixed modes are permitted.

OpenZR+ supports the combinations of network framing and modulation modes shown in Table 1-3.

Table 1-2: OpenZR+ Line Encoding, Modulation and Symbol Rates

|  |  | Framing Format | $\begin{aligned} & \text { Symbol Baud } \\ & \text { Rate } \\ & (+/-20 p p m) \end{aligned}$ |  | FEC | $\begin{gathered} \text { Net } \\ \text { Coding } \\ \text { Gain } \\ \left(\begin{array}{c} \text { NCG } C \\ (d B) \end{array}\right. \end{gathered}$ | $\begin{aligned} & \text { Pre- } \\ & \text { FEC } \\ & \text { BER } \end{aligned}$ | Reference Standard |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 400ZR+ | 400G | ZR400-OFEC-16QAM | 60138546798 | 16QAM | OFEC | 11.6 | 2.0E-2 | OpenZR+ |
| 300ZR+ | 300G | ZR300-OFEC-8QAM | 60138546798 | 8QAM |  |  |  |  |
| 200ZR+ | 200G | ZR200-OFEC-QPSK | 60138546798 | QPSK |  |  |  |  |
| 100ZR+ | 100G | ZR100-OFEC-QPSK | 30069273399 | QPSK |  |  |  |  |

### 1.1 400ZR+ Format

This DSP framing format is based on the OIF-ZR400-01.0 frame, adapted with open forward error correction (OFEC), then modulated over a dual polarization coherent interface with absolute (non-differential) 16QAM modulation. The payload can be of the following types:

- A single 400GBASE-R host interface GMP mapped into a clear channel ZR400 frame structure
- $2 \times 200 \mathrm{GBASE}-\mathrm{R}$ host interfaces each individually GMP mapped into a single channelized 400G ZR frame structure.
- $4 \times 100 \mathrm{GBASE}-\mathrm{R}$ host interfaces each individually GMP mapped into a single channelized 400 G ZR frame structure.


### 1.2 300ZR+ Format

This DSP framing format is a reduced bandwidth 300G ZR frame, adapted with open forward error correction (OFEC), then modulated over a dual polarization coherent interface with absolute (non-differential) 8QAM modulation. The payload can be of the following type:

- $3 \times 100 \mathrm{GBASE}-\mathrm{R}$ host interfaces, each individually GMP mapped into a single channelized 300G ZR frame structure.


### 1.3 200ZR+ Format

This DSP framing format is a reduced bandwidth 200G ZR frame, adapted with open forward error correction (OFEC), then modulated over a dual polarization coherent interface with absolute (non-differential) QPSK modulation. The payload can be of the following types:

- A single 200GBASE-R host interface GMP mapped into a clear channel 200G ZR frame structure
- $2 \times 100 \mathrm{GBASE}-\mathrm{R}$ host interfaces, each individually GMP mapped into a single channelized 200G ZR frame structure.


### 1.4 100ZR+ Format

This DSP framing format is a reduced bandwidth ZR100 frame, adapted with open forward error correction (OFEC), then modulated over a dual polarization coherent interface with absolute (non-differential) QPSK modulation. The payload can be of the following types:

- A single 100GBASE-R host interface GMP mapped into a reduced rate 100G ZR frame structure


### 1.5 OpenZR+ Supported Client Modes

The combinations of host interfaces and media side interfaces listed in Table 1-3 may be supported by OpenZR+ implementations. Modes supported are vendor specific.

Table 1-3 Client modes supported by OpenZR+

| Host Side | Datapath |  |  |  |  | Media Side |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Host <br> Interface | Host Map/Demap | MUX/DMUX | Media Framing | FEC <br> Encode/Decode | Modulation | Media <br> Interface |
| $1 \times 400 \mathrm{GBASE}-\mathrm{R}$ | $1 \times 400 \mathrm{ZR}$.ts |  |  |  |  |  |
| $2 \times 200 G B A S E-R$ | $2 \times 200 Z R . t s$ |  | 400ZR | OFEC | 16QAM | ZR400-OFEC-16QAM |
| $4 \times 100 \mathrm{GBASE}-\mathrm{R}$ | $4 \times 100 \mathrm{ZR}$.ts |  |  |  |  |  |
| $3 \times 100 \mathrm{GBASE}-\mathrm{R}$ | $3 \times 100 \mathrm{ZR}$.ts |  | ZR300 | OFEC | 8QAM | ZR300-OFEC-8QAM |
| $1 \times 200 \mathrm{GBASE}-\mathrm{R}$ | $1 \times 200$ ZR.ts |  |  |  |  |  |
| $2 \times 100 \mathrm{GBASE}-\mathrm{R}$ | $2 \times 100 \mathrm{ZR}$.ts |  |  |  |  |  |
| $1 \times 100 \mathrm{GBASE}-\mathrm{R}$ | $1 \times 100 \mathrm{ZR} . \mathrm{ts}$ |  | ZR100 | OFEC | QPSK | ZR100-OFEC-QPSK |

OpenZR+ MSA Specification, version 1.0

## 2 OpenZR+ Block Diagram



Figure 2-1 OpenZR+ Block Diagram

## 3 ZR frame structure

The ZR frame structure is defined prior to OFEC coder adaptation and OFEC processing. Aspects of the ZR frame structure that are specific to ZRx-OFEC-<modulation> are identified, otherwise the ZRx overhead is common to the requirements defined in OIF400ZR-01.0.

This section describes the various framing containers used in the ZR multiplexing / demultiplexing process. The generic ZRx frame structure is shown in Figure 3-1. ZRx frames are based on the OIF 400ZR frame. Organized as m columns x n rows, with the values of $m$ being either 5140 or 10280, and the values on $n$ being 128,192 or 256 , all four ZRx frames are a multiple of 257 bits so that the 257 -bit payloads fit into the designated payload area. Frame overhead bits are in the first row of each frame and include alignment markers (AM), pad (PAD), overhead (OH), and sufficient additional pad bits so that these overhead fields lie on a 257 b boundary in the frame.


Figure 3-1 - Generic ZRx Frame and Multi-Frame structure

### 3.1 257-bit Blocks

The ZR frame payloads are broken down into 257-bit blocks. The number of 257 -bit blocks is the same in all rows of the frame except the first row. The first row is shared with the frame overhead. Table 3-1 defines the number of 257-bit payload blocks for each of the various framing formats.

Table 3-1 - 257-bit blocks in ZRx frames and 4-frame multiframes

| Server <br> Mode | First row 257-bit blocks <br> allocated to AM/PAD/PH <br> and additional pad bits | Payload 257-bit <br> blocks <br> in 1 frame | Payload 257-bit <br> blocks <br> in 4 frames |
| :---: | :---: | :---: | :---: |
| ZR100 | 5 | 2555 | 10220 |
| ZR200 | 10 | 5110 | 20440 |
| ZR300 | 15 | 7665 | 30660 |
| ZR400 | 20 | 10220 | 40880 |

### 3.2 ZR400 Frame

The diagrams in this section have been cloned directly from the 400ZR IA. Figure 3-1 shows the high-level format of the ZR400 frame without any FEC overhead. The frame is constructed using 256 rows of 10280 bits. Each row contains forty 257 -bit blocks. The first twenty 257-bit blocks of the first row are used to support overhead information. The remaining $(255 * 40)+20257$-bit blocks are used for payload. There are sixteen frames in a multi-frame. The GMP algorithm is performed across a group of four consecutive frames.

### 3.3 ZR400 Frame

The 400G frame provides 20 bits of padding between the OH area and the Payload area in order to insure both the OH and payload areas are multiples of 257 -bit blocks. The 400G frame has 20 257-bit blocks of framing and 10220 257-bit blocks of payload. The 400G has four unique blocks of OH and each OH is 40 bytes in size.

Columns

|  | 1 | 1921 | 3840 | 3841 | 5120 |  | 5141 | 10280 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Rows | AM | PAD |  | OH |  | 20 | Payload (5140 bits) |  |
| 1 | Payload (10280 bits) |  |  |  |  |  |  |  |
| 2 | Payload (10280 bits) |  |  |  |  |  |  |  |
| 3 |  |  |  |  |  |  |  |  |
|  | PAYLOAD |  |  |  |  |  |  |  |
| 256 |  |  |  |  |  |  |  |  |

Figure 3-2 - 400G ZR400 Frame

### 3.4 ZR300 Frame

The 300G frame differs slightly from the 400G frame.

- The 300 G frame has 192 rows compared to 256 rows.
- The AM area contains 12 lanes of 120 -bit alignment markers
- The OH area contains 3 blocks of 320 -bits instead of 4 blocks.
- The additional PAD between OH and payload is 15 bits.

OpenZR+ MSA Specification, version 1.0

- The 300 G frame has AM/PAD/OH/additional pad bits in the first 3855 columns of the first row (corresponds to $15 \times 257$-bit blocks) and 7665x 257-bit blocks of payload.


## Columns



| 1 | AM | PAD | OH | 15 | Payload (6425 bits) |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Payload (10280 bits) |  |  |  |  |
| 2 | Payload (10280 bits) |  |  |  |  |
| 3 | PAYLOAD |  |  |  |  |
| 192 |  |  |  |  |  |

Figure 3-3-ZR300 Frame

### 3.5 ZR200 Frame

The 200G frame differs slightly from the 400G frame.

- The 200 G frame has 128 rows compared to 256 rows.
- The AM area contains 8 lanes of 120 -bit alignment markers
- The OH area contains 2 blocks of 320 -bits instead of 4 blocks.
- The additional PAD between OH and payload is 10 bits.
- The ZR200 frame has AM/PAD/OH/additional pad bits in the first 2570 columns of the first row (corresponds to $10 \times 257$-bit blocks) and $5110 \times 257$-bit blocks of payload.


## Columns



Figure 3-4-ZR200 Frame

### 3.6 ZR100 Frame

The 100G frame differs slightly from the 400G frame.

- The 100 G frame has 128 rows compared to 256 rows.
- The 100 G frame has 5140 bits per row compared to 10280 bits per row.
- The AM area contains 4 lanes of 120 -bit alignment markers
- The OH area contains 1 block of 320-bits instead of 4 blocks.
- The additional PAD between OH and payload is 5 bits.
- The 100 G frame has 5257 -bit blocks of OH and 2555 257-bit blocks of payload.

Columns

|  | 1 | 481 | 960 | 961 | 1280 |  | 1285 | 5140 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Rows | AM | PAD |  | OH |  | 5 | Payload (3855 bits) |  |
| 1 | Payload (5140 bits) |  |  |  |  |  |  |  |
| 2 | Payload (5140 bits) |  |  |  |  |  |  |  |
| 3 |  |  |  |  |  |  |  |  |
|  | PAYLOAD |  |  |  |  |  |  |  |
| 128 |  |  |  |  |  |  |  |  |

Figure 3-5-100G ZR400 Frame

### 3.7 Framing Overhead

Figure 3-6 - ZR400 Framing (Overhead) provides an expanded view of the framing area which lives in the beginning of row 1 . The AM section follows the recommendation defined in the 400ZR IA. The OH section follows the recommendation in OIF 400ZR IA but also include GID, PID, MAP and CRC OH bytes. OpenZR+ also defines the Media Slot Identifier (MSI) byte.

OpenZR+ MSA Specification, version 1.0


Figure 3-6 - ZR400 Framing (Overhead)
The ZR frame uses the STAT and GMP JC1-JC6 as defined in OIF 400ZR IA, and MFAS, GID, and PID as defined in G.709. The ZR frame adds the additional MSI field. All other fields are optional or defined as RES.

|  | Overhead Bytes |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MFAS | 1 | 2 | 3 | 4 | 5 | 6 | $7-10$ | $11-12$ | $13-26$ | $27-28$ | $29-40$ |

OpenZR+ MSA Specification, version 1.0

| 0 | MFAS | STAT | GID | GID | GID | RES | PID | RES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | MFAS | STAT | AVAIL |  | JC4 |  | JC1 | RES |
| 2 | MFAS | STAT | RES |  | JC5 |  | JC2 | ES |
| 3 | MFAS | STAT |  |  | JC6 |  | JC3 | RES |
| 4 | MFAS | STAT |  |  | MSI |  |  | RES |
| 5 | MFAS | STAT |  |  | JC4 |  | JC1 | RES |
| 6 | MFAS | STAT |  |  | JC5 |  | JC2 |  |
| 7 | MFAS | STAT |  |  | JC6 |  | JC3 |  |

Figure 3-7 - ZR400 Overhead

### 3.8 Media Slot Identifier (MSI) / Tributary Slot Identifier (TSI)

- The Media Slot Identifier (MSI) Row 4 / Byte 5 and follow example of PT22 MSI Byte as defined in G. 709 Clause 20.4.1.1.
- OpenZR+ defines a 1:1 mapping between the host port and the Media Slot Identifier. These are then referred to as a Time Slot Instance TSI.
- Optionally a crossbar can be inserted between TSIs and the MSIs.
- The transmitter can send $\mathrm{Cm} /$ Cnd information in all OH locations, but the receiver must choose only one and the selection should be to choose $\mathrm{Cm} /$ Cnd from lowest ordinal OH assigned to the port.
- A port is assigned the number of tributaries required to accommodate the port rate.
- The tributaries are ordered in time with the lower ordinals first in time.
- The tributaries need not be consecutive to avoid bandwidth fragmentation.

The following Table is an example of the MSI OH byte value for various configurations of a ZR400 frame.

| MODE | OH1 | OH2 | OH3 | OH4 |
| :---: | :---: | :---: | :---: | :---: |
| $1 \times 400 \mathrm{G}$ | $0 x c 0$ | $0 x c 0$ | $0 x c 0$ | $0 x c 0$ |
| $2 \times 200 \mathrm{G}$ | $0 x c 0$ | $0 x c 0$ | $0 x c 1$ | $0 x c 1$ |
| $4 \times 100 \mathrm{G}$ | $0 x c 3$ | $0 x c 2$ | $0 x c 1$ | $0 x c 0$ |

Table 3-2: MSI OH

## 4 Datapath Processing

For OpenZR+ applications The TRX maps and multiplexes up to four 100GBASE-R, two 200GBASE-R or one 400GBASE-R Host/Client signals into a channelized ZR container. Each channel is GMP mapped and 257 b multiplexed into tributary unit(s) of a $200 \mathrm{G}, 300 \mathrm{G}$, or 400 G ZR frame structure. The $200-400 \mathrm{G}$ ZR frame overhead fields (AM, PAD, and OH) are partitioned in 10-bit tributary ordered slices. The ZR frame is then adapted with OpenFEC (OFEC). OFEC is required to support Metro/Reginal and long-haul reaches. OFEC can also provide additional margin when operating on a 75 GHz grid.
The scope of this specification is how the node internal set of $n \times[100,200,400]$ GBASER signals are mapped into $m(m=[n / x])$ ZR-x-OFEC-<modulation> signals, with each ZR-x signal containing " $x$ " (frame/multi-frame aligned interleaved) ZR tributary mapped signals ( $x \geq 1$ ).
The digital formatting and processing done by the ZR-x-OFEC-<modulation> port function is shown in Figure 4-1.


Figure 4-1: Digital port functions for a single ZRx-OFEC-mQAM signal

### 4.1 OpenZR+ Multiplexing/Demultiplexing (ZRMAP/ZRDEMAP)

OpenZR+ supports the mapping / de-mapping (ZRMAP/ZRDEMAP) and multiplexing / demultiplexing (ZRMUX/ZRDMUX) of up to $1 \times 400 \mathrm{GBASE}-\mathrm{R}, 1$ or $2 \times 200 \mathrm{GBASE}-\mathrm{R}$, or $1 . .4 \times 100 \mathrm{GBASE}-\mathrm{R}$ host interfaces. Combinations of 200GBASE-R and 100GBASER host interfaces are also feasible, but outside the scope of this specification release. The Ethernet host interfaces are assumed to be within $+/-100 \mathrm{ppm}$ of each other, but otherwise asynchronously framed.
A high-level list of functions provided by OpenZR+ Muxceivers/Muxponders include:

- Multiplexing/Demultiplexing of Ethernet frames in 257-bit blocks.
- GMP mapping of Ethernet frames into n x 100 G tributary slots.
- Reflection of PHY fault in reverse direction.
- Forward and reverse handling of LD, RD indicators, and local handling of FEC Degrade detection. ZR overhead information insertion/removal (MFAS, STAT, GID, PID, MSI, and GMP JC1-JC6).
- PRBS generation/checking for the ZR payload.
- Local Fault sourcing for tributary slots in alarm state.


### 4.2 GMP Definition

The ZR400 frames operate at a fixed server frequency. The server frequency is higher than what is required to carry the payload. The difference between the input payload and the payload capacity is handled using GMP stuffing blocks. The client traffic is mapped into the ZR400 payload using GMP blocks. The GMP processor calculates the number of active and stuffing GMP blocks for each frame. The active GMP blocks are filled with client traffic while the stuffing GMP blocks are filled with a fixed pattern of all zeros.
The GMP process is defined in G. 709 Annex D.

### 4.3 GMP Blocks

A consecutive set of 257 -blocks are combined to form a GMP block. The ZR400 frame can support time-division multiplexing of both $100 \mathrm{G}, 200 \mathrm{G}$ and 300 G clients into the ZR400 container frame. Each client rate uses a different number of 257 -bit blocks for each GMP block. The GMP algorithm is used across a period of four ZR400 frames. The number of GMP blocks for each client rate is shown in Table 4-1 - GMP Block Counts. All client rates have the same number of GMP blocks in four frames. This GMP block count serves as the $\mathrm{Pm}_{\mathrm{m}, \text { server }}$ parameter in the GMP algorithm.

|  | Number of <br> 257-bit <br> Blocks in 1 <br> GMP Block | Number of <br> 257-bit <br> Blocks <br> in 4 Frames | Number of <br> GMP blocks <br> In 4 Frames |
| :---: | :---: | :---: | :---: |
| Client Mode | 1 | 10220 | 10220 |
| 100 G | 2 | 20440 | 10220 |
| 200 G | 3 | 30660 | 10220 |
| 300 G | 4 | 40880 | 10220 |
| 400 G |  |  |  |

Table 4-1 - GMP Block Counts

### 4.4 Mapping of client traffic into ZR400

Figure 4-2 - Mapping of Client Traffic into ZR400 describes how data and stuffing are used in the ZR400 frame. For the 400 G container, each GMP block is $4 \times 257$-bit blocks. Each GMP block containers either data or stuffing. The GMP mapping scheme operates over a period of four ZR400 frames. The number of stuffing blocks in a frame is defined by the Cm value that is stored in the ZR 400 frame OH . A new Cm value is made available every four ZR400 frames.


Figure 4-2 - Mapping of Client Traffic into ZR400
The number of 257-bit blocks in a GMP block is a function of the ZR400 container rate as defined in Table 4-1 - GMP Block Counts.

The ZR400 GMP overhead for this mapping consists of:

- Three justification control (JC1, JC2, JC3) bytes carrying the value of GMP overhead Cm;
- Three justification control (JC4, JC5, JC6) bytes carrying the value of GMP overhead $\sum$ CnD.


Figure 4-3 - Justification Control
The JC1, JC2 and JC3 bytes consist of a 14-bit Cm field (bits C1, C2, .., C14), a 1-bit Increment Indicator (II) field, a 1-bit Decrement Indicator (DI) field and an 8-bit CRC-8 field which contains an error check code over the JC1, JC2 and JC3 fields.

The JC4, JC5 and JC6 bytes consist of a 7-bit CnD field (bits D1, D2, .., D7), a 4-bit CRC8 field which contains an error check code over the JC4, JC5 and JC6 fields.
The ZR400 payload consists of some number of GMP blocks (see Table 4-1 - GMP Block Counts). Each GMP block consists of some number of 257-bits blocks (see Table 4-1 GMP Block Counts).

The ZR400 signal is created from a locally generated clock which is independent of the client signal. The client signal is adapted to the locally generated ZR400 clock by means of a generic mapping procedure (GMP) as specified in G. 709 Annex D. The generic mapping process generates the $\mathrm{Cm}(\mathrm{t})$ and $\mathrm{CnD}(\mathrm{t})$ information, once per four ZR400 frames, according to Annex D and encodes this information in the justification control overhead JC1/JC2/JC3 and JC4/JC5/JC6. The de-mapping process decodes $\mathrm{Cm}(\mathrm{t})$ and $\mathrm{CnD}(\mathrm{t})$ from $\mathrm{JC} 1 / \mathrm{JC} 2 / \mathrm{JC} 3$ and $\mathrm{JC} 4 / \mathrm{JC} 5 / \mathrm{JC} 6$ and interprets $\mathrm{Cm}(\mathrm{t})$ and $\mathrm{CnD}(\mathrm{t})$ according to Annex D . CRC-8 shall be used to protect against an error in JC1/JC2/JC3 and CRC4 protect against and error JC4/JC5/JC6 signals.

### 4.5 Generic Mapping Procedure Principles

Reference: G. 709 Annex D.
The values of $n, m, M$, $f_{\text {client, }}$ fserver, $T_{\text {server, }} \mathrm{B}_{\text {server, }}$, and $\mathrm{P}_{\mathrm{m}, \text { server }}$ for client mapping into the ZR400 are shown in Table 4-2.

OpenZR+ MSA Specification, version 1.0

| Ref | GMIP Parameter | Formul a | Client Mapping |  |  | $\begin{gathered} \text { Unit } \\ \text { s } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{aligned} & \text { 400GD to } \\ & \text { ZR400 } \end{aligned}$ | $\begin{aligned} & \text { 200GE to } \\ & \text { ZR200 } \end{aligned}$ | $\begin{aligned} & \text { 100GE to } \\ & \text { ZRI } 100 \end{aligned}$ |  |
| fclient | nominal client information bit rate |  | 401,542,892,456.055 | 200,771,446,228.027 | 100,390,625,000.000 | b/s |
| $\Delta \mathrm{f}_{\text {client }}$ | client bit rate tolerance |  | 100 | 100 | 100 | ppm |
| $\mathrm{f}_{\text {server }}$ | server nominal bit rate |  | 402,489,753,309.729 | 201,244,876,654.865 | 100,622,438,327.432 | b/s |
| $\Delta \mathrm{f}_{\text {server }}$ | server bit rate tolerance |  | 20 | 20 | 20 | ppm |
| $\mathrm{T}_{\text {server }}$ | period of the server multi-frame | $\mathrm{B}_{\text {server }} / \mathrm{f}_{\text {server }}$ | 26.154 | 26.154 | 26.154 | $\mu \mathrm{s}$ |
| $B_{\text {server }}$ | number of bits per server multi-frame |  | 10,526,720 | 5,263,360 | 2,631,680 | b |
| Oserver | number of overhead bits per server multiframe |  | 20,560 | 10,280 | 5,140 | b |
| $\mathrm{P}_{\text {server }}$ | number of payload bits per server multiframe | $B_{\text {server }}$ - <br> $\mathrm{O}_{\text {server }}$ | 10,506,160 | 5,253,080 | 2,626,540 | b |
| $\mathrm{f}_{\mathrm{p}, \mathrm{server}}$ | nominal server payload bit rate | $\mathrm{f}_{\text {server }} \mathrm{X}$ <br> $\mathrm{P}_{\text {server }} /$ <br> $B_{\text {server }}$ | 401,703,640,510.296 | 200,851,820,255.148 | 100,425,910,127.574 | b/s |
| m | GMP data/stuff granularity |  | 1,028 | 514 | 257 | b |
| M | m and n ratio | $\mathrm{m} / \mathrm{n}$ | 128 | 128 | 128 |  |
| $\underset{\text { er }}{\mathrm{P}_{\mathrm{m}, \mathrm{serv}}}$ | Max number of (m bits) in server payload area | $\mathrm{P}_{\text {server }} / \mathrm{m}$ | 10,220 | 10,220 | 10,220 | $\begin{array}{r} \text { 1028b } \\ \text { blocks } \end{array}$ |
| $\mathrm{Cm}_{\mathrm{m}}$ | Number of client m-bit data entities per server multi-frame at nominal rates |  |  |  |  |  |
| Cm,nom | Cm value at nominal client and server bit rates | $\begin{gathered} \left(\mathrm{f}_{\text {client }} /\right. \\ \left.\mathrm{f}_{\mathrm{p}, \text { server }}\right) \times \\ \mathrm{P}_{\mathrm{m}, \mathrm{server}} \end{gathered}$ | 10215.910 | 10215.910 | 10216.409 |  |
| $\mathrm{Cm}_{\mathrm{m} \text { min }}$ | Cm at min client, max server rates | $\begin{gathered} \mathrm{C}_{\mathrm{m}, \text { nom }} \times(1- \\ \left.\Delta \mathrm{f}_{\text {client }}\right) /(1 \\ \left.+\Delta \mathrm{f}_{\text {server }}\right) \end{gathered}$ | 10214.684 | 10214.684 | 10215.183 |  |
| $\mathrm{Cm}_{\text {max }}$ | Cm at max client, min server rates | $\begin{aligned} & \mathrm{C}_{\mathrm{m}, \mathrm{nom}} \times(1 \\ & \left.+\Delta \mathrm{f}_{\text {client }}\right) / \\ & \left(1-\Delta \mathrm{f}_{\text {server }}\right) \end{aligned}$ | 10217.136 | 10217.136 | 10217.635 |  |
| $\mathrm{Cm}_{\mathrm{m} \text { min }}$ | integer value of Cm,min | $\left\lfloor\mathrm{C}_{\text {,min }}\right\rfloor$ | 10214 | 10214 | 10215 |  |
| $\mathrm{Cm}_{\text {max }}$ | rounded up value of Cm,max | $\left\lceil\mathrm{Cm}_{\mathrm{m}, \text { max }}\right\rceil$ | 10218 | 10218 | 10218 |  |
| n | GMP justification accuracy, n bit data entity |  | 8.03125 | 4.01563 | 2.00781 | b |
| $P_{n, \text { serve }}$ | Max number of ( n bits) data entities in the server payload area | $\mathrm{P}_{\text {server }} / \mathrm{n}$ | 1,308,160 | 1,308,160 | 1,308,160 | $\begin{gathered} 8.0312 \\ 5 \mathrm{~b} \\ \text { blocks } \end{gathered}$ |

OpenZR+ MSA Specification, version 1.0

| Ref | GMIP Parameter | Formul | Client Mapping |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{aligned} & \text { 400GE to } \\ & \text { ZR400 } \end{aligned}$ | $\begin{aligned} & \text { 200GE to } \\ & Z R 200 \end{aligned}$ | $\begin{aligned} & \text { 100GE to } \\ & \text { ZRI } 100 \end{aligned}$ |  |
| $\mathrm{C}_{\mathrm{n}}$ | Number of client n -bit data entities per server multi-frame at nominal rates |  |  |  |  |  |
| $\mathrm{C}_{\mathrm{n}, \mathrm{nom}}$ | Cn value at nominal client and server bit rates | $\begin{gathered} \left(\mathrm{f}_{\text {client }} /\right. \\ \left.\mathrm{f}_{\mathrm{p}, \text { server }}\right) \times \\ \mathrm{P}_{\mathrm{n}, \text { server }} \end{gathered}$ | 1,307,636.519 | 1,307,636.519 | 1,307,700.372 |  |
| $\mathrm{C}_{\mathrm{n}, \text { min }}$ | Cn at min client, max server rates | $\begin{gathered} \mathrm{C}_{\mathrm{n}, \mathrm{nom}} \times(1- \\ \left.\Delta \mathrm{f}_{\text {client }}\right) /(1 \\ \left.+\Delta \mathrm{f}_{\text {server }}\right) \end{gathered}$ | 1,307,479.606 | 1,307,479.606 | 1,307,543.451 |  |
| $\mathrm{C}_{\mathrm{n}, \text { max }}$ | Cn at max client, min server rates | $\begin{gathered} \mathrm{C}_{\mathrm{n}, \mathrm{nom}} \times(1+ \\ \left.\Delta \mathrm{f}_{\text {client }}\right) /(1- \\ \left.\Delta \mathrm{f}_{\text {server }}\right) \end{gathered}$ | 1,307,793.439 | 1,307,793.439 | 1,307,857.299 |  |
| CnD | remainder of $\mathrm{C}_{\mathrm{n}}$ and $\mathrm{C}_{\mathrm{m}}$ |  | 0.910305637 | 0.910305637 | 0.409153740 |  |
| CnD | integer value of $\mathrm{CnD}^{\text {d }}$ |  |  |  |  |  |
| $\Sigma \mathrm{C}_{\mathrm{nD}}$ | accumulated value of $\mathrm{C}_{\mathrm{nD}}$ |  | 127 | 127 | 127 |  |

Table 4-2 - Client and ZRx GMP parameter values
Where,

- Nominal client information bit rates for 400GE and 200GE are nominal 400GBASE-R and 200GBASE-R rates after RS $(544,514)$ FEC and AM removal. Nominal client information bit rate for 100GE clients with FEC is the nominal 100GBASE-R rate after RS $(544,514)$ FEC removal. For 100GE clients without FEC, it is the nominal 100GBASE-R rate after transcoding from 64B66B to 256B257B blocks.
- Server is ZR400, ZR200 or ZR100 4-frame multi-frame (both payload and overhead), with fserver

- Server payload is ZR400, ZR200 or ZR100 4-frame multi-frame payload (before AM/PAD/OH insert), with $\mathrm{f}_{\mathrm{p}, \text { server }}$ nominal bit rate, $\Delta \mathrm{f}_{\text {server }}$ bit rate tolerance and $\mathrm{P}_{\text {server }}$ number of bits per server 4frame multi-frame payload area.
- The maximum number_of_m [=1028] bit GMP data entities per 4-frame multi-frame payload is $\mathrm{P}_{\mathrm{m} \text {,server }}[=10220$, or 5110 , or 2555$]$.
- For ZR400, ZR200 or ZR100, we use $n=[\mathrm{m} / 128]=[4 \times 257-$ bit $] / 128=8.03125$ UI that is used as a phase unit " $n$-bit equivalent" for $C_{n}$ parameter. $C_{n}$ indicates the number of " $n$-bit equivalent" of the xGBASE-R client per ZRx 4-frame multi-frame server payload. It can be used as a finer phase indicator to encode the client clock at the GMP mapper.
- So, $\mathrm{C}_{\mathrm{n}, \mathrm{nom}}=128 \times \mathrm{C}_{\mathrm{m}, \mathrm{nom}} ; \mathrm{C}_{\mathrm{n}, \min }=128 \times \mathrm{C}_{\mathrm{m}, \min } ; \mathrm{C}_{\mathrm{n}, \max }=128 \times \mathrm{C}_{\mathrm{m}, \max }$
- $\mathrm{C}_{\mathrm{m}}=\mathrm{P}_{\mathrm{m}, \text { server }} \times$ [client_bit_rate / Server_Payload_bit_rate].
- $\mathrm{C}_{\mathrm{m}}$ is an integer value indicating to every ZRx frame the number of $m$-bit client blocks carried [m $=4 \times 257 \mathrm{~b}=1028 \mathrm{~b}]$ in this ZRx 4 -frame server multi-frame payload $=$

- $\quad \mathrm{C}_{\mathrm{m}} \leq \mathrm{P}_{\mathrm{m}, \text { server }}$ and is a value varying between $\mathrm{C}_{\mathrm{m}, \min }$ and $\mathrm{C}_{\mathrm{m}, \max }$ for the given client and payload type, due to client and payload bit rate tolerance range ( $+/-100 \mathrm{ppm}$ and $+/-20 \mathrm{ppm}$ ).


### 4.6 Stuffing Locations

Table 4-3 shows the location of the "stuff" GMP blocks for a few specific Cm values.

| Cm | Stuffi Locations (index values of $4 \times 257 \mathrm{~b}$ <br> locations in 4 frame multi-firame) |
| :--- | :--- |
| 10220 | N/A |
| 10219 | 1 |
| 10218 | 1,5111 |
| 10217 | $1,3407,6814$ |
| 10216 | $1,2556,5111,7666$ |
| 10215 | $1,2045,4089,6133,8177$ |
| 10216 | $1,1704,3407,5111,6814,8517$ |

Table 4-3 - GMP STUFF Locations of ZR400

## 5 Multiplexing

Multiplexing of 100 G and 200 G clients into the ZR400 frame is performed using simple time division multiplexing of the 257 -bit blocks in the ZR payload. A ZR400 frame has four sets of overhead $(\mathrm{OH})$ available in the first row to support multiplexing of GMP for up to four clients.
There are 10220 257-bit blocks in a ZR400 frame. This number is divisible by both 4 and 2. Row 1 has 20 blocks, while all other rows have 40 blocks. The ZR400 stuffing location uses some number of consecutive 257-bit blocks based upon ZR400 rate as shown in Table 4-1 - GMP Block Counts. The ZR400 frame has 4 unique OH chunks of 40 bytes. The GMP six justification control bytes are distributed inside the OH using four consecutive frames. There are two GMP values processed during the 8 -frame ZR400 multi-frame.

OpenZR+ MSA Specification, version 1.0


Figure 5-1 - 100G, and 200G Multiplexing in ZR400 Frame

### 5.1 ZR400 Frame Structure

The ZR400 frame structure is 10280 b $\times 256$ rows with 1920 b columns of AM, 1920b columns of PAD, and 1280b of OH and 20-bits of additional pad located in row 1 bits 5121 through 5140. The additional pad is to align the payload area on a 257b boundary. Parity is added by the OFEC block and interleaver stages downstream of the ZR400 frame structure.

The ZR400 frame structure is shown in Figure 5-2.


Figure 5-2: ZR400- frame structure

- There are 10220257 -bit blocks in a ZR400 frame. This number is divisible by both 4 and 2 .
- Row 1 has 20-blocks, all other rows have 40 blocks.
- The ZR400 stuffing location uses 4 consecutive 257-bit blocks.
- The ZR400 frame has 4 unique OH chunks of 40 bytes. The GMP is distributed across 4 consecutive frames in the 40 -byte OH . There are 2 GMP values processed during the 8 frame ZR400 multi-frame.
- Multiplexing scheme defines $4 \times 100 \mathrm{G}$ and $2 \times 200 \mathrm{G}$.
- $\mathrm{Cm} /$ Cnd distributed across OH in 4 frames.
- $\mathrm{Cm} /$ Cnd value extracted in current 4 frame set used in next 4 frame set.


### 5.1.1 400G Container Multiplexing

This section describes how 100 G , and 200G, clients are multiplexed in a ZR400 container.
For multiplexed signals, the AM, PAD, and OH from four frame/multi-frame aligned ZR100 frames or from two frame/multi-frame aligned ZR200 frames and additional pad are 10 -bit interleaved. The payload area is 257 b interleaved.

This process is shown in Figure 5-3.


Figure 5-3: 4 Interleaved ZR100 frame to ZR400 frame structure

- 4100 G tributaries numbered T1, T2, T3, T4.
- 10220 257-block locations are numbered 1 through 10220, ordered left to right, top to bottom in ZR400 frame view.
- Each tributary assigned 2555 257-bit blocks.
- T1 consumes locations $1,5,9, \ldots, 10217$
- T2 consumes locations $2,6,10, \ldots, 10218$
- T3 consumes locations $3,7,11, \ldots, 10219$
- T4 consumes locations $4,8,12, \ldots, 10220$
- Simple round-robin ordering.
- 4 Unique 40 -byte OH sections in each ZR400 frame, ordered left to right, in ZR400 frame view, numbered $\mathrm{OH} 1, \mathrm{OH} 2, \mathrm{OH} 3, \mathrm{OH} 4$
- $4 \times 257$-bit stuffing locations.
- Each $4 \times 257$-bit stuffing block divided into 4 stuffing locations numbered S1 through S4, ordered left to right in ZR400 frame.
- Each tributary assigned 1257 -bit block of stuffing.
- T1 uses S1
- T2 uses S2
- T3 uses S3
- T4 uses S4
- Stuffing location defined by CM value of each OH .
- Every $4 \times 257$-bit stuffing location will have mix of data and stuff when multiplexing in play.
- 4 Unique OH numbered $\mathrm{OH} 1, \mathrm{OH} 2, \mathrm{OH} 3, \mathrm{OH} 4$.
- T1 uses OH1
- T2 uses OH2
- T3 uses OH3
- T4 uses OH4


### 5.1.2 $1 \times 400 \mathrm{G}$ Data Multiplexing

- 1400 G client numbered CL1.
- 400 G client assigned all four tributaries.
- The GMP for the client is stored in the assigned overhead.


### 5.1.3 $2 \times 200 \mathrm{G}$ Data Multiplexing

- 2200 G clients numbered CL1, CL2.
- Each client assigned two tributaries and two corresponding overhead.
- Tributaries assigned to client need not be consecutive, but data is ordered with first data in time assigned to lower ordinal tributary.
- The GMP for the client is stored in the overhead with the lowest ordinal number.


### 5.1.4 $4 \times 100 \mathrm{G}$ Data Multiplexing

- 4100 G clients numbered CL1, CL2, CL3, CL4.
- Each client assigned one tributary and one corresponding overhead.
- The GMP for the client is stored in the overhead with the lowest ordinal number ( OH 1 ).
- Alignment markers are inserted in the 100G data stream to transparently pass the BIP3/BIP7 values across transport layer.
- The alignment marker follows the rules defined in 802.3 Clause 91 and G. 709 Annex E with one exception.
- When looking at 802.3 Clause 91.5.2 Figure 91-4; the values in amp_tx_0,1,2,3,16,17,18,19 are replaced with the unique values for those 8 logical lanes, as defined by Clause 82.2.7 Table 82-2.
- The alignment markers consume 5 consecutive 257 -bit blocks using the intervals defined in Clause 91.
- The alignment markers are constructed using 128 10-bit symbols followed by the 5 -bit pad as defined in Clause 91. The 128 10-bit symbols plus 5-bit pad combine to form 5257 -bit blocks.
- The order of the 10 -bit symbols can be referenced using 802.3 Clause 91 Figure $91-4$ with the symbols extracted top-to-bottom, left-to-right from the box in this figure with the 5-bit pad following at the end.


### 5.2 ZR300 Frame Structure

The ZR300 frame structure is 10280 b $\times 192$ rows with 1440 b columns of AM, 1440b columns of PAD, and 960 b of OH and 15 -bits of additional pad located in row 1 bits 3841 through 3855 . The additional pad is to align the payload area on a 257 b boundary. Parity is added by the OFEC block and interleaver stages downstream of the ZR300 frame structure.

The ZR300 frame structure is shown in Figure 5-4.


Figure 5-4: ZR300 frame structure

### 5.2.1 300G Container Multiplexing

This section describes how 100G and 300G clients are multiplexed in a ZR300 container.
For multiplexed signals, the AM, PAD, and OH, from three frame/multi-frame aligned ZR100 frames and additional pad are 10b interleaved. The payload area is 257 b interleaved.
This interleaving process is shown in Figure 5-5.


Figure 5-5: Three interleaved ZR100 frames to ZR300 frame structure

- 3 100G tributaries numbered T1, T2, T3.
- 7665 257-block locations are numbered 1 through 7665, ordered left to right, top to bottom in ZR400 frame view.
- Each tributary assigned 2555 257-bit blocks.
- T1 consumes locations $1,4,7, \ldots, 7663$
- T 2 consumes locations $2,5,8, \ldots, 7664$
- T3 consumes locations 3,6,9,...,7665
- Simple round-robin ordering.
- 3 Unique 40 -byte OH sections in each ZR300 frame, ordered left to right, in ZR300 frame view, numbered OH1, OH2, OH3.
- $3 \times 257$-bit stuffing locations.
- Each $3 \times 257$-bit stuffing block divided into 3 stuffing locations numbered S1 through S3, ordered left to right in ZR300 frame.
- Each tributary assigned 1257 -bit block of stuffing.
- T1 uses S1
- T2 uses S2
- T3 uses S3
- Stuffing location defined by CM value of each OH .
- Every $3 \times 257$-bit Stuffing location will have mix of data and stuff when multiplexing in play.
- 3 Unique OH numbered $\mathrm{OH} 1, \mathrm{OH} 2, \mathrm{OH} 3$.
- T1 uses OH1
- T 2 uses OH 2
- T3 uses OH3


### 5.2.2 $3 \times 100 \mathrm{G}$ Data Multiplexing

- 3100 G clients numbered CL1, CL2, CL3.
- Each client assigned one tributary and one corresponding overhead.
- The GMP for the client is stored in the assigned overhead.
- Alignment markers are inserted in the 100 G data stream to transparently pass the BIP3/BIP7 values across transport layer.
- The alignment marker follows the rules defined in 802.3 Clause 91 and G.709 Annex E with one exception.
- When looking at 802.3 Clause 91.5.2 Figure 91-4; the values in amp_tx_0,1,2,3,16,17,18,19 are replaced with the unique values for those 8 logical lanes, as defined by Clause 82.2.7 Table 82-2.
- The alignment markers consume 5 consecutive 257-bit blocks using the intervals defined in Clause 91.
- The alignment markers are constructed using 128 10-bit symbols followed by the 5 -bit pad as defined in Clause 91. The 128 10-bit symbols plus 5 -bit pad combine to form 5257 -bit blocks.
- The order of the 10 -bit symbols can be referenced using 802.3 Clause 91 Figure $91-4$ with the symbols extracted top-to-bottom, left-to-right from the box in this figure with the 5 -bit pad following at the end.

OpenZR+ MSA Specification, version 1.0

### 5.3 ZR200 Frame Structure

The ZR200 frame structure is a block format of 10280 -bit columns $\times 128$ rows with 960 b columns of AM, 960b columns of PAD, and 640 b of OH and 10 -bits of additional pad located in row 1 bits 1921 through 2560. The additional pad is to align the payload area on a 257 b boundary. Parity is added by the OFEC block and interleaver stages downstream of the ZR200 frame structure.

The ZR200 frame structure is shown in Figure 5-6.


Figure 5-6: ZR200 frame structure

### 5.3.1 200G Container Multiplexing

This section describes how 100 G and 200G clients are multiplexed in a ZR200 container.
For multiplexed signals, the AM, PAD, and OH , from two frame/multi-frame aligned ZR100 frames and additional pad are 10b interleaved. The payload area is 257 b interleaved.
The interleaving process is shown in Figure 5-7.


Figure 5-7: Two interleaved ZR100 frames to a ZR200 frame structure

- 2100 G tributaries numbered T1, T2.
- 5110257 -block locations are numbered 1 through 5110, ordered left to right, top to bottom in ZR400 frame view.
- Each tributary assigned 2555 257-bit blocks.
- T1 consumes locations $1,3,5, \ldots, 5109$
- T 2 consumes locations $2,4,6, \ldots, 5110$
- Simple round-robin ordering.
- 2 Unique 40 -byte OH sections in each ZR400 frame, ordered left to right, in ZR400 frame view, numbered $\mathrm{OH} 1, \mathrm{OH} 2$.
- $2 \times 257$-bit stuffing locations.
- Each $2 \times 257$-bit stuffing block divided into 2 stuffing locations numbered S1 through S2, ordered left to right in ZR400 frame.
- Each tributary assigned 1257 -bit block of stuffing.
- T1 uses S1
- T2 uses S2
- Stuffing location defined by CM value of each OH.
- Every $2 \times 257$-bit Stuffing location will have mix of data and stuff when multiplexing in play.
- 2 Unique OH numbered $\mathrm{OH} 1, \mathrm{OH} 2$.
- T1 uses OH1
- T 2 uses OH 2


### 5.3.2 $1 \times 200 \mathrm{G}$ Data Multiplexing

- 1200 G client numbered CL1.
- 200 G client assigned all two tributaries.
- The GMP for the client is stored in the assigned overhead.


### 5.3.3 $2 \times 100 \mathrm{G}$ Data Multiplexing

- 2100 G clients numbered CL1, CL2.
- Each client assigned one tributary and one corresponding overhead.
- The GMP for the client is stored in the overhead with the lowest ordinal number $(\mathrm{OH} 1)$.
- The alignment marker follows the rules defined in 802.3 Clause 91 and G. 709 Annex E with one exception.
- When looking at 802.3 Clause 91.5.2 Figure 91-4; the values in amp_tx_0, 1,2,3,16,17,18,19 are replaced with the unique values for those 8 logical lanes, as defined by Clause 82.2.7 Table 82-2.
- The alignment markers consume 5 consecutive 257-bit blocks using the intervals defined in Clause 91.
- The alignment markers are constructed using 128 10-bit symbols followed by the 5 -bit pad as defined in Clause 91. The 128 10-bit symbols plus 5-bit pad combine to form 5 257-bit blocks.
- The order of the 10 -bit symbols can be referenced using 802.3 Clause 91 Figure $91-4$ with the symbols extracted top-to-bottom, left-to-right from the box in this figure with the 5 -bit pad following at the end.


### 5.4 ZR100 frame structure

The ZR100 frame structure is similar to the FlexO-1 frame structure defined in G.709.1 (G.709.1/Y.1331(18)_F8-1) copied as Figure 5-8 for reference. FlexO is a block format of 5140 -bit columns $\times 128$ rows. The ZR100 frame structure in Figure 5-9 is also a block format of 5140 -bit columns $\times 128$ rows, however, it includes a 5 -bit pad located in row 1 bits 1281 through 1285. The additional pad is to align the payload area on a 257 b boundary.


Figure 5-8: FlexO frame structure (reference)


Figure 5-9: ZR100 frame structure

### 5.4.1 100G Container Multiplexing

This section describes how 100 G is multiplexed in a 100 G ZR container.

- 1100 G tributaries numbered T1.
- 2555 257-bit block locations are numbered 1 through 2555 , ordered left to right, top to bottom in ZR400 frame view.
- Each tributary assigned 2555 257-bit blocks.
- T1 consumes locations $1,2,3, \ldots, 2555$
- 1 Unique 40 byte OH sections in each ZR400 frame, ordered left to right, in ZR400 frame view, numbered OH 1 .
- $1 \times 257$-bit stuffing locations numbered S1.
- Each tributary assigned 1 257-bit block of stuffing.
- T1 uses S1
- Stuffing location defined by CM value of each OH .
- 1 Unique OH numbered OH1.
- T1 uses OH1


### 5.4.2 1x100G Data Multiplexing

- 1100 G client numbered CL1.
- 1100 G tributaries numbered T1.
- 1 Unique OH numbered OH 1 .
- CL1 assigned tributary T 1 and overhead OH1.
- The GMP for the client is stored in the overhead with the lowest ordinal number $(\mathrm{OH} 1)$.
- The alignment marker follows the rules defined in 802.3 Clause 91 and G. 709 Annex E with one exception.
- When looking at 802.3 Clause 91.5.2 Figure 91-4; the values in amp_tx_0,1,2,3,16,17,18,19 are replaced with the unique values for those 8 logical lanes, as defined by Clause 82.2.7 Table 82-2.
- The alignment markers consume 5 consecutive 257-bit blocks using the intervals defined in Clause 91.

OpenZR+ MSA Specification, version 1.0

- The alignment markers are constructed using 128 10-bit symbols followed by the 5 -bit pad as defined in Clause 91. The 128 10-bit symbols plus 5 -bit pad combine to form 5257 -bit blocks.
- The order of the 10 -bit symbols can be referenced using 802.3 Clause 91 Figure $91-4$ with the symbols extracted top-to-bottom, left-to-right from the box in this figure with the 5 -bit pad following at the end


## 6 ZRx adaptation to OFEC

The ZRx frame structure is adapted to the OFEC Coder block by adding padding after every $\mathrm{n} \times 10280$-bit rows. The data stream is then scrambled and passed to the OFEC encoder. Table 6-1 shows the relationships between the OFEC-x Coder Payload and the ZRx frame structure. The ZRx-OFEC is aligned and synchronized to the DSP frame, therefore the number of PAD bits, OFEC block and payload bits per DSP frame is modulation dependent.

|  | ZRx <br> Rows | PAD <br> (bits) | OFEC-x coder <br> payload (bits) | OFEC <br> Blocks | ZRx <br> (bits) | Modulation <br> Format |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| ZR400 | 116 rows | 992 | $1,193,472$ | 168 | $1,376,256$ | 16QAM |
| ZR300 | 87 rows | 744 | 895,104 | 126 | $1,032,192$ | 8 QAM |
| ZR200 | 58 rows | 496 | 596,736 | 84 | 688,128 | QPSK |
| ZR100 | 116 rows | 496 | 596,736 | 84 | 688,128 | QPSK |

Table 6-1: OFEC adaptation rates
The digital formatting and processing done by the DSP to adapt the FlexO-x to the OFEC Coder is shown in Figure 6-1.


Figure 6-1: Digital processes of ZR-x to ZRx-OFEC adaptation.

### 6.1 Padding Insertion/Removal

The OFEC block processing is aligned and synchronized to the DSP super-frame (See Section 9.1). Pad bits are appended to the ZRx framed data to enable this alignment. The PAD is removed after the decoder on the receive interface. The PAD is an all-zero field that gets scrambled prior to encoding and removed after decoding and descrambling.

### 6.2 ZR400 adaptation to ZR400-OFEC-16QAM

For ZR400 adaptation to a ZR400-OFEC-16QAM line interface, 116 rows of ZR400 information ( $1,192,480$ bits) plus 992 bits of pad ( $1,193,472$ bits total) are scrambled and then bitwise demultiplexed to two OFEC encoders, each of which operate on input blocks
of 3,552 bits and produce output blocks of 4096 bits. To process the $1,193,472$ bits each encoder operates on 168 input blocks of 7104 bits.

Figure 6-2 shows the adaptation of the ZR400 frame structure to the OFEC input block structure.


Figure 6-2: ZR400 adaptation to a ZR400-OFEC-16QAM line interface

### 6.3 ZR300 adaptation to ZR300-OFEC-8QAM

For ZR300 adaptation to an ZR300-OFEC-8QAM line interface 87 rows of ZR300 information ( 894,360 bits) plus 744 bits of pad ( 895,104 bits total) are scrambled and then bitwise demultiplexed to two OFEC encoders, each of which operate on input blocks of 3552 bits and produce output blocks of 4,096 bits. To process the 895,104 bits each encoder operates on 126 input blocks of 7104 bits.

Figure 6-3 shows the adaptation of the ZR300 frame structure to the OFEC input block structure.


Figure 6-3: ZR300 adaptation to a ZR300-OFEC-8QAM line interface

### 6.4 ZR200 adaptation to ZR200-OFEC-QPSK

For ZR200 adaptation to an ZR200-OFEC-QPSK line interface 58 rows of ZR200 information ( 596,240 bits) plus 496 bits of pad ( 596,736 bits total) are scrambled and then bitwise demultiplexed to two OFEC encoders, each of which operate on input blocks of 3,552 bits and produce output blocks of 4,096 bits. To process the 596,736 bits each encoder operates on 84 input blocks of 7104 bits.

Figure 6-3 shows the adaptation of the ZR200 frame structure to the OFEC input block structure.

OpenZR+ MSA Specification, version 1.0


Figure 6-4: ZR200 adaptation to a ZR200-OFEC-QPSK line interface

### 6.5 ZR100 adaptation to OFEC input blocks

For ZR100 116 rows of information (596,240 bits) plus 496 bits of pad (596,736 bits total) are scrambled and then bitwise demultiplexed to two OFEC encoders, each of which operate on input blocks of 3,552 bits and produce output blocks of 4,096 bits. To process the 596,736 bits each encoder operates on 84 input blocks of 7104 bits.

Figure 6-3 shows the adaptation of the ZR100 frame structure to the OFEC input block structure and then to the encoder input block sequence.

OpenZR+ MSA Specification, version 1.0


Figure 6-5: ZR100 adaptation to a ZR100-OFEC-QPSK line interface

### 6.6 Frame Synchronous Scrambling

The scrambler/descrambler is located before OFEC encoder on transmit, and after the OFEC decoder on receive. The operation of the scrambler shall be functionally equivalent to that of a frame-synchronous additive scrambler of sequence 65535 and the generating polynomial shall be:

$$
\mathrm{x}_{16}+\mathrm{x}_{12}+\mathrm{x}_{3}+\mathrm{x}+1
$$

The scrambler/descrambler resets to 0xFFFF at the start of each new OFEC input block structure. The scrambler runs continuously over the entire OFEC input block. Figure 6-6 shows a functional diagram of the frame synchronous scrambler.


Figure 6-6: Frame synchronous scrambler

## 7 Open Forward Error Correction (OFEC)

NOTE: This section of the document uses zero-based indexing for mathematical formula convenience.

The OFEC encoding block shown in Figure 7-1 consists of two FEC encoders/decoders (ENC0 and ENC1) operating in parallel. 7,104 bits are bit de-interleaved/interleaved to/from each encoder/decoder. The encoder expansion ratio is 4096/3552.

The OFEC encoder and OFEC interleaver datapath is shown in Figure 7-1. The 7104 bits from the scrambler are bit demultiplexed into two parallel 3552/4096 encoder engines. Even numbered bits ( 0 based) go to encoder 0 (ENC0), and odd numbered bits to encoder 1 (ENC1).


Figure 7-1: OFEC block encoder and OFEC Interleaver

### 7.1 OFEC encoding codec

Note: The section below describe a single instance of the OFEC encoder engine, i.e. one of ENCO or ENC1 in Figure 7-1.

For the OpenZR+ applications two encoding engines operate in parallel, with each engine producing an OFEC codeword. A codeword in OFEC is a semi-infinite set of bits organized in a matrix with semi-infinite number of rows and N columns $(\mathrm{N}=128)$.
It has the property that each bit is part of two "constituent component codewords," in which each constituent component codeword is a binary vector x of length 2 N satisfying the parity check constraint $\mathrm{xH}=0$, where H is a ( $2 \mathrm{~N}, 2 \mathrm{~N}-\mathrm{k}$ ) binary parity check matrix, with $2 \mathrm{~N}>$ $\mathrm{k}>\mathrm{N}$. Here $\mathrm{k}=239$, and each constituent component codeword has $(2 \mathrm{~N}-\mathrm{k})=17$ parity bits. The fraction of bits that are parity bits is $17 / 128$, the rate of the code is $111 / 128=$ 0.867 , and the overhead is $17 / 111=15.3 \%$.

Specifically in OFEC, H is a parity check matrix of an extended $\mathrm{BCH}(256,239)$ code. This BCH code has a minimum Hamming distance of 6. OFEC uses a BCH textbook encoding with a parity check matrix $H$ that is specified below.

The constituent component codewords are ordered as explained below to allow high speed parallel encoding and decoding. To define what bits are part of a given constituent component codeword the following structure is used:

- The infinite matrix of bits is partitioned in square blocks of $B \times B$ bits $(B=16)$, arranged in rows and columns as shown in Figure 7-2. There are N/B blocks per row ( $\mathrm{N} / \mathrm{B}=8$ ), and each square block is identified by a square block row number, R , and a square block column number, C , where $\mathrm{C}=0,1, \ldots, \mathrm{~N} / \mathrm{B}-1$, appearing respectively on the left hand side and at the top of the figure.
- Each bit inside a square block is identified by its row number, r , where $\mathrm{r}=0,1, \ldots, \mathrm{~B}-1$, and column number, c , where $\mathrm{c}=0,1, \ldots, \mathrm{~B}-1$, where bit 0,0 is at the upper left corner of a block. Overall, each bit in the infinite matrix is identified by a quadruple $\{R, C, r, c\}$.
- The number of guard-block rows needs to be even with a value 2 G , (e.g. $\mathrm{G}=2$, or $2 \mathrm{G}=4$ rows, in Figure 7-2)

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |






Figure 7-2: Structure of an openFEC Coder

A row of bits is identified by $(R, r)$, with a square block row number $R$ and a bit row number $r$ within that block, where $r=0,1, \ldots, B-1$. A constituent component codeword can be identified by the number of the row that contains all bits of the 2 nd half of the codeword. The $\mathrm{k}_{\mathrm{th}}$ bit $(\mathrm{k}=0,1, \ldots, 2 \mathrm{~N}-1)$ of constituent component codeword $(\mathrm{R}, \mathrm{r})$ is the bit identified with the quadruple:

- If $\mathrm{k}<\mathrm{N}: \quad\left\{\left(\mathrm{R}^{\wedge} 1\right)-2 \mathrm{G}-2 \mathrm{~N} / \mathrm{B}+2[\mathrm{k} / \mathrm{B}],[\mathrm{k} / \mathrm{B}],(\mathrm{k} \% \mathrm{~B})^{\wedge} \mathrm{r}, \mathrm{r}\right\}$
- If $k \geq N$ : $\left\{R,[(k-N) / B], r,(k \% B)^{\wedge} r\right\}$
where,
[.] denotes the floor operator,
( $\mathrm{a} \% \mathrm{~b}$ ) denotes the value of a modulo b , and
$\left(a^{\wedge} b\right) \quad$ represents the number with a binary representation equal to the bitwise "exclusive or" of the binary representations of the numbers a and $b$.
These formulas are illustrated in Figure 7-2. The union of line segments (both vertical and horizontal) of a given color shows the bits forming a constituent component codeword but the ordering in the segments is not the ordering in the codeword.
For example, consider the constituent component codeword $(20,0)$. The position of its bits in the semi-infinite matrix are indicated by the red line segments. Bits 0 to 15 are in column 0 of block ( 1,0 ), bits 16 to 31 in column 0 of block ( 3,1 ), $\ldots$, and bits 112 to 127 in column 0 of block $(15,7)$. The bit indices go up as one descends in the columns.
Bits 128 to 255 are in row 0 of blocks $(20,0)$ to $(20,7)$, and their indices go up moving to the right within a row.
Bits 0 to 127 are referred to as the "front" of a constituent component codeword, and bits 128 to 255 as the "back."

Note that each bit in the OFEC encoder belongs to the front of a constituent component codeword and to the back of another one. Also, if the back of a constituent component codeword is in an odd-numbered row of square blocks (yellow background), then its front is an even-numbered row of square blocks (blue background), and conversely.

The square blocks located below the "front bits" and above the "back bits" of a given constituent component codeword are so called guard blocks, relative to the constituent component codeword of interest.
Continuing the example, the bits of constituent component codeword (20, 15), identified by the orange line segments, are in the same blocks as the segments of constituent component codeword (20, 0). However, because "r" is 15 instead of 0 as in the previous example, the expressions "^ $\mathbf{r}$ " in formulas (1) and (2) become significant, and the bits are taken in reverse order in each block. For example, bits 0 to 15 in the front of codeword ( 20 , $15)$ are bits 15 to 0 in column 15 of block ( 1,0 ).
Note: The OFEC code is a block-convolutional code, and its performance is characterized by its "error events." Without the "^ $r$ " permutation, there are about 625,000 possible error events of weight 36 that can start at every decoding of a constituent component codeword. For comparison, a Product Code based on the same constituent component codeword has more than $3.3 e 13$ codewords of weight 36. The presence of the "^ $r$ " permutation can be observed to eliminate error events of weight 36. Consequently, the minimum Hamming distance of the OFEC code is at least 42.

### 7.2 Encoding

Encoding is done sequentially, in order of increasing row index. At the time when a constituent component codeword ( $\mathrm{R}, \mathrm{r}$ ) is being encoded, all constituent component codewords ( R ', $\mathrm{r}^{\prime}$ ) with R ' < R - 2G must be already be encoded.
To encode a constituent component codeword ( $\mathrm{R}, \mathrm{r}$ ), form a vector $x$ of length 2 N where the front N bits are read from previously encoded bits in the infinite matrix according to formula (1) above. In the back, the first $\mathrm{k}-\mathrm{N}$ (i.e., 111) bits are fresh information bits. The last $2 \mathrm{~N}-\mathrm{k}$ (i.e., 17) back bits are parity bits that can be calculated to satisfy $x \mathrm{H}=0$. After encoding, the N back bits are placed at their positions in the infinite matrix according to formula (2) above, and bits in those positions are output to an interleaver.
Considering Figure 7-2, we see that $G$ is large enough to allow the parallel encoding of 2 $B(G+1)=96$ constituent component codewords, assuming the pipeline delay is small. This number is considerably reduced when the pipeline delay increases, which is typically the case in the decoder.
One can also see that at most N/B $(\mathrm{N} / \mathrm{B}+2 \mathrm{G}+1)=104$ square blocks need to be kept in the encoder memory (excluding the current input). The square blocks that must be kept in memory in order to encode block rows 20 and 21 are surrounded by the dashed line in Figure 7-2.

A large G allows for longer pipeline delays in the encoding and decoding operations and allows for more parallel execution in the encoder and decoder, at the expense of increased memory.

### 7.3 Encoder interface

The encoder input consists of rectangular blocks of size $(2 B) \times(2 N-k)=32 \times 111$ bits. The encoder input blocks are numbered $0,1,2, \ldots$ The input bits into the encoder are sequenced. The ith input bit is placed in the encoder input block [i/ $(32 \times 111)$ ] at the position indicated by the value i $\%(32 \times 111)$ in Figure $7-3$. Note that an encoder input block is divided in $16 \times 16$-bit blocks, except along the right edge where their size is $16 \times 15$.
Bit $\mathrm{k}=0,1,2 \ldots$ of row p in encoder input block P is placed in position $\mathrm{N}+\mathrm{k}$ of constituent component codeword (2 $\mathrm{P}+[\mathrm{p} / \mathrm{B}], \mathrm{p} \% \mathrm{~B}$ ).

OpenZR+ MSA Specification, version 1.0


Figure 7-3: Sequencing of bits within an input block
The encoder output consists of rectangular blocks of size (2 B) $\times \mathrm{N}=32 \times 128$ bits. The encoder output blocks are numbered $0,1,2, \ldots$. Bit $k=0,1,2, \ldots$ of row p in rectangle P is the bit $\{2 \mathrm{P}+[\mathrm{p} / \mathrm{B}],[\mathrm{p} / \mathrm{B}], \mathrm{k} / \mathrm{B}, \mathrm{p} \% \mathrm{~B}\}$ of the semi-infinite array.
The bits within an output block are sequenced according to Figure 7-4.

| $\begin{array}{\|cccc} \hline 0 & 1 & \ldots & 15 \\ 16 & 17 & \ldots & 31 \\ 32 \ldots & & \\ . & & & \\ \cdot & & & \\ . & & & \\ . & & & \\ 240 & . . & & 255 \end{array}$ | 512... $\text { ... } 767$ | $1024 \ldots$ $\text { ... } 1279$ | $1536 \ldots$ $\text { ... } 1791$ | $\begin{aligned} & \hline 2048 \text {... } \\ & \cdot \\ & \cdot \\ & \cdot \\ & \cdot \\ & \cdot \\ & \cdot \\ & \text {... } 2303 \end{aligned}$ | $\begin{aligned} & \hline 2560 \text {... } \\ & \cdot \\ & \cdot \\ & \cdot \\ & \cdot \\ & \cdot \\ & \cdot \\ & \text {... } 2815 \end{aligned}$ | $3072$ $\text { ... } 3327$ | $3584$ $\text { ... } 3839$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 256... 271 | 768 | 1280 ... | 1792 | 2304... | 2816.. | 3328 | 3840 |
| 272 |  |  |  |  |  |  |  |
|  |  | . | - | . |  | . |  |
|  | . |  | . | . |  | . |  |
|  | . | . | . | . |  | . |  |
|  |  |  | . |  |  |  |  |
| 496511 | .... 1023 | ... 1535 | ... 2047 | ... 2559 | ... 3071 | . ... 3583 | ... 4095 |

Figure 7-4: Bit numbering within an output block

### 7.4 Formal encoder definition

This section directly describes the encoder (ENC0 or ENC1) output bits as a function of the input bits, integrating the diverse elements that have been described in previous sections.

An OFEC encoder is an entity that produces a binary output $y(i)$ from a binary input $u(i)$, where $\mathrm{i}=0,1,2, \ldots$.
The relationship between $y$ and $u$ is expressed through intermediate variables.
In particular, there is a four dimensional array $\mathrm{V}(\mathrm{R}, \mathrm{C}, \mathrm{r}, \mathrm{c})$, where R is an integer; $\mathrm{C}=0$, $1, \ldots, 7 ; \mathrm{r}=0,1, \ldots, 15$; and $\mathrm{c}=0,1, \ldots, 15$.
Associated with array V , there are constituent component codeword vectors $\mathrm{W}_{\mathrm{R}, \mathrm{rw}}$ with elements $W_{R, r}(i)$, where $R \geq 0, r=0,1.2 \ldots . .15$, and $i=0,1, \ldots, 255$.

For $R \geq 0, W_{R, r}(k)=\left\{\begin{array}{l}V\left(\left(R^{\wedge} 1\right)-20+2[k / 16],[k / 16],(k \% 16)^{\wedge} r, r\right) \text { for } k<128 \\ V\left(R,[(k-128) / 16], r,(k \% 16)^{\wedge} r\right) \text { for } 128 \leq k<256\end{array}\right.$
where,
[.] denotes the floor operator,
( $\mathrm{a} \% \mathrm{~b}$ ) denotes the value of a modulo b , and
$\left(a^{\wedge} b\right)$ represents the number with a binary representation equal to the bitwise "exclusive or" of the binary representations of the numbers a and $b$.

The bits in the $\mathrm{W}_{\mathrm{R}, \mathrm{r}}$ satisfy the following equalities:
For $\mathrm{R} \geq 0, \mathrm{r}=0,1, \ldots, 15$ and $\mathrm{k}=0,1, \ldots, 110$
WR, $\mathrm{r}(128+\mathrm{k})=\mathrm{u}([\mathrm{R} / 2] \times 32 \times 111+((\mathrm{R} \% 2) \times 16+\mathrm{r}) \times(16-[\mathrm{k} / 96])+[\mathrm{k} / 16] \times 512+$ k \% 16)
For $\mathrm{R} \geq 20, \mathrm{~W}_{\mathrm{R}, \mathrm{r}} \mathrm{H}=0$, where H is a parity check matrix of an extended $\operatorname{BCH}(256,239)$ code, using a textbook encoding; i.e., if $x$ is a vector satisfying $x \mathrm{H}=0$, then

1. $x$ has an even parity, and
2. if the first 255 bits of $x$ are seen as the binary coefficients of a polynomial $x(t)$ of degree 254 (with bit 0 of $x$ being the coefficient of power 254), with $t$ being the indeterminate, then this binary polynomial $\mathrm{x}(\mathrm{t})$ is divisible by the binary codeword generator polynomial $\mathrm{t} 16+\mathrm{t} 14+\mathrm{t} 13+\mathrm{t} 11+\mathrm{t} 10+\mathrm{t} 9+\mathrm{t} 8+\mathrm{t} 6+\mathrm{t} 5+\mathrm{t}+1$.
The output y satisfies the relationship
For $\mathrm{R} \geq 0 ; \mathrm{C}=0,1, \ldots, 7 ; \mathrm{r}=0,1, \ldots, 15$; and $\mathrm{c}=0,1, \ldots, 15$.
$\mathrm{V}(\mathrm{R}, \mathrm{C}, \mathrm{r}, \mathrm{c})=\mathrm{y}([\mathrm{R} / 2] \times 32 \times 128+(\mathrm{R} \% 2) \times 256+\mathrm{C} \times 16 \times 32+\mathrm{r} \times 16+\mathrm{c})$
It can be observed that $20 \times 16 \times 17$ values are left undefined in $W_{R, r}$ and in $V(R, C, r, c)$ for $0 \leq \mathrm{R}<20$, and thus also in the output y . This is by design; an implementation can choose any convenient values.

However, for test vectors, the output needs to be totally specified. To that end, the following additional constraints are added:

For $0 \leq \mathrm{R}<20, \mathrm{~W}_{\mathrm{R}, \mathrm{r}} \mathrm{H}^{\prime}=0$, where $\mathrm{H}^{\prime}$ is a $256 \times 17$ binary matrix where the first 128 rows are all zero and the last 128 rows are equal to the last 128 rows of H .

### 7.5 Decoding

Any of the iterative algorithms designed for turbo decoding of Product Codes can easily be adapted to decode OFEC codewords.
For use with iterative decoding, observe that the bits in square block row will all have been decoded as front bits in later constituent component codewords after $2(\mathrm{~N} / \mathrm{B}+\mathrm{G}+1$ ) rows of blocks have been decoded. Specifically, in Figure 7-2, bits in square block row $\mathrm{R}=0$ will all have been decoded as front bits by the time block row 21 has been decoded. It then makes sense to decode the constituent component codewords in block row 0 again.

### 7.6 OFEC Interleaver

The FEC datapath is shown in Figure 7-1. After OFEC encoding, mapping the bit stream is interleaved by a block interleaver. The interleaver block size is 172,032 bits ( 42 encoder output blocks, 21 from ENC0 and 21 from ENC1). The number of interleaver blocks per ZRx-OFEC structure is dependent on the modulation:

- $\mathrm{DP}-16 \mathrm{QAM}=(1376256 / 172032)=8$
- DP-8QAM $=(1032192 / 172032)=6$
- DP-QPSK $=(688128 / 172032)=4$


### 7.7 OFEC Interleaver architecture

The 172,032 bits in an interleaver block are organized as an $(84,8)$ array of 16 bit $\times 16$ bit square blocks; see Figure $7-5$ below. Note that the format is similar to the format used by the encoder and decoder. We then apply the two following mechanisms:

1 An intra-block interleaver that reorders the bits in each $16 \times 16$ square block to ensure that the bits in each row and column of a square block at the encoder output are remapped almost uniformly in the square block for transmission on the line. That operation can be seen as happening on input to the interleaver.
2 An inter-block interleaver that attempts to have nearby symbols on the line contain bits that are widely separated in the encoder output.
The interleaver is full rate, but it is fed by two half rate encoders, ENC0 and ENC1. Successive rows of square blocks from ENC0 will be written in even block rows of the interleaver buffer (yellowish colors in Figure 7-5), whereas successive rows of square blocks from ENC1 will be written in odd block rows (pinkish colors). Consequently, the content of an interleaver buffer is the square block row by square block row interleaving of vertical segments of the semi-infinite matrices of encoders ENC0 and ENC1.

### 7.8 Intra-block interleaving

For the purpose of intra-block interleaving, the interleaver is considered to receive $16 \times 16$ square blocks of bits from the encoders, and each square block is considered separately.

The intra-block interleaving is specified by the following Table $7-1$, which indicates the row and column of the source bit for each destination bit in the square block. For example,
bit $(14,15)$ [base 0] encoder output block is placed in row 1 of column 0 of the corresponding interleaver square block.

| 0,0 | 1,1 | 2,2 | 3,3 | 4,4 | 5,5 | 6,6 | 7,7 | 8,8 | 9,9 | 10,10 | 11,11 | 12,12 | 13,13 | 14,14 | 15,15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 14,15 | 15,0 | 0,1 | 1,2 | 2,3 | 3,4 | 4,5 | 5,6 | 6,7 | 7,8 | 8,9 | 9,10 | 10,11 | 11,12 | 12,13 | 13,14 |
| 12,14 | 13,15 | 14,0 | 15,1 | 0,2 | 1,3 | 2,4 | 3,5 | 4,6 | 5,7 | 6,8 | 7,9 | 8,10 | 9,11 | 10,12 | 11,13 |
| 10,13 | 11,14 | 12,15 | 13,0 | 14,1 | 15,2 | 0,3 | 1,4 | 2,5 | 3,6 | 4,7 | 5,8 | 6,9 | 7,10 | 8,11 | 9,12 |
| 8,12 | 9,13 | 10,14 | 11,15 | 12,0 | 13,1 | 14,2 | 15,3 | 0,4 | 1,5 | 2,6 | 3,7 | 4,8 | 5,9 | 6,10 | 7,11 |
| 6,11 | 7,12 | 8,13 | 9,14 | 10,15 | 11,0 | 12,1 | 13,2 | 14,3 | 15,4 | 0,5 | 1,6 | 2,7 | 3,8 | 4,9 | 5,10 |
| 4,10 | 5,11 | 6,12 | 7,13 | 8,14 | 9,15 | 10,0 | 11,1 | 12,2 | 13,3 | 14,4 | 15,5 | 0,6 | 1,7 | 2,8 | 3,9 |
| 2,9 | 3,10 | 4,11 | 5,12 | 6,13 | 7,14 | 8,15 | 9,0 | 10,1 | 11,2 | 12,3 | 13,4 | 14,5 | 15,6 | 0,7 | 1,8 |
| 15,7 | 0,8 | 1,9 | 2,10 | 3,11 | 4,12 | 5,13 | 6,14 | 7,15 | 8,0 | 9,1 | 10,2 | 11,3 | 12,4 | 13,5 | 14,6 |
| 13,6 | 14,7 | 15,8 | 0,9 | 1,10 | 2,11 | 3,12 | 4,13 | 5,14 | 6,15 | 7,0 | 8,1 | 9,2 | 10,3 | 11,4 | 12,5 |
| 11,5 | 12,6 | 13,7 | 14,8 | 15,9 | 0,10 | 1,11 | 2,12 | 3,13 | 4,14 | 5,15 | 6,0 | 7,1 | 8,2 | 9,3 | 10,4 |
| 9,4 | 10,5 | 11,6 | 12,7 | 13,8 | 14,9 | 15,10 | 0,11 | 1,12 | 2,13 | 3,14 | 4,15 | 5,0 | 6,1 | 7,2 | 8,3 |
| 7,3 | 8,4 | 9,5 | 10,6 | 11,7 | 12,8 | 13,9 | 14,10 | 15,11 | 0,12 | 1,13 | 2,14 | 3,15 | 4,0 | 5,1 | 6,2 |
| 5,2 | 6,3 | 7,4 | 8,5 | 9,6 | 10,7 | 11,8 | 12,9 | 13,10 | 14,11 | 15,12 | 0,13 | 1,14 | 2,15 | 3,0 | 4,1 |
| 3,1 | 4,2 | 5,3 | 6,4 | 7,5 | 8,6 | 9,7 | 10,8 | 11,9 | 12,10 | 13,11 | 14,12 | 15,13 | 0,14 | 1,15 | 2,0 |
| 1,0 | 2,1 | 3,2 | 4,3 | 5,4 | 6,5 | 7,6 | 8,7 | 9,8 | 10,9 | 11,10 | 12,11 | 13,12 | 14,13 | 15,14 | 0,15 |

Table 7-1: Source positions (row, col) for intra-block interleaving
Note: The left entries of the pairs in this table form a Latin Square. The right entries almost form a Latin square, but they are duplicated in the first and last rows.

### 7.9 Inter-block interleaving

The intra-block permutation described in the previous section is applied to each square block in the buffer as it comes in from the encoder.

In addition to partitioning the interleaver buffer as a function of the encoder, ENC0 or ENC1, it is also partitioned in an upper half of 42 block rows (light color tones) and a lower half of 42 block rows (dark color tones). Overall the buffer is then partitioned in 4 subsets, each containing $21 \times 8$ square blocks or $336 \times 128$ bits.

| Subset number | Row Blocks |
| :---: | :--- |
| 0 | $0,2, \ldots, 40$ |
| 1 | $1,3, \ldots, 41$ |
| 2 | $42,44, \ldots, 82$ |
| 3 | $43,45, \ldots, 83$ |

Table 7-2: Interleaver subsets
On output, groups of 8 bits are taken in turn from each subset, reading them out of a column of bits before proceeding to the next columns of bits. These output bits form the FlexO-xDO structure.

Specifically, as shown in Figure 7-5, the first 8 bits are read from the top of first column of subset 0 , then the first 8 bits from the first column of subsets 1,2 , and 3 . Those 32 bits are then followed by the taking the next 8 bits in the first column of each of the subsets $0,1,2$, and 3 . After 42 such cycles of $4 \times 8$ bits each, the first bit column of the interleaver buffer
will be completely read out, and the output process continues by reading bit columns 1 to 127.


Figure 7-5: Inter-block interleaving
Note: Bits are read by columns, rather than rows because interleaver columns are much longer than rows, so bits in a column are spread over more constituent component codewords than bits in a row, which increases the tolerance to long bursts. The maximum correctable burst length, when used with a hard decoder, is a traditional measure of interleaver quality. In this case it can be shown to be 2,681 bits.
The bits read out of the interleaver are passed to the modulator where they are used in groups of $\mathrm{S}=4,6$ or 8 , for QPSK, 8QAM and 16QAM respectively in both the H and V polarizations.

Note: The output bits with even indexes are used to form symbols for the $H$ polarization, whereas those in odd positions are formed to symbols in the V polarization. This simplifies the line BER estimation in each polarization. The $H$ and $V$ bits will appear at fixed positions in each square block in the decoder independently of the modulation.

## 8 Symbol Mapping and Polarization Distribution

This section describes the procedure for mapping encoded and interleaved OFEC Blocks to DP-QPSK and DP-nQAM constellation symbols for distribution on each (X/Y) polarizations. This procedure is illustrated in Figure 8-1 below.


Figure 8-1: DSP symbol mapping and polarization distribution

### 8.1 Symbol mapping

Symbol mapping is modulation dependent. Each ZRx-OFEC structure is mapped to 172032 symbols in each polarization.

### 8.2 DP-16QAM Symbols

The ZR400-OFEC bits denoted by $c_{k}(\mathrm{k}=0 \ldots 1376255)$ are mapped to 16QAM symbols ( $S$ ).
$S=\left[S_{0}, s_{1}, \ldots, s_{172031}\right]$,
where,
( $\boldsymbol{c}_{\mathbf{8} \boldsymbol{i}}, \boldsymbol{c}_{\mathbf{8 i + 2}}$ ) maps to the in-phase (I) component of the X-pol of $\boldsymbol{s}_{\boldsymbol{i}}$
( $\boldsymbol{c}_{\mathbf{8 i + 4}}, \boldsymbol{c}_{\mathbf{8 i + 6}}$ ) maps to the quadrature-phase (Q) component of the X-pol of $\boldsymbol{s}_{\boldsymbol{i}}$
( $\boldsymbol{c}_{\mathbf{8} \boldsymbol{i}+\boldsymbol{1}}, \boldsymbol{c}_{\mathbf{8 i + 3}}$ ) maps to the I component of the Y-pol of $\boldsymbol{s}_{\boldsymbol{i}}$
$\left(\boldsymbol{c}_{\mathbf{8 i + 5}}, \boldsymbol{c}_{\mathbf{8 i + 7}}\right)$ maps to the Q component of the Y-pol of $\boldsymbol{s}_{\boldsymbol{i}}$

In each signaling dimension, the following mapping from binary label to relative symbol amplitude is defined as:
$(0,0) \rightarrow-3,(0,1) \rightarrow-1,(1,1) \rightarrow+1,(1,0) \rightarrow+3$
This mapping per polarization is further detailed in Table 8-1 below.

OpenZR+ MSA Specification, version 1.0

| $\left(c_{8 i}, c_{8 i+2}, c_{8 i+4,} c_{8 i+6}\right)$ | or ( $\left.c_{8 i+1}, c_{8 i+3}, c_{8 i+5}, c_{8 i+7}\right)$ | I | Q |
| :---: | :---: | :---: | :---: |
|  | $(0,0,0,0)$ | -3 | -3 |
|  | $(0,0,0,1)$ | -3 | -1 |
|  | $(0,0,1,0)$ | -3 | 3 |
|  | $(0,0,1,1)$ | -3 | 1 |
|  | (0,1,0,0) | -1 | -3 |
|  | $(0,1,0,1)$ | -1 | -1 |
|  | (0,1,1,0) | -1 | 3 |
|  | (0,1,1,1) | -1 | 1 |
|  | $(1,0,0,0)$ | 3 | -3 |
|  | (1,0,0,1) | 3 | -1 |
|  | (1,0,1,0) | 3 | 3 |
|  | (1,0,1,1) | 3 | 1 |
|  | (1,1,0,0) | 1 | -3 |
|  | (1,1,0,1) | 1 | -1 |
|  | (1,1,1,0) | 1 | 3 |
|  | (1,1,1,1) | 1 | 1 |

Table 8-1: 16QAM symbol amplitude map

### 8.3 8QAM Symbols

The ZR300-OFEC bits denoted by $c_{k}(\mathrm{k}=0 \ldots 1032191)$ are mapped to 8QAM symbols $(S)$,

$$
S=\left[s_{0}, s_{1}, \ldots, s_{172031}\right]
$$

where,
$\left(\boldsymbol{c}_{\boldsymbol{6} \boldsymbol{i}}, \boldsymbol{c}_{\boldsymbol{6 i + 2}}, \boldsymbol{c}_{\boldsymbol{6 i + 4}}\right)$ maps to the in-phase/quadrature-phase (I/Q) component of the X-pol of $\boldsymbol{s}_{\boldsymbol{i}}$
$\left(\boldsymbol{c}_{\boldsymbol{6} \boldsymbol{i}+\boldsymbol{1}}, \boldsymbol{c}_{\boldsymbol{6} \boldsymbol{i + 3}}, \boldsymbol{c}_{\boldsymbol{6} \boldsymbol{i}+5}\right)$ maps to the I/Q component of the Y-pol of $\boldsymbol{s}_{\boldsymbol{i}}$

In each polarization, we define the following map from binary label to relative symbol amplitudes:

| $\left(\boldsymbol{c}_{\mathbf{6 i}}, \boldsymbol{c}_{\mathbf{6 i + 2},} \boldsymbol{c}_{\mathbf{6 i + 4}}\right) \boldsymbol{o r}\left(\boldsymbol{c}_{\mathbf{6 i + 1}}, \boldsymbol{c}_{\mathbf{6 i + 3},}, \boldsymbol{c}_{\mathbf{6 i + 5}}\right)$ | $\mathbf{I}$ | $\mathbf{Q}$ |
| :---: | :---: | :---: |
| $(0,0,0)$ | 0 | -1 |
| $(0,0,1)$ | -1.366 | -1.366 |
| $(0,1,0)$ | -1.366 | 1.366 |
| $(0,1,1)$ | -1 | 0 |
| $(1,0,0)$ | 1.366 | -1.366 |
| $(1,0,1)$ | 1 | 0 |
| $(1,1,0)$ | 0 | 1 |
| $(1,1,1)$ | 1.366 | 1.366 |

Table 8-2: 8QAM symbol amplitude map

### 8.4 QPSK Symbols

The ZR200-OFEC or ZR100-OFEC bits denoted by $c_{k}(\mathrm{k}=0 \ldots 688127)$ are mapped to QPSK symbols ( $S$ ),

$$
S=\left[s_{0}, s_{1}, \ldots, s_{172031}\right]
$$

where,
( $\boldsymbol{c}_{4 i}$ ) maps to the in-phase (I) component of the X-pol of $\boldsymbol{s}_{\boldsymbol{i}}$
$\left(\boldsymbol{c}_{4 i+2}\right)$ maps to the quadrature-phase (Q) component of the X-pol of $\boldsymbol{s}_{\boldsymbol{i}}$
$\left(\boldsymbol{c}_{\boldsymbol{4 i + 1}}\right)$ maps to the I component of the Y-pol of $\boldsymbol{s}_{\boldsymbol{i}}$
$\left(\boldsymbol{c}_{4 \boldsymbol{i}+\boldsymbol{3}}\right)$ maps to the Q component of the Y-pol of $\boldsymbol{s}_{\boldsymbol{i}}$

In each polarization, we define the following map from binary label to relative symbol amplitudes:

| $\left(\boldsymbol{c}_{\boldsymbol{4} \boldsymbol{i}}, \boldsymbol{c}_{\boldsymbol{4} \boldsymbol{i}+\boldsymbol{2}}\right)$ or $\left(\boldsymbol{c}_{\boldsymbol{4} \boldsymbol{i}+\mathbf{1}}, \boldsymbol{c}_{\boldsymbol{4} \boldsymbol{i}+\boldsymbol{3}}\right)$ | $\mathbf{I}$ | $\mathbf{Q}$ |
| :---: | :---: | :---: |
| $(0,0)$ | -1 | -1 |
| $(0,1)$ | -1 | 1 |
| $(1,0)$ | 1 | -1 |
| $(1,1)$ | 1 | 1 |

Table 8-3: QPSK symbol amplitude map

## 9 DSP Framing

This section describes the DSP framing format. The DSP super-frame consists of 48 DSP sub-frames. The DSP frame length expressed in symbols is modulation independent. The frame format is defined for each polarization (X/Y).


Figure 9-1: DSP Frame generation

### 9.1 DSP super-frame

A DSP super-frame is defined as a set of 178176 symbols in each X/Y polarization. A DSP sub-frame consists of 3712 symbols. The DSP super-frame thus consists of 48 DSP subframes.

Pilot Symbols (PS) are inserted every 32 symbols starting with the first symbol of the first DSP sub-frame. Each DSP sub-frame starts with an 11-symbol training sequence. The first symbol of the training sequence is a Pilot Symbol. The first DSP sub-frame of the superframe also includes the DSP super-frame Frame Alignment Word (FAW).
As illustrated in Figure 9-1 above, once the data stream has been mapped into symbols and distributed onto each polarization pilot symbols, training symbols, Frame Alignment Word (FAW), and other overhead are added to create the DSP super-frame/sub-frame structure. Pilot symbols, Training symbols, and FAW symbols are always mapped to the outer constellation points of the optical signal.

| Parameter | DP-16QAM | DP-8QAM | DP-QPSK |
| :---: | :---: | :---: | :---: |
| Constellation Map |  0 0 0 0 <br> 0 0 0 0  <br>  0 0 0 0 <br> 0 0 0 0  |  |  |
| FAW | 22 Symbols | 22 Symbols | 22 Symbols |
| TS | 11 symbols per DSP subframe | 11 symbols per DSP subframe | 11 symbols per DSP subframe |
| PS | Every 32 symbols | Every 32 symbols | Every 32 symbols |

Table 9-1: FAW/TS/PS pattern

### 9.2 DSP sub-frame

Each DSP super-frame is divided into 48 DSP sub-frames and each DSP sub-frame consists of 3,712 symbols.

The first DSP sub-frame of the DSP super-frame includes a 22 symbol Frame Alignment Word (FAW) used for alignment to the OFEC blocks. 74 additional symbols are reserved for future use/innovation.

The first DSP sub-frame includes:

- 22 symbol super-frame Frame Alignment Word (FAW) used for super-frame delineation and alignment to the OFEC block. 74 additional symbols are reserved for future use/innovation. The FAW sequence is different between X and Y polarizations.
- 74 symbols are reserved to be used for future proofing and for innovation. These symbols should be randomized to avoid strong tones.
- 11 symbols available for link training. The first Training Symbol (TS) is shared as a Pilot Symbol (PS) in each DSP sub-frame.
- 116 Pilot Symbols.

Every subsequent DSP sub-frame (sub-frames 2-48 of a DSP super-frame) include:

- 11 symbols available for link training. The first Training Symbol (TS) is shared as a Pilot Symbol (PS) in each DSP sub-frame.
- 116 Pilot Symbols

$\square$ FAW: Super-Frame Alignment Word (22 symbols)
$\square$ RES: Reserved for future use ( 74 symbols)
- PS: Pilot symbol (every 32 symbols ( 5568 symbols per DSP super-frame)
- TS: Training symbol ( $48^{*} 11$ symbols, the first TS is shares as a PS)
- Information, parity and padding symbols

Figure 9-2: DSP super-frame

OpenZR+ MSA Specification, version 1.0


Figure 9-3: DSP sub-frames 1 to 47 of the DSP super-frame

### 9.3 FAW Sequence

The required sequence and constellation corner relative symbol amplitude for the 16QAM FAW is shown in Table 9-2.

|  | 16QAM |  | 8QAM |  | QPSK |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Index | FAW (X) | FAW (Y) | FAW (X) | FAW (Y) | FAW (X) | FAW (Y) |
| 1 | 3-3j | $3+3 \mathrm{j}$ | 1.366-1.366j | $1.366+1.366 \mathrm{j}$ | $1-1 \mathrm{j}$ | $1+1 \mathrm{j}$ |
| 2 | $3+3 \mathrm{j}$ | $-3+3 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $1+1 \mathrm{j}$ | $-1+1 \mathrm{j}$ |
| 3 | $3+3 \mathrm{j}$ | -3-3j | $1.366+1.366 \mathrm{j}$ | -1.366-1.366j | $1+1 \mathrm{j}$ | $-1-1 \mathrm{j}$ |
| 4 | $3+3 \mathrm{j}$ | $-3+3 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $1+1 \mathrm{j}$ | $-1+1 \mathrm{j}$ |
| 5 | $3-3 \mathrm{j}$ | $3-3 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $1-1 \mathrm{j}$ | $1-1 \mathrm{j}$ |
| 6 | 3-3j | $3+3 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $1-1 \mathrm{j}$ | $1+1 \mathrm{j}$ |
| 7 | -3-3j | $3-3 \mathrm{j}$ | $-1.366-1.366 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $-1-1 \mathrm{j}$ | $1-1 \mathrm{j}$ |
| 8 | $3+3 \mathrm{j}$ | $3-3 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $1+1 \mathrm{j}$ | $1-1 \mathrm{j}$ |
| 9 | $-3-3 \mathrm{j}$ | $-3-3 \mathrm{j}$ | $-1.366-1.366 \mathrm{j}$ | -1.366-1.366j | $-1-1 \mathrm{j}$ | $-1-1 \mathrm{j}$ |
| 10 | $-3+3 \mathrm{j}$ | $3-3 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $-1+1 \mathrm{j}$ | $1-1 \mathrm{j}$ |
| 11 | $-3+3 \mathrm{j}$ | $3+3 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $-1+1 \mathrm{j}$ | $1+1 \mathrm{j}$ |
| 12 | $3-3 \mathrm{j}$ | $-3+3 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $1-1 \mathrm{j}$ | $-1+1 \mathrm{j}$ |
| 13 | $-3-3 \mathrm{j}$ | $-3+3 \mathrm{j}$ | -1.366-1.366j | $-1.366+1.366 \mathrm{j}$ | $-1-1 \mathrm{j}$ | $-1+1 \mathrm{j}$ |
| 14 | -3-3j | $3+3 \mathrm{j}$ | $-1.366-1.366 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $-1-1 \mathrm{j}$ | 1+1j |
| 15 | $-3+3 \mathrm{j}$ | $-3-3 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $-1.366-1.366 \mathrm{j}$ | $-1+1 \mathrm{j}$ | $-1-1 \mathrm{j}$ |
| 16 | $3+3 \mathrm{j}$ | $3+3 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $1+1 \mathrm{j}$ | $1+1 \mathrm{j}$ |
| 17 | -3-3j | $-3-3 \mathrm{j}$ | -1.366-1.366j | -1.366-1.366j | $-1-1 \mathrm{j}$ | $-1-1 \mathrm{j}$ |
| 18 | 3-3j | $-3+3 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $1-1 \mathrm{j}$ | $-1+1 \mathrm{j}$ |
| 19 | $-3+3 \mathrm{j}$ | $3-3 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $-1+1 \mathrm{j}$ | $1-1 \mathrm{j}$ |
| 20 | $3+3 \mathrm{j}$ | $-3-3 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | -1.366-1.366j | $1+1 \mathrm{j}$ | $-1-1 \mathrm{j}$ |
| 21 | -3-3j | $3-3 \mathrm{j}$ | $-1.366-1.366 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $-1-1 \mathrm{j}$ | $1-1 \mathrm{j}$ |

OpenZR+ MSA Specification, version 1.0

|  | 16QAM |  | 8QAM |  | QPSK |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Index | FAW (X) | FAW (Y) | FAW (X) | FAW (Y) | FAW (X) | FAW (Y) |
| 22 | $-3+3 \mathrm{j}$ | $-3+3 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $-1+1 \mathrm{j}$ | $-1+1 \mathrm{j}$ |

Table 9-2: FAW Sequence

### 9.4 Training Sequence

The required sequence and constellation corner relative symbol amplitude for the 16QAM TS is shown in Table 9-3. The constellation corner relative symbol amplitude for the 8QAM TS and QPSK TS should be scaled per Table 8-2 and Table 8-3 respectively.

|  | 16QAM |  | 8QAM |  | QPSK |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Index | Training <br> $(\mathbf{X})$ | Training <br> $(\mathbf{Y})$ | Training (X) | Training (Y) | Training <br> $(\mathbf{X})$ | Training <br> $(\mathbf{Y})$ |
| $1^{*}$ | $-3+3 \mathrm{j}$ | $-3-3 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $-1.366-1.366 \mathrm{j}$ | $-1+1 \mathrm{j}$ | $-1-1 \mathrm{j}$ |
| 2 | $3+3 \mathrm{j}$ | $-3-3 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $-1.366-1.366 \mathrm{j}$ | $1+1 \mathrm{j}$ | $-1-1 \mathrm{j}$ |
| 3 | $-3+3 \mathrm{j}$ | $3-3 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $-1+1 \mathrm{j}$ | $1-1 \mathrm{j}$ |
| 4 | $3+3 \mathrm{j}$ | $-3+3 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $1+1 \mathrm{j}$ | $-1+1 \mathrm{j}$ |
| 5 | $-3-3 \mathrm{j}$ | $-3+3 \mathrm{j}$ | $-1.366-1.366 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $-1-1 \mathrm{j}$ | $-1+1 \mathrm{j}$ |
| 6 | $3+3 \mathrm{j}$ | $3+3 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $1+1 \mathrm{j}$ | $1+1 \mathrm{j}$ |
| 7 | $-3-3 \mathrm{j}$ | $-3-3 \mathrm{j}$ | $-1.366-1.366 \mathrm{j}$ | $-1.366-1.366 \mathrm{j}$ | $-1-1 \mathrm{j}$ | $-1-1 \mathrm{j}$ |
| 8 | $-3-3 \mathrm{j}$ | $-3+3 \mathrm{j}$ | $-1.366-1.366 \mathrm{j}$ | $-1.366+1.366 \mathrm{j}$ | $-1-1 \mathrm{j}$ | $-1+1 \mathrm{j}$ |
| 9 | $3+3 \mathrm{j}$ | $3-3 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $1+1 \mathrm{j}$ | $1-1 \mathrm{j}$ |
| 10 | $3-3 \mathrm{j}$ | $3+3 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $1.366+1.366 \mathrm{j}$ | $1-1 \mathrm{j}$ | $1+1 \mathrm{j}$ |
| 11 | $3-3 \mathrm{j}$ | $3-3 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $1.366-1.366 \mathrm{j}$ | $1-1 \mathrm{j}$ | $1-1 \mathrm{j}$ |

Table 9-3: Training symbol sequence
*The first symbol of the Training Sequence is processed as a pilot

### 9.5 Pilot Sequence

Training symbols and pilot symbols shall be set at the outer 4 points of the DP-nQAM constellation.

The Pilot is a fixed PRBS10 mapped to the QPSK sequence with different seed values for X/Y.

- Seeds are selected so that pilots are DC balanced
- Seeds are selected so that the 1 st symbol in the training sequence is also the first symbol in the pilot sequence
- The seed is reset at the head of every DSP super-frame

OpenZR+ MSA Specification, version 1.0


Figure 9-4: Pilot Symbol (DP-16QAM modulation shown)


Table 9-4: Pilot Sequence


Figure 9-5: Pilot Seed and Sequencing
The required sequence and constellation corner relative symbol amplitude for the 16QAM PS is shown in Table 9-5. The constellation corner relative symbol amplitude for the 8QAM PS and QPSK PS should be scaled per Table 8-2 and Table 8-3 respectively.

The complete table is shown below:

|  | 16QAM |  | 8QAM |  | QPSK |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Index | Pilot X | Pilot Y | Pilot X | Pilot Y | Pilot X | Pilot Y |
| 1 | $-3+3 \mathrm{i}$ | -3-3i | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 2 | $3+3 \mathrm{i}$ | -3-3i | $1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 3 | $3-3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 4 | $-3+3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 5 | $3-3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | 1-1i | -1-1i |
| 6 | $3-3 i$ | $3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | 1-1i | $1+1 \mathrm{i}$ |
| 7 | $-3-3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | -1-1i | $-1+1 \mathrm{i}$ |
| 8 | $3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 9 | $-3+3 \mathrm{i}$ | -3-3i | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | -1-1i |
| 10 | $3+3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 11 | $3+3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 12 | $-3-3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 13 | $3+3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 14 | $3-3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 15 | $3+3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 16 | $3-3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 17 | $3+3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 18 | $3-3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 19 | $-3+3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 20 | $-3-3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | 1-1i |
| 21 | $3+3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | 1-1i |
| 22 | $-3+3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 23 | $-3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 24 | $3-3 \mathrm{i}$ | 3-3i | $1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | 1-1i |
| 25 | $-3+3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | 1-1i |
| 26 | $-3+3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | 1+1i |
| 27 | $-3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 28 | $-3+3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 29 | $-3-3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 30 | $3-3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | 1-1i | 1-1i |
| 31 | $-3-3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | -1-1i | $-1+1 \mathrm{i}$ |
| 32 | $3+3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 33 | $-3+3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 34 | $-3+3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 35 | $-3+3 \mathrm{i}$ | -3-3i | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | -1-1i |
| 36 | $3-3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 37 | 3-3i | $3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 38 | -3-3i | -3-3i | $-1.366-1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 39 | -3-3i | $3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | -1-1i | $1+1 \mathrm{i}$ |

OpenZR+ MSA Specification, version 1.0

|  | 16QAM |  | 8QAM |  | QPSK |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Index | Pilot X | Pilot Y | Pilot X | Pilot Y | Pilot X | Pilot Y |
| 40 | $3-3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 41 | -3-3i | $3-3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | -1-1i | 1-1i |
| 42 | 3-3i | 3-3i | $1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 43 | $-3+3 \mathrm{i}$ | -3-3i | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | -1-1i |
| 44 | $-3+3 \mathrm{i}$ | -3-3i | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 45 | -3-3i | $3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 46 | $-3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 47 | $-3-3 \mathrm{i}$ | $3+3 i$ | $-1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 48 | $3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 49 | $3+3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 50 | $-3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 51 | $3-3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 52 | 3-3i | $-3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 53 | 3-3i | $-3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 54 | $-3-3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 55 | $3-3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 56 | $3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | 1+1i | $-1+1 \mathrm{i}$ |
| 57 | $-3+3 \mathrm{i}$ | -3-3i | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | -1-1i |
| 58 | $-3-3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | -1-1i | $1-1 \mathrm{i}$ |
| 59 | 3-3i | $3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | 1-1i | 1-1i |
| 60 | $3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1.366+1.366 i$ | $1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 61 | 3-3i | $3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | 1-1i | $1+1 \mathrm{i}$ |
| 62 | -3-3i | $-3-3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | -1.366-1.366i | -1-1i | -1-1i |
| 63 | $3-3 i$ | $3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | 1-1i | $1+1 \mathrm{i}$ |
| 64 | $-3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 65 | $3-3 i$ | $3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | 1-1i | 1-1i |
| 66 | $3+3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | 1+1i | $1+1 \mathrm{i}$ |
| 67 | $3-3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | -1-1i |
| 68 | $-3+3 \mathrm{i}$ | $3-3 i$ | $-1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 69 | $3-3 i$ | $-3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | 1-1i | $-1+1 \mathrm{i}$ |
| 70 | $-3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 71 | $3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 72 | -3-3i | -3-3i | $-1.366-1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | -1-1i |
| 73 | -3-3i | $-3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 74 | $3-3 i$ | $3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 75 | $-3+3 \mathrm{i}$ | -3-3i | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 76 | $3-3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 77 | $-3+3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 78 | $-3-3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 79 | $3+3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 80 | $3+3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | -1.366-1.366i | $1+1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |

OpenZR+ MSA Specification, version 1.0

|  | 16QAM |  | 8QAM |  | QPSK |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Index | Pilot X | Pilot Y | Pilot X | Pilot Y | Pilot X | Pilot Y |
| 81 | $3+3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | 1-1i |
| 82 | -3-3i | $-3-3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | -1-1i | $-1-1 \mathrm{i}$ |
| 83 | -3-3i | $3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 84 | $3+3 \mathrm{i}$ | -3-3i | $1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | -1-1i |
| 85 | $3-3 \mathrm{i}$ | $-3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 86 | $-3+3 \mathrm{i}$ | -3-3i | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | -1-1i |
| 87 | $3+3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 88 | $3-3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 89 | -3-3i | $-3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 90 | $3-3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 91 | 3-3i | $3+3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | 1-1i | $1+1 \mathrm{i}$ |
| 92 | $-3+3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 93 | $-3-3 \mathrm{i}$ | $3-3 i$ | $-1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | -1-1i | $1-1 \mathrm{i}$ |
| 94 | $3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 95 | $-3-3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 96 | -3-3i | $3-3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | -1-1i | $1-1 \mathrm{i}$ |
| 97 | $3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | 1+1i | $-1+1 \mathrm{i}$ |
| 98 | $-3+3 \mathrm{i}$ | $3-3 i$ | $-1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | 1-1i |
| 99 | $3-3 i$ | -3-3i | $1.366-1.366 \mathrm{i}$ | -1.366-1.366i | $1-1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 100 | -3-3i | $3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | -1-1i | $1+1 \mathrm{i}$ |
| 101 | $3+3 \mathrm{i}$ | -3-3i | $1.366+1.366 \mathrm{i}$ | -1.366-1.366i | 1+1i | -1-1i |
| 102 | $-3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 103 | -3-3i | $-3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | -1-1i | $-1+1 \mathrm{i}$ |
| 104 | -3-3i | $3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | -1-1i | $1+1 \mathrm{i}$ |
| 105 | $3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | 1+1i | $-1+1 \mathrm{i}$ |
| 106 | $3-3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1-1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 107 | $3+3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | 1+1i | $1+1 \mathrm{i}$ |
| 108 | $-3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 109 | -3-3i | $3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 110 | $-3+3 \mathrm{i}$ | -3-3i | $-1.366+1.366 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1-1 \mathrm{i}$ |
| 111 | $-3-3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 112 | $-3+3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 113 | $-3+3 \mathrm{i}$ | $-3+3 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1.366+1.366 \mathrm{i}$ | $-1+1 \mathrm{i}$ | $-1+1 \mathrm{i}$ |
| 114 | $3+3 \mathrm{i}$ | $3+3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $1+1 \mathrm{i}$ |
| 115 | $3+3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $1.366+1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $1+1 \mathrm{i}$ | $1-1 \mathrm{i}$ |
| 116 | $-3-3 \mathrm{i}$ | $3-3 \mathrm{i}$ | $-1.366-1.366 \mathrm{i}$ | $1.366-1.366 \mathrm{i}$ | $-1-1 \mathrm{i}$ | $1-1 \mathrm{i}$ |

Table 9-5: Pilot Sequence

OpenZR+ MSA Specification, version 1.0

## 10 Frame Expansion Rate

The OFEC optical signal is $\sim 60.138546798$ GBd. Table 10-1 provides detail on expansion for each functional block.

| Parameters | Mapping |
| :---: | :---: |
| FEC Payload | ZR100, ZR200, ZR300 or ZR400 frames |
| FEC algorithm | OFEC |
| FEC payload size (k) | 3,552 |
| FEC block size (n) | 4,096 |
| The number of FEC blocks in super frame | 168(16QAM)/126(8QAM)/84(QPSK) |
| The total payload size | $\begin{aligned} & 1,193,472(16 \mathrm{QAM}) \\ & 895,104(8 \mathrm{QAM}) \\ & 596,736(\mathrm{QPSK}) \end{aligned}$ |
| PAD before FEC | 992(16QAM)/744(8QAM)/496(QPSK) |
| The total payload size based on 257b | $\begin{aligned} & 1,192,480 \mathrm{~b}(16 \mathrm{QAM}) 4,640 \times 257 \mathrm{~b} \\ & 894,360 \mathrm{~b}(8 \mathrm{QAM}) 3,480 \times 257 \mathrm{~b} \\ & 596,240 \mathrm{~b} \text { (QPSK) } 2,320 \times 257 \mathrm{~b} \end{aligned}$ |
| The total bits | $\begin{aligned} & 1,376,256(16 \mathrm{QAM}) \\ & 1,032,192(8 \mathrm{QAM}) \\ & 688,128(\mathrm{QPSK}) \end{aligned}$ |
| Total number of symbols per before DSP frame OH | 172,032 |
| The number of FAW symbols | 22 |
| The number of RES symbols | 74 |
| The number of Training Symbols | 480 |
| The number of Pilot Symbols (PS) | 5,568 |
| The total symbol of super-frame | 178,176 |
| DSP sub-frame symbols | 3,712 |
| The number of DSP sub-frames per super-frame | 48 |
| Modulation format | 16QAM / 8QAM / QPSK |
| Baud rate | ~60 138546798 Baud* |

Table 10-1: ZRx/OFEC expansion rates
$* 60.138546798 \mathrm{GBd}=401.703640510 \times(512 / 511) \times(37296 / 37265) \times(4096 / 3552) \times(899 / 896) \times(32 / 31) / 8$

## 11 Optical Specifications

The OpenZR+ optical parameters are organized by applications: DWDM amplified in 11.1, and Single-wavelength un-amplified in 11.2. Parameters for the DWDM link are requirements that ensure multi-vendor operation between compliant Tx / Rx modules. OpenZR+ uses the black link methodology to define the DWDM link.

Note: All specifications are defined after calibration and compensation, at EOL over temperature and wavelength. All specifications are based on 100 GHz grid spacing. Parameters for 75 GHz channel spacing will be included in a future revision.

### 11.1 OpenZR+ DWDM amplified application:

This section defines the optical parameters for the DWDM amplified application.

### 11.1.1 DWDM link specifications (black link methodology)

| Ref. | Parameter | Mode | Min | Max | Unit | Conditions / Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Channel frequency | All | 191.3 | 196.1 | THz |  |
|  | Channel spacing | All | 100 | - | GHz |  |
|  | Fiber type | All |  |  |  | Single mode fiber per ITU-T G. 652 used for link budgeting. |
|  | Ripple | All | - | 2 | dB |  |
|  |  | 400G | - | 20,000 | ps/nm | Frequency dependent change in phase velocity due to fiber. |
|  | Chromatic dispersion | 300G | - | 40,000 |  |  |
|  |  | 200G | - | 50,000 |  |  |
|  |  | 100G | - | 100,000 |  |  |
|  | Optical return loss at Ss | All | - | 24 | dB |  |
|  | Discrete reflectance between Ss and Rs | All | - | -27 | dB |  |
|  |  | 400G | - | 50 |  | The DGD max limits are based on a |
|  | Instantaneous | 300G | - | 66 |  | are the fiber portion of the receiver PMD |
|  | delay (DGD) | 200G | - | 66 | ps | tolerance limits. |
|  |  | 100G | - | 83 |  |  |
|  | Polarization dependent loss (PDL) | All | - | 2 | dB |  |
|  | Polarization rotation speed | All |  | 50 | krad/s |  |
|  | Inter-channel crosstalk at Rs | All |  | -8 | dB |  |
|  | Interferometric crosstalk | All |  | -35 | dB |  |

Table 11-1: Optical channel specifications

OpenZR+ MSA Specification, version 1.0

### 11.1.2 Transmitter Optical Specifications



OpenZR+ MSA Specification, version 1.0

| Ref | Parameter | Line Rate | Min | Max | Unit | Conditions/Comments |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
|  | I-Q phase imbalance | All | -5 | 5 | degrees |  |
|  | I-Q skew | All | - | 0.75 | ps |  |

Table 11-2: Tx optical specifications

### 11.1.2.1 Laser maximum frequency noise mask

The measurement resolution bandwidth shall be between 10-1 and 10-6 times the frequency of interest. The high frequency component ( 100 MHz and above) of the phase noise is consistent with a 500 kHz laser line width. The receiver local oscillator has the same line width.


Figure 11-1 Laser maximum frequency noise mask
Table 11-3 Laser maximum frequency noise values at selected frequencies

| Frequency <br> [Hz] | 1-sided Noise power <br> spectral density <br> $[\mathbf{H z} / \mathbf{H z}]$ |
| :---: | :---: |
| $1.0 \mathrm{e}+02$ | $1.0 \mathrm{e}+11$ |
| $1.0 \mathrm{e}+04$ | $1.0 \mathrm{e}+09$ |
| $1.0 \mathrm{e}+06$ | $1.0 \mathrm{e}+06$ |
| $1.0 \mathrm{e}+07$ | $6.0 \mathrm{e}+05$ |
| $1.0 \mathrm{e}+08$ | $1.6 \mathrm{e}+05$ |
| $1.0 \mathrm{e}+09$ | $1.6 \mathrm{e}+05$ |

### 11.1.2.2 Tx clock maximum phase noise mask

OpenZR+ MSA Specification, version 1.0


| PN [dBc/Hz] | Frequency [Hz] |
| :---: | :---: |
| -100 | $1.00 \mathrm{E}+04$ |
| -120 | $1.00 \mathrm{E}+05$ |
| -130 | $1.00 \mathrm{E}+06$ |
| -140 | $1.00 \mathrm{E}+07$ |

Phase noise, $\mathcal{L}(f)$,

$$
\mathrm{f}_{\mathrm{c}}=\frac{\mathrm{f}_{\text {baud }}}{128}=\sim 469.83 \mathrm{MHz}
$$

Mask does not apply to spurs, broadband phase noise only. Spurs are considered separately as per 13.1.213b and 13.1.213c

### 11.1.2.3 Tx clock maximum total integrated RMS phase jitter

rms random jitter:

$$
\sigma_{r j}=\frac{1}{2 \pi f_{c}} \sqrt{2 \cdot \int_{f_{1}}^{f_{2}} 10^{\frac{\mathcal{L}(f)}{10}} d f}
$$

rms periodic jitter (spurs):

$$
\sigma_{p j, i}=\frac{1}{\sqrt{2} \pi f_{c}} \cdot 10^{\frac{s_{i}}{20}}
$$

where,

$$
\begin{aligned}
& \mathrm{f}_{1}=10 \mathrm{kHz} \\
& \mathrm{f}_{2}=10 \mathrm{MHz} \\
& \mathrm{f}_{\mathrm{c}}=\frac{\mathrm{f}_{\text {baud }}}{128}=\sim 469.83 \mathrm{MHz} \\
& \mathcal{L}(\mathrm{f})=\text { phase noise }(\mathrm{PN}) \\
& s_{i}=\text { individual spur in }[\mathrm{dBc}]
\end{aligned}
$$

rms total jitter:

$$
\sigma_{t j}=\sqrt{\sigma_{r j}^{2}+\sum_{i=1}^{N} \sigma_{p j, i}^{2}}
$$

where,

$$
\mathrm{N}=\text { total number of spurs } .
$$

### 11.1.2.4 Minimum excess bandwidth mask

The minimum excess bandwidth is specified to guarantee multi-vendor clock recovery interoperability. The baseband Tx spectral shape in this excess bandwidth shall meet or exceed the following conditions:
The magnitude of the spectrum in the frequency range:

$$
\frac{1}{2 T} \leq f \leq \frac{9}{16 T}
$$

shall meet

$$
\begin{gathered}
|H(f)| \geq H(0) \sqrt{\frac{1}{2}\left\{1+\cos \left[8 \pi T\left(\left(\frac{8}{15 T}\right)-\frac{7}{16 T}\right)\right]\right\}} \\
\frac{1}{2 T} \leq|f| \leq \frac{8}{15 T} \\
|H(f)| \geq H(0) \sqrt{\frac{1}{2}\left\{1+\cos \left[8 \pi T\left(|f|-\frac{7}{16 T}\right)\right]\right\}} \\
\frac{8}{15 T} \leq|f| \leq \frac{9}{16 T}
\end{gathered}
$$

where T denotes the symbol period of the signal.

11.1.3 Receiver Optical Specifications

## OpenZR+ MSA Specification, version 1.0

The receiver optical tolerance specifications include margin for Tx and line impairments.


OpenZR+ MSA Specification, version 1.0

| Ref. | Parameter | Mode | Min | Max | Unit | Conditions/Comments |
| :---: | :--- | :--- | :---: | :---: | :---: | :--- |
|  | Peak PDL <br> tolerance | All | 3.5 | - | dB | Tolerance to peak PDL with $\leq 1.3 \mathrm{~dB}$ <br> additional OSNR penalty when change <br> in SOP is $\leq 1$ rad/ms. |
|  | Tolerance to <br> change in SOP | All | 50 | - | $\mathrm{krad} / \mathrm{s}$ | With $\leq 0.5 \mathrm{~dB}$ additional OSNR penalty <br> over all PMD and PDL values. |
|  | Optical input <br> power transient <br> tolerance | All | -2 | 2 | dB | With $\leq 0.5$ dB additional OSNR penalty <br> over all PMD and PDL values. |

Table 11-4: Rx optical specifications

### 11.2 OpenZR+, Single wavelength, Unamplified:

TBD.

### 11.3 Optical Parameter Definitions

### 11.3.1 Receiver Optical Signal-to-noise Ratio Tolerance

The receiver OSNR tolerance is defined as the minimum value of OSNR (referred to 0.1 $\mathrm{nm} @ 193.7 \mathrm{THz}$ or 12.5 GHz ) that can be tolerated while maintaining the maximum BER of the application. This must be met for all powers between the maximum and minimum mean input power with a transmitter with worst-case values of:

- Transmitter optical return loss,
- Receiver connector degradations
- Measurement tolerances

The receiver OSNR tolerance does not have to be met in the presence of chromatic dispersion, non-linear effects, reflections from the optical path, PMD, and PDL or optical crosstalk. These effects are specified separately but contribute to total optical path OSNR penalty.

System integrators need to account for these path penalties when evaluating network performance.

### 11.3.2 Tx spectral excursion

Spectral excursion is defined as the difference between the nominal central frequency of the channel and the -3.0 dB points of the transmitter spectrum furthest from the nominal central frequency measured at point $S_{\text {s. }}$. This includes the laser frequency accuracy error value from the nominal center frequency. See Figure 11-2.


Figure 11-2 Example of $\mathbf{3 2} \mathbf{~ G H z}$ maximum spectral excursion

### 11.3.3 Out-of-Band OSNR (OOB OSNR)

Out-of-Band OSNR (OOB OSNR) is 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.

### 11.3.4 Differential Group Delay (DGD)

Differential group delay (DGD) is the time difference between the fractions of an optical signal transmitted in the two principal states of polarization. For distances greater than several kilometers, and assuming random (strong) polarization mode coupling, DGD in a fiber can be statistically modelled as having a Maxwellian distribution.

Due to the statistical nature of polarization mode dispersion (PMD), the relationship between maximum instantaneous DGD and mean DGD can only be defined probabilistically. The probability of the instantaneous DGD exceeding any given value can be inferred from its Maxwellian statistics.

For purposes of this specification the ratio of maximum instantaneous DGD to mean DGD is defined as 3.3 , corresponding to the probability of exceeding the maximum DGD $4.1 \times$ 10-6.

### 11.3.5 Ripple

Ripple is defined as the peak-to-peak difference in insertion loss between the input and output ports of the black link over that channel in the frequency (or wavelength) range of the channel $+/$ - the maximum spectral excursion. See Figure 11-3.


Figure 11-3 Illustration of maximum ripple

### 11.3.6 Optical return loss at Ss

Reflections are caused by refractive index discontinuities along the optical path. If not controlled, they can degrade system performance through their disturbing effect on the operation of the optical source, or through multiple reflections which lead to interferometric noise at the receiver. Reflections from the optical path are controlled by specifying the:

- minimum optical return loss of the cable plant at the source reference point $\left(\mathrm{S}_{\mathrm{s}}\right)$, including any connectors; and
- maximum discrete reflectance between source reference point ( $\mathrm{S}_{\mathrm{s}}$ ) and receive reference point ( Rs )

Reflectance denotes the reflection from any single discrete reflection point, whereas the optical return loss is the ratio of the incident optical power to the total returned optical power from the entire fiber including both discrete reflections and distributed backscattering such as Rayleigh scattering.

### 11.3.7 Discrete reflectance between Ss and Rs

Optical reflectance is defined to be the ratio of the reflected optical power present at a point, to the optical power incident to that point. The maximum number of connectors or other discrete reflection points which may be included in the optical path must be such as to allow the specified overall optical return loss to be achieved.

### 11.3.8 Polarization Dependent Loss (PDL)

The polarization dependent loss (PDL) is the difference (in dB ) between the maximum and minimum values of the channel insertion loss (or gain) of the black link from point $\mathrm{S}_{\mathrm{s}}$ to $\mathrm{R}_{\mathrm{s}}$ due to a variation of the State Of Polarization (SOP) over all state of polarizations.

### 11.3.9 Polarization rotation speed

The polarization rotation speed is the rate of rotation in Stokes space of the two polarizations of the optical signal at point $\mathrm{R}_{\mathrm{s}}$ measured in $\mathrm{krad} / \mathrm{s}$.

### 11.3.10Inter-channel crosstalk

Inter-channel crosstalk is defined as the ratio of total power in all the disturbing channels to that in the wanted channel, where the wanted and disturbing channels are at different wavelengths.

Specifically, the isolation of the link shall be greater than the amount required to ensure that when any channel is operating at the minimum mean output power at point $S_{s}$ and all of the others are at the maximum mean output power, then the inter-channel crosstalk at the corresponding point $\mathrm{Rs}_{\mathrm{s}}$ is less than the maximum inter-channel crosstalk value.

### 11.3.11 Interferometric crosstalk

Interferometric crosstalk is defined as the ratio of the disturbing power to the wanted power within a single channel, where the disturbing power is the power (not including ASE) within the optical channel that would remain if the wanted signal were removed from the link while leaving all of the other link conditions the same.

Specifically, the isolation of the link shall be greater than the amount required to ensure that when any channel is operating at the minimum mean output power at point $\mathrm{S}_{\mathrm{s}}$ and all of the others are at the maximum mean output power, then the interferometric crosstalk at the corresponding point $\mathrm{R}_{\mathrm{s}}$ is less than the maximum interferometric crosstalk value.

### 11.3.12 I-Q offset

I-Q offset is measured separately on each polarization and is calculated using the following formula:

$$
\begin{gathered}
P_{\text {excess }}=\frac{\mathrm{I}_{\text {mean }}^{2}+\mathrm{Q}_{\text {mean }}^{2}}{\mathrm{P}_{\text {Signal }}} \\
I Q_{\text {offset }}=10 \log _{10}\left(\mathrm{P}_{\text {excess }}\right)
\end{gathered}
$$

Instantaneous I-Q offset is measured with an averaging period $\leq 1 \mu$ s to be consistent with the timescales of receiver DSP operations.

OpenZR+ MSA Specification, version 1.0

## 12 Appendix - Host interfaces (informative)

An OpenZR+ Transponder/Muxponder may support the following host interface protocols:
Ethernet:

- 400GBASE-R
- 200GBASE-R
- 100GBASE-R

The Host/Client interface signaling is expected to conform to existing protocol standards (IEEE 802.3тм-2018) and operate over standard physical layer interface(s).

### 12.1 400GE Clients

If the host/client signal is 400 GE , then it can be multiplexed into a ZR400 frame for transmission. The required and optional (O) Ethernet physical layer clauses associated with 400GE clients are listed in Table 12-1.

Table 12-1 Ethernet physical layer clauses associated with 400GE client signals

| Associated clause | ZR400-OFEC- |
| :--- | :---: |
| 16QAM |  |$|$ Required.

The client logic for 400GE is shown in Figure 12-1. The block diagram shows the required operations between a 400GE PMA sublayer and the GMP mapping sublayer of the OpenZR+ architecture.

OpenZR+ MSA Specification, version 1.0


Figure 12-1 400GE client logic block diagram

OpenZR+ MSA Specification, version 1.0

### 12.2 200GE Clients

If the host/client signal is 200GE, then it may be multiplexed into a ZR200 or a ZR400 frame for transmission. The required and optional (O) Ethernet physical layer clauses associated with 200GE clients are listed in Table 12-2.

Table 12-2 Ethernet physical layer clauses associated with 200GE client signals

| Associated clause | $\begin{gathered} \hline \text { ZR400-OFEC- } \\ \text { 16QAM } \end{gathered}$ | $\begin{gathered} \hline \text { ZR300-OFEC- } \\ \text { 8QAM } \end{gathered}$ | $\begin{gathered} \text { ZR200- } \\ \text { OFEC-QPSK } \end{gathered}$ |
| :---: | :---: | :---: | :---: |
| 117-RS | Required (up to 2) | N/A | Required |
| 117-200GMII | O |  | O |
| 118-200GMII Extender | O |  | O |
| 119-PCS for 200GBASE-R | Required (up to 2) |  | Required |
| 120-PMA for 200GBASE-R | Required (up to 2) |  | Required |
| 120B-Chip-to-chip 200GAUI-8 | O |  | O |
| 120C-Chip-to-module 200GAUI-8 | O |  | O |
| 120D-Chip-to-chip 200GAUI-4 | O |  | O |
| 120 E - Chip-to-module 200GAUI-4 | O |  | O |

The client logic for 200GE is shown in Figure 12-2. The block diagram shows the required operations between a 400GE PMA sublayer and the GMP mapping sublayer of the OpenZR+ architecture.


Figure 12-2 200GE client logic block diagram

### 12.3 100GE Clients

If the host/client signal is 100GE, then it may be multiplexed into a ZR100, ZR200, ZR300 or ZR400 frame for transmission. The required and optional (O) Ethernet physical layer clauses associated with 100GE clients are listed in Table 12-3.

Some 100GE clients may be 64b/66b encoded and will require transcoding to $256 \mathrm{~b} / 257 \mathrm{~b}$ blocks before conversion to a ZR100 frame. Other 100GE clients that implement clause 91 RS-FEC will be $256 \mathrm{~b} / 257 \mathrm{~b}$ encoded and will require FEC decoding before conversion to a ZR100 frame. All 100GE clients will have 8-byte alignment markers on 20 virtual PCS lanes. These will be removed by OpenZR+ implementations and replaced by $4 \times 120 \mathrm{~b}$ alignment markers in the ZR100 frame as described in 5.4.2.

Table 12-3 Ethernet physical layer clauses associated with 100GE client signals

| Associated clause | $\begin{gathered} \text { ZR400-OFEC- } \\ \text { 16QAM } \end{gathered}$ | $\begin{gathered} \text { ZR300- } \\ \text { OFEC-8QAM } \end{gathered}$ | $\begin{gathered} \text { ZR200-OFEC- } \\ \text { QPSK } \end{gathered}$ | $\begin{gathered} \text { ZR100-OFEC- } \\ \text { QPSK } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| 81-RS | Required (up to 4) | Required (up to 3) | Required (up to 2) | Required |
| 81-100GMII | O | O | O | O |
| 82-PCS | Required (up to 4) | Required (up to 3) | Required (up to 2) | Required |
| 91-RS-FEC RS $(514,528)_{\text {a }}$ | O | O | O | O |
| 91-RS-FEC RS(514,544)b | O | O | O | O |
| 83-100GBASE-R PMAa | O | O | O | O |
| 135-100GBASE-P PMA ${ }_{\text {b }}$ | O | O | O | O |
| 83D-CAUI-4 C2Ca | O | O | O | O |
| 83E-CAUI-4 C2Ma | O | O | O | O |
| 135D-100GAUI-4 C2Cb | O | O | O | O |
| 135E-100GAUI-4 C2Mb | O | O | O | O |
| 135F-100GAUI-2 C2Cb | O | O | O | O |
| 135G-100GAUI-2 C2Mb | O | O | O | O |

Notes: aIf CAUI-4 C2C or C2M are present then clause 83 100GBASE-R PMA is required and clause 91 RS-FEC with $\operatorname{RS}(514,528)$ is optional.
bIf 100GAUI-4 C2C, 100GAUI-4 C2M, 100GAUI-2 C2C or 100GAUI-2 C2M are present then clause 135 100GBASE-P PMA is required and clause 91 RS-FEC with $\operatorname{RS}(514,544)$ is required.

The client logic for a 100GE client implementing clause 91 RS-FEC is shown in Figure 12-3. The block diagram shows the required operations between a 100GE PMA sublayer and the 100 G GMP mapping sublayer of the OpenZR+ architecture.

The client logic for a 100GE client without FEC is shown in Figure 12-3. The block diagram shows the required operations between a 100GE PMA sublayer and the 100G GMP mapping sublayer of the OpenZR+ architecture.

OpenZR+ MSA Specification, version 1.0


Figure 12-3 100GE with RS-FEC logic block diagram


Figure 12-4 100GE client without FEC logic block diagram

### 12.4 Client signal processing

OpenZR+ implementations provide the required processing between incoming and outgoing client signals and the $100 \mathrm{ZR}, 200 \mathrm{ZR}$ or 400 ZR formatted frames detailed in sections 3.3, 3.5 and 3.6. The required functions include:

PMA processing

- Per-input-lane clock and data recovery
- Bit-level multiplexing
- Clock generation
- Signal drivers
- Tolerate skew variation
- Optionally provide loopback and test-pattern generation and checking

PCS processing

- Encoding (decoding) data octets to (from) 66-bit blocks (64B/66B) [100GE clients without RSFEC only].

OpenZR+MSA Specification, version 1.0

- Transcoding from 66-bit blocks to (from) 257-bit blocks [100GE clients without RS-FEC only].
- Insert (remove) alignment markers
- Reed-Solomon encoding (decoding) the 257-bit blocks.
- Transferring encoded data to (from) the PMA sublayer including alignment lock, lane deskew, lane reorder and de-interleave in the egress direction.
[End of Document]

