QuickTime<sup>™</sup> and a GIF decompressor are needed to see this picture.

Sponsored

# High Speed Optical Networking Task 3: Progress Report

#### Joel M. Morris, PhD

Communications and Signal Processing Laboratory (CSPL) CSEE Department/UMBC 1000 Hilltop Circle, Catonsville, MD 21250 morris@umbc.edu 410.455.3503

Presented @ LTS, 27 June 2003



1

# Outline

- FEC Code Design: RCD Code subset of LDPC Codes
- Channel Models for FEC Code and Decision Circuit
- Performance (I deal) Assessment via Bounds and Simulation
- Performance (Non-I deal) Assessment via Implementation I ssues



# FEC Code Design: RCD Codes

- Subset of Regular LDPC Codes
- Decodable via Variety of Decoder Schemes
   w/ Choice Driven by Performance vs. Technology Trade-offs
  - Majority-Logic (MLG) Decoding
  - I terative Hard-Decision Decoding (Bit-Flipping)
  - I terative Soft-Decision Decoding (SPA)
- High Code Rates (Low Overhead) Possible



# LDPC vs. TC Codes

- Best designed LDPC codes shown to surpass corresponding best known turbo codes.
- For LDPC codes, decoder failure is a detectable event.
- TCCs show an error floor at a relatively higher probability of error. Hence, quite often, they require an outer code.
- LDPC decoding fully parallelizable with respect to graph nodes.

### Channel Models for FEC Code and Decision Circuit

Investigate More Accurate Models for Code/Decision Circuit Studies:

- BAC w/Chi-Square *pdf*s
  - Single threshold
  - Higher channel capacity
  - Requires knowing exact pdfs
  - Looking at robust (minimax) decision characterization
- BSC/E
  - Double threshold to generate erasure output plus 0 and 1
  - Higher channel capacity
  - Codes can correct more erasures than errors via (2e+f) < d<sub>min</sub>

# Decision Circuit pdfs





### Decision Thresholds for Different Channel Models





#### One-Threshold Decisioning -- BSC/BAC





# **BSC/BAC** Capacity



BSC capacity is

$$C = 1 - H(p), \quad p = e_0 = e_1$$

$$C = H[p_0(1 - \boldsymbol{e}_0) + (1 - p_0)\boldsymbol{e}_1] - p_0H[\boldsymbol{e}_0] - (1 - p_0)H[\boldsymbol{e}_1]$$

$$p_0 = 1 - \frac{1 - (1 + k)\boldsymbol{e}_0}{(1 - \boldsymbol{e}_0 - \boldsymbol{e}_1)(1 + k)} \qquad k = \exp\{\frac{H(\boldsymbol{e}_1) - H(\boldsymbol{e}_0)}{(\log_2 e)(1 - \boldsymbol{e}_0 - \boldsymbol{e}_1)}\}$$



University of Maryland Baltimore County

## Chi-Square *pdf* Parameters

$$p_{1}(I) = \frac{1}{N_{0}} \left(\frac{I}{E}\right)^{(M-1)/2} exp\left(-\frac{I+E}{N_{0}}\right) I_{M-1}\left(2\frac{\sqrt{IE}}{N_{0}}\right)$$

$$p_{0}(I) = \frac{1}{N_{0}} \frac{\left(I/N_{0}\right)^{M-1} exp\left(-I/N_{0}\right)}{(M-1)!}$$

$$Q = \left(\mathbf{m}_{1} - \mathbf{m}_{0}\right) / \left(\mathbf{s}_{1} + \mathbf{s}_{0}\right)$$

$$\mathbf{s}_{0} = \sqrt{\frac{B_{0}}{B_{e}}} \qquad I_{0} = \frac{B_{0}}{B_{e}} = M$$

$$\mathbf{s}_{1} = \sqrt{\frac{B_{0}}{B_{e}}} + 2Q \qquad I_{1} = 2Q\sqrt{\frac{B_{0}}{B_{e}}} + 2Q^{2} + \frac{B_{0}}{B_{e}}$$

## Optimal Decision Thresholds $(a_{opt})$ vs. b and M







# Channel Capacity vs. $\boldsymbol{b}$ and M using $\boldsymbol{a}_{\text{opt}}$





#### Average $P_e$ as a Function **b** and M





#### Two-Threshold Decisioning - BSC/E





#### Capacity of BSC/E vs. t and CSNR



#### Shannon Limit Curves - BSC/E





### Shannon $P_e$ vs. $E_b/N_0$ Lower Limit Curves - BSC/E









18

University of Maryland Baltimore County

# FEC Decoding for the BSC/E

Hard-decision decoding algorithms for the BSC can be suitably modified to perform decoding for the BSC/E.

Begin with a bounded distance decoder for the BSC and received word w.

- 1. Replace every location in w that has an erasure with 1 and decode to obtain a resulting codeword  $c_1$ .
- 2. Then replace every location in w that has an erasure with 0 and decode to obtain a resulting codeword  $c_0$ .
- 3. Compute the Hamming distance between the pair w and  $c_1$  and the pair w and  $c_0$ .
- 4. Choose  $c_1$  as the decoder output if its Hamming distance from w is less than that of  $c_0$  from w. Else choose  $c_0$ .
- *Note:* An erasure in w contributes equally to both Hamming distances.



# FEC Decoding for the BSC/E

The preceding decoder for the BSC/E can correct all patterns of e errors and f erasures as long as  $(2e + f) < d_{min}$ . Hence it is a bounded distance decoder for the BSC/E.

$$P_{CD} = \sum_{e,f \ge 0, (2e+f) < d_{\min}} {n \choose f} {n-f \choose e} \mathbf{a}^{f} \mathbf{b}^{e} (1-\mathbf{a}-\mathbf{b})^{n-f-e} \sim \text{Prob. of Correct}$$
  
Decoding

 $P_{I} = 1 - P_{CD}$ 

~ Prob. of Incorrect Decoding



20

# $P_{I}^{(t)}$ vs. CSNR Plots





University of Maryland Baltimore County





CSPLA

# $P_{I}^{(t)}$ vs. CSNR Plots





University of Maryland Baltimore County

# **BAC/AE** Channel Model



# **Related Conclusions**

- Using two-thresholds (BSC/E) provides coding and capacity gains over the one-threshold (BSC).
- Gains achieved by only doubling decoding and decisioning complexity.
- Improvements in employing a BSC/E channel model:
  - Decrease with increasing n and  $d_{\min}$
  - Decrease with increasing P<sub>I</sub>

### Performance (I deal) Assessment via Bounds and Simulations

- Union Bound on BER/WER vs.  $E_{\rm b}/N_{\rm o}$  requires Weight Enumerator Function (WEF) for Code

$$W(z) = \sum_{d=0}^{n} A_d z^d$$
,  $\{A_d\}$  ~ WEF coefficients

- Simulations for BER/WER vs. E<sub>b</sub>/N<sub>o</sub> require major computing power/time, or modified importance sampling (IS)
  - ~ Multicanonical Monte Carlo technique under investigation

26

# Error Correction Capability wrt $d_{min}$ (BSC)



$$P_{CD} = \sum_{i=0}^{t} \binom{n}{i} p^{i} (1-p)^{n-i}$$

~ Prob. Correct Decoding

~ Prob. Failure



 $m = 0 < k \qquad m > < m$ 

 $P_F = 1 - P_{CD} - P_E$ 

#### Water-Fall and Error-Floor Behavior





# RCD-LDPC Code WEF

The RCD code WEF is given by

$$W(z) = 2^{-(3h-2)}(1+z)^{h^{2}}$$
  
•  $\sum_{a=0}^{h} \sum_{b=0}^{h-1} \sum_{c=0}^{h-1} h_{a}h_{b} \frac{h-b}{h} \frac{h-c}{h} \sum_{m=1}^{K_{a,b}} p_{m} \left(\frac{1-z}{1+z}\right)^{w} \sum_{n=1}^{N} \prod_{l=1}^{L_{m}} \left(\frac{h_{l,m}}{\Delta_{l,n}}\right) \left(\frac{1-z}{1+z}\right)^{-2\Delta_{l,n}I_{l,m}}$ 



29

### RCD-LDPC Code WEF Plots

WEF plots for RCD codes of n = 49 and 121





## $d_{\min}$ (= $d_6$ ) Component of RCD WER





# **Related Conclusions**

- Solution for WEF for a class of LDPC codes obtained
- Results show the RCD-LDPC codes are weakly-random-like codes with WEF approximately Binomial for moderate code lengths n
- Technique likely extendable to related classes of LDPC codes
- Important for WER/BER vs. SNR performance assessment

32

### Performance (Non-I deal) Assessment via Implementation I ssues

- Effect of Mismatched/Incorrect Decision Circuit Statistics on SPA
  - Incorrect estimate of initial statistics
  - Time-varying statistics
- Effect of Logic Circuit Errors on Majority-Logic Decoding e.g., optical logic devices have appreciable error rates

### SPA Sensitivity to Channel Noise Assumptions

• We define 
$$a = \frac{s_a^2}{s_t^2}$$
 where,

= assumed noise variance for APP computation  $s_a^2$  = true noise variance on channel  $s_t^2$ 

is set during initialization

٠

 $\boldsymbol{s}_a^2$ 

#### Surface Plot of WER vs. a and $s_{t}$ ?





2D Plot of WER vs.  $\boldsymbol{s}_{a}$ ? for Given  $\boldsymbol{s}_{t}$ ?







# Related Conclusions

- Performance of SPA is sensitive to changes in noise variance  $s^2$ .
- WER and BER were observed to be "asymmetrical" about a = 1 when  $s^2$  is fixed.
- Results indicate the range of inaccuracy allowable in estimating to achieve a given performance tolerance.  $s^2$
- There is a broad minimum for WER wrt where WER remains within twice that at when is fixed.
   a
- Increase  $fn^1WER$  is  $nfo^2$  reapid beyond this range.
- It may be advantageous to assume a that is 1.05 1.1 times that of the true value during initialization -- yields a more "symmetrical" performance wrt noise variations.  $s^2$

### Logic Circuit Errors: Motivation

- Traditionally, logic devices such as OR, AND, XOR-gates have been assumed to perform perfectly without introducing any errors at the output.
- However, for CMOS devices, as they approach the fundamental physical limits, or for logic devices implemented in the optical domain, this assumption may no longer be true.
- More stringent requirements on the probability of error that can be tolerated on communication channels may also render this assumption tenuous, e.g., optical channels demand a BER of ~10<sup>-15</sup>.

### Error Model for Simple Logic Devices

- Probability transition matrices can model errors introduced by logic devices.
- 2-inp XOR gate
  - 4 i/p states
  - 2 o/p states

| Ip 1 | lp2 | Ор |
|------|-----|----|
| 0    | 0   | 0  |
| 0    | 1   | 1  |
| 1    | 0   | 1  |
| 1    | 1   | 0  |





University of Maryland Baltimore County

### Analysis of Error Introduced by a Logic Circuit System

• Simplest technique: Find probability of correct output  $(P_c)$  for each logic device from its transition matrix. Probability of error at the output of the logic circuit,  $(P_E)$  is given as

$$P_E = 1 - \prod_{\text{All logic devices}} P_C$$

- For a more accurate analysis, one has to determine the overall transition matrix that relates the output of the logic circuit to its inputs.
  - Logic circuit specific
  - May not be easy
  - Need to exploit whatever independence exists among input variables



# **Related Conclusions**

- Logic gates with internal errors, particularly optical logic gates, can affect the error performance of MLG decoders
- Similar effects expected for other logic circuit systems
- An analysis method is under development, based on a probability transition matrix approach.

41

# Related Publications

- 1. "On RCD SPC Codes as LDPC Codes Based on Arrays and Their Equivalence to Some Codes Constructed from Euclidean Geometries and BI BDs", UMBC Technical Report No.: CSPL TR: 2002-1, June 2002
- 2. "On the Sensitivity of the SPA for LDPC Codes ..... to Variations in Channel Noise", 2003 Conf Inform. Sci. and Sys. (CI SS2003), The Johns Hopkins University, 12-14 Mar. 2003.
- 3. "On Minimum Probability of Error Decision Thresholds for FEC Codes on the BSC/E ......", *CI SS2003*, 12-14 Mar. 2003.
- 4. "On the Weight Enumerator Function for a Class of Regular LDPC Codes", *CI SS2003*, 12-14 Mar. 2003.
- 5. "On FEC Code Performance I mprovement Comparisons between the BSC and the BSC/E under Bounded Distance Decoding", *2003 Canadian Workshop on I nform. Thy*, Waterloo, Ontario, 18-21 May 2003.
- 6. "The RCD Array Code is a Weakly Random-Like Code", to appear 3<sup>rd</sup> Int'l. Symp. on Turbo Codes and Related Topics, Brest, France, 1-5 Sept. 2003.
- 7. "A Performance Surface Characterizing Sensitivity to Incorrect Channel Noise Statistics for SPA Decoding of LDPC Codes ......", to appear 3<sup>rd</sup> Int'l. Symp. on Turbo Codes and Related Topics, Brest, France, 1-5 Sept. 2003.

# **Related Publications**

8. W. Martin, "The WEF for a Class of Regular LDPC Codes: The RCD Array Code", PhD Dissertation, 2003, CSEE Dept., UMBC, Catonsville, MD 21250

43