FPGA implementation of robust symmetrical number system in high-speed folding analog-to-digital converters

Lim, Han Wei
Monterey, California. Naval Postgraduate School

http://hdl.handle.net/10945/5062

Downloaded from NPS Archive: Calhoun
FPGA IMPLEMENTATION OF ROBUST SYMMETRICAL NUMBER SYSTEM IN HIGH-SPEED FOLDING ANALOG-TO-DIGITAL CONVERTERS

by

Han Wei Lim

December 2010

Thesis Advisor: Phillip E. Pace
Second Reader: David C. Jenn

Approved for public release; distribution is unlimited
Analog-To-Digital Converters (ADCs) are integral building blocks of most sensor and communication systems today. As the need for ADCs with faster conversion speeds and lower power dissipation increases, there is a growing motivation to reduce the number of power-consuming components by employing folding circuits to fold the input analog signal symmetrically, prior to quantization by high-speed comparators. These properties of low-power consumption, compactness, high-resolution and fast conversion speeds make folding ADCs an attractive concept to be used for defense applications, such as unmanned systems, direction-finding antenna architectures and system-on-a-chip applications.

In this thesis, a prototype of an optical folding ADC was implemented using the Robust Symmetrical Number System (RSNS). The architecture employs a three-modulus (Moduli 7, 8, 9) scheme to preprocess the antenna signal.

This thesis focuses on the simulation and hardware implementation of this ADC architecture, including the bank of comparators and the RSNS-to-Binary Conversion within a Field Programmable Gate Array (FPGA), to achieve an eight-bit Dynamic Range of 133. This is then integrated with the front-end photonics implementation (designed under a separate thesis).

Low frequency analyses of the results using a 1-kHz input signal indicate a 5.39 Effective Number of Bits (ENOB), a Signal-to-Noise Ratio plus Distortion (SINAD) of 34.21 dB, and a Total Harmonic Distortion (THD) of –61.68 dB.
ABSTRACT

Analog-To-Digital Converters (ADCs) are integral building blocks of most sensor and communication systems today. As the need for ADCs with faster conversion speeds and lower power dissipation increases, there is a growing motivation to reduce the number of power-consuming components by employing folding circuits to fold the input analog signal symmetrically prior to quantization by high-speed comparators. These properties of low-power consumption, compactness, high-resolution and fast conversion speeds make folding ADCs an attractive concept to be used for defense applications, such as unmanned systems, direction-finding antenna architectures and system-on-a-chip applications.

In this thesis, a prototype of an optical folding ADC was implemented using the Robust Symmetrical Number System (RSNS). The architecture employs a three-modulus (Moduli 7, 8, 9) scheme to preprocess the antenna signal.

This thesis focuses on the simulation and hardware implementation of this ADC architecture, including the bank of comparators and the RSNS-to-Binary Conversion within a Field Programmable Gate Array (FPGA), to achieve an eight-bit dynamic range of 133. This is then integrated with the front-end photonics implementation (designed under a separate thesis).

Low frequency analyses of the results using a 1-kHz input signal indicate a 5.39 Effective Number of Bits (ENOB), a Signal-to-Noise Ratio plus Distortion (SINAD) of 34.21 dB, and a Total Harmonic Distortion (THD) of -61.68 dB.
# TABLE OF CONTENTS

I. INTRODUCTION
   A. FOLDING-TYPE ANALOG-TO-DIGITAL CONVERTERS
   B. SUMMARY OF RECENT RESEARCH
   C. PRINCIPAL CONTRIBUTIONS
   D. THESIS OUTLINE

II. ROBUST SYMMETRICAL NUMBER SYSTEM
   A. RSNS STRUCTURE
   1. Dynamic Range
   2. Ambiguity Types
   3. Sub-Channel Analysis
   4. Even-Odd Analysis
   B. RSNS DYNAMIC RANGE SEARCH ALGORITHM
   1. Dynamic Range Upper Bound
   2. RSNS Vector Ambiguity Locations
   3. Minimal Ambiguity Pair Locations
   4. Consecutive Minimal Pair Locations
   C. RSNS-TO-BINARY CONVERSION ALGORITHM
   1. RSNS-RNS Relationship
   2. Dynamic Range Compression
   3. Alignment of RNS Least Positive Solution

III. RSNS-TO-BINARY CONVERSION
   A. LOGIC BLOCK DIAGRAM OF RSNS-TO-BINARY CONVERTER
   B. POSITION BIT CONVERSION
   1. RSNS Thermometer Code to RNS Residue/Position Bit Conversion
   2. Position Bit Equations
   C. EVEN RESIDUE AND SUB-CHANNEL FLAGS
   1. Even Residue Flags
   2. Sub-Channel Flags
   D. CONDITIONAL BIT REVERSAL
   E. LEAST POSITIVE SOLUTION ALIGNMENT
   1. Full Dynamic Range With LPS Priority
   2. Truncated Dynamic Range
   F. ENCODER
   G. ADDER

IV. LABVIEW IMPLEMENTATION OF RSNS-TO-BINARY CONVERSION
   A. LABVIEW SCHEMATICS OF RSNS-TO-BINARY CONVERTER
   B. POSITION BIT CONVERSION AND EVEN RESIDUE/SUB-CHANNEL FLAGS
   1. Channel 1
   2. Channel 2
3. Channel 3 ............................................................................................47
4. Sub-Channel Flags ..............................................................................48
C. CONDITIONAL BIT REVERSAL ..............................................................49
1. Channel 2 Reversal ............................................................................50
2. Channel 3 Reversal ............................................................................50
D. ALIGNMENT LOGIC ............................................................................51
E. ENCODER .............................................................................................53
1. Truncated Dynamic Range ...............................................................54
2. Full Dynamic Range ..........................................................................55
F. ADDER .................................................................................................57
V. SIMULATION OF RSNS-TO-BINARY CONVERSION .....................................59
A. LABVIEW THERMOMETER CODE GENERATORS ................................59
1. Channel 1 ............................................................................................59
2. Channel 2 ............................................................................................62
3. Channel 3 ............................................................................................65
B. SIMULATION MODEL ............................................................................69
C. SIMULATION RESULTS ............................................................................70
1. Truncated Dynamic Range ...............................................................70
2. Full Dynamic Range ..........................................................................71
3. LPS Priority Circuit ..........................................................................71
4. Full Dynamic Range with LPS Priority Circuit ..............................73
VI. ADC INTEGRATION ....................................................................................75
A. DIGITAL DECODING SUB-SYSTEM .......................................................75
B. COMPARATORS ......................................................................................76
1. Channel 1 ............................................................................................76
2. Channel 2 ............................................................................................77
3. Channel 3 ............................................................................................78
C. FPGA IMPLEMENTATION .......................................................................79
1. FPGA VI .............................................................................................80
2. Host Interface VI ................................................................................82
3. Results .................................................................................................82
VII. ADC PERFORMANCE ................................................................................75
A. LINEARITY ERRORS ................................................................................85
1. ADC Resolution ..................................................................................87
2. Differential Non-Linearity .................................................................87
3. Integral Non-Linearity .........................................................................87
B. NOISE FLOOR ANALYSIS ......................................................................89
1. Quantization Noise .............................................................................89
2. Clock Jitter .........................................................................................91
C. DYNAMIC PERFORMANCE ANALYSIS .................................................92
1. Signal-to-Noise Ratio ........................................................................92
2. Total Harmonic Distortion ...............................................................92
3. SNR Plus Distortion .........................................................................92
4. Effective Number of Bits ...................................................................92
LIST OF FIGURES

Figure 1. Block Diagram of a Three-Channel Folding ADC Architecture (After [3]). ....2
Figure 2. Three-Channel RSNS for Moduli $m_j = [7 \ 8 \ 9]$. .................................................6
Figure 3. Folded RSNS Waveforms for Moduli $m_j = [7 \ 8 \ 9]$ .............................................6
Figure 4. Single Channel Ambiguity Types ($m_1 = 7$)............................................................8
Figure 5. Decimation of Channels into Sub-Channels for Moduli $m_j = [7 \ 8 \ 9]$ ..............9
Figure 6. RSNS Vectors for Sub-Channels 0, 1 and 2 ..............................................................9
Figure 7. Plot of Sub-Channels 0, 1 and 2..............................................................................10
Figure 8. Even-Odd Structure of RSNS Vectors for Sub-Channels 0, 1 and 2......................12
Figure 9. Overall Even-Odd Structure of RSNS Vectors .......................................................12
Figure 10. RSNS Vector Ambiguity Locations (Three-Channel Case) ....................................14
Figure 11. RSNS Vector Ambiguity Locations (for Moduli 7, 8 and 9) .................................16
Figure 12. Minimal Pair Locations .......................................................................................17
Figure 13. Consecutive Minimal Pair Locations .....................................................................18
Figure 14. One-to-One Correspondence between RSNS and RNS Vectors .........................19
Figure 15. RSNS and RNS Vectors for Even Index $g$ ..........................................................20
Figure 16. RNS Vectors Spanning DR (Before and After Shifting Start Position) .............22
Figure 17. RSNS-to-Binary Conversion Algorithm (After [2]). ..........................................24
Figure 18. Logic Block Diagram of RSNS-to-Binary Converter (After [4]) .........................25
Figure 19. RSNS Thermometer Codes for $m_i = [7 \ 8 \ 9]$ ...................................................26
Figure 20. Channel 1 RSNS-to-RNS Conversion for all Sub-Channels (After [2]) ............27
Figure 21. Channel 1 RSNS-RNS-Position Bit Correspondences for all Sub-Channels (After [2]) ........................................................................................................28
Figure 22. Channel 2 RSNS-to-RNS Conversion for Sub-Channels 0 and 1 (After [2]) ........................................................................................................................29
Figure 23. Channel 2 RSNS-RNS-Position Bit Correspondences for Sub-Channels 0 and 1 (After [2]) ........................................................................................................29
Figure 24. Channel 2 RSNS-to-RNS Conversion for Sub-Channel 2 (After [2]) .............30
Figure 25. Channel 2 RSNS-RNS-Position Bit Correspondences for Sub-Channel 2 (After [2]) ........................................................................................................................30
Figure 26. Channel 3 RSNS-to-RNS Conversion for Sub-Channel 0 (After [2]) ..........31
Figure 27. Channel 3 RSNS-RNS-Position Bit Correspondences for Sub-Channel 0 (After [2]) ..................................................................................................................31
Figure 28. Channel 3 RSNS-to-RNS Conversion for Sub-Channels 1 and 2 (After [2]) .....................................................................................................................32
Figure 29. Channel 3 RSNS-RNS-Position Bit Correspondences for Sub-Channels 1 and 2 (After [2]) ...........................................................................................................32
Figure 30. LPS Alignment using Position Bits .......................................................................37
Figure 31. Adder Function for Implementing Multiplication by Three (After [2]) .............41
Figure 32. Single Adder for Converting LPS to Binary (After [2]) ......................................41
Figure 33. Overall LabVIEW Schematics of RSNS-to-Binary Converter ..........................44
Figure 34. LabVIEW Schematics of Channel 1 Position Bit and Even Residue Flag .......45
# LIST OF TABLES

<table>
<thead>
<tr>
<th>Table</th>
<th>Description</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Table 1</td>
<td>List of Variables</td>
<td>xx</td>
</tr>
<tr>
<td>Table 2</td>
<td>Encoder Logic Table</td>
<td>53</td>
</tr>
<tr>
<td>Table 3</td>
<td>Channel 1 (m_1 = 7) Logic Table</td>
<td>60</td>
</tr>
<tr>
<td>Table 4</td>
<td>Channel 2 (m_2 = 8) Logic Table</td>
<td>62</td>
</tr>
<tr>
<td>Table 5</td>
<td>Channel 3 (m_3 = 9) Logic Table</td>
<td>65</td>
</tr>
<tr>
<td>Table 6</td>
<td>Comparison of Dynamic Range</td>
<td>73</td>
</tr>
<tr>
<td>Table 7</td>
<td>ADC Dynamic Performance Parameters</td>
<td>93</td>
</tr>
</tbody>
</table>
THIS PAGE INTENTIONALLY LEFT BLANK
EXECUTIVE SUMMARY

Analog-To-Digital Converters (ADCs) are integral building blocks of most sensor and communication systems today. As the need for ADCs with faster conversion speeds and lower power dissipation increases, there is a growing motivation to reduce the number of power-consuming components by employing folding circuits to fold the input analog signal symmetrically prior to quantization by high-speed comparators. The folding of the analog signal allows comparators to be repetitively used, resulting in a smaller die area and lower power consumption.

These properties of low-power consumption, compactness, high-resolution and fast conversion speeds make folding ADCs an attractive concept to be used for defense applications that involve power and size constraints as key factors in the design of battlefield systems and sensors.

In this thesis, a prototype of an optical folding ADC was implemented using the Robust Symmetrical Number System (RSNS), which minimizes the number of comparators and removes the interpolation circuitry completely. The architecture employs a three-modulus (Moduli 7, 8, 9) scheme to preprocess the antenna signal and is shown in Figure 1.

![Figure 1. Block Diagram of a Three-Channel Folding ADC Architecture.](image)
The goal of this thesis is to conduct hardware and software implementation of the Digital Decoding Sub-System (DDS) module of the folding ADC architecture (for Moduli 7, 8, 9), from the bank of comparators to the RSNS-to-binary conversion within the Field Programmable Gate Array (FPGA), as well as integration with the front-end Photonics Encoding Sub-System (PES) module of this ADC design. This was accomplished via several milestones described below.

Firstly, the RSNS Dynamic Range (DR) Computation algorithm was verified to be correct, proving that an eight-bit DR of 133 can be achieved theoretically for a three-channel RSNS ADC with Moduli \( m_1 = 7, m_2 = 8 \) and \( m_3 = 9 \).

Secondly, the RSNS-to-binary conversion algorithm for a three-channel RSNS ADC with Moduli \( m_1 = 7, m_2 = 8 \) and \( m_3 = 9 \) was developed in LabVIEW, shown in Figure 2.

![LabVIEW Schematics of RSNS-to-Binary Converter.](image)

Figure 2. LabVIEW Schematics of RSNS-to-Binary Converter.
This conversion was done to convert the RSNS output into a more convenient decimal representation. This implementation was shown to achieve the DR value of 133 with no ambiguities, which is in agreement with the RSNS DR Computation algorithm, and a one-bit improvement over that achieved in a previous design. Design of thermometer code generator circuits and simulation of this algorithm were carried out to verify that it is working properly before connecting to actual signals.

Thirdly, the comparator circuits and RSNS-to-binary conversion algorithm were designed and implemented on the FPGA to form the DDS module, shown in Figure 3.

The comparator speed was a limiting factor to the ADC system speed as actual comparator ICs were used for sampling outside the FPGA in a previous design. The key improvement made to the DDS module setup in Figure 3 is that the comparator circuits now reside in the FPGA, allowing them to sample at a rate equal to the FPGA speed.
The comparator circuit and RSNS-to-binary conversion logics were also ran on the FPGA to guarantee a higher FPGA execution speed, as opposed to running it on a National Instruments Real-Time Controller module with a lower processing speed. These two factors allow the ADC to achieve an overall higher sampling frequency.

Lastly, the DDS module was integrated with the front-end PES module to form a folding ADC system and characterization of the ADC performance was carried out. Analysis of the results attributed the dominant noise source in the ADC system to quantization noise, with the ADC remaining resilient to errors caused by other additive noise sources and comparator sampling.

This electro-optic RSNS ADC system has been demonstrated to work and produces an eight-bit output with relatively simple hardware and software. Due to the reduced number of hardware and software components, the energy and size savings make this folding ADC design appealing for defense applications, such as unmanned systems, direction-finding antenna architectures and electronic warfare system-on-a-chip applications.
## LIST OF ACRONYMS AND ABBREVIATIONS

<table>
<thead>
<tr>
<th>Acronym</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC</td>
<td>Analog to Digital Converter</td>
</tr>
<tr>
<td>ASIC</td>
<td>Application Specific Integrated Circuit</td>
</tr>
<tr>
<td>CRIO</td>
<td>Compact Reconfigurable Input/Output</td>
</tr>
<tr>
<td>CRT</td>
<td>Chinese Remainder Theorem</td>
</tr>
<tr>
<td>DDS</td>
<td>Digital Decoding Sub-System</td>
</tr>
<tr>
<td>DMA</td>
<td>Dynamic Memory Allocation</td>
</tr>
<tr>
<td>DNL</td>
<td>Differential Non-Linearity</td>
</tr>
<tr>
<td>DR</td>
<td>Dynamic Range</td>
</tr>
<tr>
<td>ENOB</td>
<td>Effective Number of Bits</td>
</tr>
<tr>
<td>FIFO</td>
<td>First-In-First-Out</td>
</tr>
<tr>
<td>FPGA</td>
<td>Field Programmable Gate Array</td>
</tr>
<tr>
<td>IC</td>
<td>Integrated Circuit</td>
</tr>
<tr>
<td>INL</td>
<td>Integral Non-Linearity</td>
</tr>
<tr>
<td>I/O</td>
<td>Input/Output</td>
</tr>
<tr>
<td>LPS</td>
<td>Least Positive Solution</td>
</tr>
<tr>
<td>LSB</td>
<td>Least Significant Bit</td>
</tr>
<tr>
<td>NI</td>
<td>National Instruments</td>
</tr>
<tr>
<td>PES</td>
<td>Photonics Encoding Sub-System</td>
</tr>
<tr>
<td>PRP</td>
<td>Pair-Wise Relatively Prime</td>
</tr>
<tr>
<td>RNS</td>
<td>Residue Number System</td>
</tr>
<tr>
<td>RSNS</td>
<td>Robust Symmetrical Number System</td>
</tr>
<tr>
<td>RTC</td>
<td>Real-Time Controller</td>
</tr>
</tbody>
</table>
SC  Sub-Channel
SINAD  Signal-to-Noise Ratio plus Distortion
SNR  Signal-to-Noise Ratio
THD  Total Harmonics Distortion
VI  Virtual Instrument
\( \hat{M} \)  Longest series of consecutive non-ambiguous RSNS vectors
\( P_f \)  Fundamental period
\( XR_g \)  Vector of RNS residues at position \( g \)
\( X_h \)  Vector of RSNS residues at position \( h \)

<table>
<thead>
<tr>
<th>Variable</th>
<th>Description</th>
<th>Subscript ( i )</th>
<th>Subscript ( k )</th>
</tr>
</thead>
<tbody>
<tr>
<td>( g_i )</td>
<td>Encoder Output</td>
<td>Bit Order</td>
<td></td>
</tr>
<tr>
<td>( h_i )</td>
<td>Adder Output</td>
<td>Bit Order</td>
<td></td>
</tr>
<tr>
<td>( i_k )</td>
<td>RNS States</td>
<td>Channel Number</td>
<td>Bit Order</td>
</tr>
<tr>
<td>( m_i )</td>
<td>Modulus</td>
<td>Channel Number</td>
<td></td>
</tr>
<tr>
<td>( n_i )</td>
<td>Alignment Logic Output / LPS Solution</td>
<td>Bit Order /</td>
<td>Gate Number</td>
</tr>
<tr>
<td>( p_{ik} )</td>
<td>Position Bit</td>
<td>Channel Number</td>
<td>Bit Order</td>
</tr>
<tr>
<td>( s_{ik} )</td>
<td>Thermometer Code / RSNS States</td>
<td>Channel Number</td>
<td>Bit Order</td>
</tr>
<tr>
<td>( t_i )</td>
<td>Shift Value</td>
<td>Channel Number</td>
<td></td>
</tr>
</tbody>
</table>

Table 1. List of Variables.
ACKNOWLEDGMENTS

Firstly, I will like to express my gratitude to Singapore’s Ministry of Defence and the Republic of Singapore Navy for providing me the opportunity to further my postgraduate education at the Naval Postgraduate School (NPS). NPS is definitely a unique institution to be in, and a melting pot that brings together multiple disciplines and cultures.

It has been my great pleasure and honor to work with Professor Phillip E. Pace and Dr. Brian Luke, who are renowned experts in this field. I will like to express my appreciation for their guidance, tutelage and support during this one-year journey.

I am deeply grateful to Dr James Calusdian, Lab Director of the Photonics Lab, who provided invaluable advice and technical expertise in the realms of FPGA programming. James assisted me in overcoming numerous problems and provided practical suggestions on the next steps towards making the project work. His enthusiasm and resourcefulness provided me with the confidence to complete this project successfully.

I will like to express my most sincere thanks to Kee Leong, my partner-in-crime for this project, and Yean Wee for their numerous brain-storming and helps along the way.

Lastly, I will like to thank my lovely wife, who has graciously endured the lengthy periods when I am away working on this thesis, and for taking good care of me all this while. I will also like to thank my parents and siblings for the support that they have shown me throughout my life, without which I would not be where I am today.

I dedicate this thesis to my first child, who will be arriving into this world in March 2011.
THIS PAGE INTENTIONALLY LEFT BLANK
I. INTRODUCTION

A. FOLDING-TYPE ANALOG-TO-DIGITAL CONVERTERS

Analog-To-Digital Converters (ADCs) are integral building blocks of most sensor and communication systems today. They allow analog data measured in the real world to be sampled and converted into quantized levels for high-speed digital processing.

As the need for ADCs with faster conversion speeds and lower power dissipation increases, there is a growing motivation to reduce the number of power-consuming components by employing folding circuits to fold the input analog signal symmetrically, prior to quantization by high-speed comparators. [1]

The folding of the analog signal allows comparators to be repetitively used, resulting in a smaller die area and lower power consumption. One folding technique employed is the Robust Symmetrical Number System (RSNS), which minimizes the number of comparators and removes the interpolation circuitry completely. [1]

These properties of low-power consumption, compactness, high-resolution and fast conversion speeds make folding ADCs an attractive concept to be used for defense applications, such as unmanned systems, direction-finding antenna architectures and electronic warfare system-on-a-chip applications.

B. SUMMARY OF RECENT RESEARCH

It was demonstrated in [2] that a three-channel folding ADC of Moduli 3, 4 and 5 can be designed using an efficient pipelined RSNS-to-binary algorithm to produce a six-bit Dynamic Range (DR) of 43 while utilizing significantly less electronic components than other equivalent six-bit ADC architecture designs. The implementation of this ADC architecture was verified to have the same DR in [3], shown in Figure 1.
In [4], it was demonstrated that the same algorithm can be extended and applied to a folding ADC of higher moduli (Moduli 7, 8 and 9). A seven-bit DR of 126 was achieved in [4], but the full DR of 133 could not be achieved due to ambiguities in the ADC output. The next step is to solve for the ambiguities and carry out an implementation of this ADC design.

This thesis is done in conjunction with another Master’s thesis to implement a three-channel electro-optical folding ADC architecture (for Moduli 7, 8, 9) [5]. It focuses on the implementation of the Digital Decoding Sub-System (DDS), which involves the hardware and software implementation of the bank of comparators to the RSNS-to-binary conversion within a Field Programmable Gate Array (FPGA), to achieve an eight-bit DR of 133.
This is done using a novel solution to solve for the ambiguities in the ADC output. The DDS module is then integrated with the front-end Photonics Encoding Sub-System (PES), which is detailed in [5].

C. PRINCIPAL CONTRIBUTIONS

Given the works summarized in the previous section, the principal contributions of the research in this thesis are three-fold.

Firstly, this thesis provides a derivation of the theoretical DR and its start and end positions for a folding ADC of Moduli 7, 8 and 9. This is based on the RSNS dynamic range computation algorithm in [6] and [7] and is used as a yardstick comparison to verify with actual experimental values obtained.

The second contribution is the implementation of the RSNS-to-binary algorithm in LabVIEW to achieve an eight-bit DR of 133, which is a one-bit improvement over that achieved in [4]. Simulation of this algorithm is carried out to verify that it is working properly before connecting to actual signals. This is done by designing test circuits to produce the three-channel thermometer codes, which are then supplied to the algorithm to obtain the simulated DR and its position.

Thirdly, this thesis documents the DDS implementation of the comparator circuit design and RSNS-to-binary conversion algorithm onboard a National Instruments (NI) FPGA so as to achieve a higher sampling frequency. The comparator circuit is redesigned in LabVIEW to allow it to achieve a higher speed to match that of the FPGA, as opposed to using actual comparator Integrated Circuits (ICs) as in [3]. The DDS module is then integrated with the front-end PES module in [5] to form an overall folding ADC architecture and tested. Lastly, an analysis and characterization of the ADC performance is carried out.

D. THESIS OUTLINE

Having covered the recent research efforts for a folding ADC architecture, we will provide the reader with a summary of the RSNS structure and principles behind the RSNS-to-binary conversion algorithm in Chapter II. A good understanding of these two
areas is required in order to translate these into actual hardware and software implementation. A theoretical derivation of the DR and its start and end positions for a folding ADC of Moduli 7, 8 and 9, based on the RSNS dynamic range computation algorithm in [6] and [7] is also provided in Chapter II.

All the logic blocks and their equivalent Boolean equations required to form the RSNS-to-binary converter for an ADC of Moduli 7, 8, 9 are delineated in Chapter III.

The process to convert the Boolean equations in Chapter III into a suitable form for implementation in LabVIEW is outlined in Chapter III. It describes how each logic block is designed in LabVIEW and the integration of all logic blocks to form the RSNS-to-binary converter.

The simulation and testing of the RSNS-to-binary converter to verify that the conversion logic is functioning properly is delineated in Chapter V. The first section of this chapter describes the creation of thermometer codes for each channel in LabVIEW to simulate as inputs to the conversion algorithm. The second section highlights the key simulation results obtained for various models.

The process of implementing the comparator circuit design and RSNS-to-binary conversion algorithm on a NI FPGA module is detailed in Chapter VI. It also highlights the integration of the DDS module with the front-end PES module in [5] to form an overall folding ADC architecture are also highlighted.

An analysis of the results to characterize the performance of this ADC system is provided in Chapter VII.

The key conclusions obtained from this project and recommendations for future research are given in Chapter VIII.
II. ROBUST SYMMETRICAL NUMBER SYSTEM

The basic theory and structure of the RSNS, and how its properties are used in the implementation of the RSNS-to-binary converter, is explained in this chapter.

A. RSNS STRUCTURE

A single-channel RSNS is based on the following staircase sequence [1]:

\[ X_h = [0, 1, 2, \ldots, m_i - 1, m_i, m_i - 1, \ldots, 2, 1] \]  

(1)

This sequence starts from zero and increases to a peak value \( m_i \), which is the channel modulus. It then decreases back to zero and repeats itself, forming a periodic sequence with a period of \( 2m_i \).

A three-channel RSNS vector is denoted as:

\[ X_h = \begin{bmatrix} s_1 \\ s_2 \\ s_3 \end{bmatrix}, \]

(2)

where the RSNS residues are in the range

\[ s_1 = \{0, 1, \cdots, m_1\}, \]
\[ s_2 = \{0, 1, \cdots, m_2\}, \]
\[ s_3 = \{0, 1, \cdots, m_3\}. \]

(3)

For an \( N \)-channel RSNS, each number in the sequence is repeated \( N \) times, extending the sequence period to \( 2Nm_i \). Each RSNS channel modulus is required to be pair-wise relatively prime (PRP) to all other channel moduli [1].

The three-channel RSNS case (\( N = 3 \)), with channel moduli \( m_1 = 7 \), \( m_2 = 8 \) and \( m_3 = 9 \), which meets the PRP condition, is focused on in this thesis. Each channel period is of length \( 2Nm_i \). The first 49 RSNS vectors of the three-channel RSNS structure for the moduli \( m_i = [7 \ 8 \ 9] \) are shown in Figure 2 as an illustration.
Table 1. Values of $X_h$ for $m_1 = 7$, $m_2 = 8$, and $m_3 = 9$.

<table>
<thead>
<tr>
<th>$h$</th>
<th>$X_h^{(m_1 = 7)}$</th>
<th>$X_h^{(m_2 = 8)}$</th>
<th>$X_h^{(m_3 = 9)}$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0 0 0 1 1 1 2 2 2 3 3 3 4 4 4 5 5 5 6 6 6 7 7 7 7 7 6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0 0 1 1 1 2 2 2 3 3 3 4 4 4 5 5 5 6 6 6 7 7 7 7 7 8 8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>0 1 1 1 2 2 2 3 3 3 4 4 4 5 5 5 5 6 6 6 7 7 7 7 8 8 8 8</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 2. Three-Channel RSNS for Moduli $m_i = [7 8 9]$.

A plot of the folded RSNS waveforms for the three channels in Figure 2, as well as the relative left-shift for Channels 2 and 3, is shown in Figure 3. Notice that these relative shifts are required for the system to exhibit Gray-code properties, where the residues within consecutive RSNS vectors change one at a time at the next code position. This property makes it attractive for error control [1].

Figure 3. Folded RSNS Waveforms for Moduli $m_i = [7 8 9]$.
The fundamental period of a three-channel RSNS is [1]:

\[ P_f = 2N \prod m_i = 2Nm_1m_2m_3 \]  

This is calculated to be \( P_f = 2(3)(7)(8)(9) = 3024 \) for a RSNS with \( m_i = [7 \ 8 \ 9] \).

1. Dynamic Range

The maximum DR of the RSNS is defined as the longest series of consecutive unambiguous RSNS vectors within the fundamental period of the system [1]. The DR for the same RSNS system is given by [1]:

\[ \hat{M} = \frac{3}{2}m_i^2 + \frac{15}{2}m_i + 7. \]  

This is calculated as \( \hat{M} = \frac{3}{2}(7^2) + \frac{15}{2}(7) + 7 = 133 \).

It was shown that the size of the DR in a RSNS is the same regardless of the shift sequence and whether the shift is to the left or right. However, the location of the DR is affected by the choice of the channels that receive the shifts [1].

Since the aim is to achieve an eight-bit DR for this design regardless of its location, a left-shift \( t_i = [0 \ 1 \ 2] \) system is chosen for ease of implementation as the RSNS-to-binary conversion algorithm is derived based on this shift system in [2], with Channel 2 and 3 shifted one and two positions to the left, respectively, both relative to Channel 1.

2. Ambiguity Types

The conventional approach towards finding the DR and its position is to search the entire fundamental period for a sequence of non-repeating or unambiguous vectors of unknown length, which is computationally-intensive. A more efficient approach is to compute the finite locations of the ambiguous RSNS vectors for each channel and solve for all vector ambiguity locations to obtain the DR and its position [2], which will be elaborated in Section B of this chapter.
Three types of ambiguities exist in each RSNS channel [2]. The positions of the three ambiguity types for the Channel 1 \((m_1 = 7)\) case are illustrated in Figure 4. Type 0 ambiguities occur for every repeating channel period, while Type 1 ambiguities occur on the rise and fall of a channel period. In addition, Type 2 ambiguities occur every time each residue value is repeated three times within the period.

![Single Channel Ambiguity Types \((m_1 = 7)\).](image)

3. **Sub-Channel Analysis**

It was shown in [2] that decimating each of the three channels into their sub-channels aids in the solving of channel ambiguities. This is illustrated for the \(m_i = [7 \ 8 \ 9]\) case in Figure 5.

Grouping each of the sub-channels together, and re-indexing the position index \(h\) to a new index \(g\), we obtain the results in Figure 6. The relationship between the old position index \(h\) and the new index \(g\) is given by [2]:

\[
g = \frac{h}{3} \quad \text{(Sub-Channel 0)}
\]

\[
g = \frac{(h-1)}{3} \quad \text{(Sub-Channel 1)}
\]

\[
g = \frac{(h-2)}{3} \quad \text{(Sub-Channel 2)}
\]
Figure 5. Decimation of Channels into Sub-Channels for Moduli $m_i = [7 \ 8 \ 9]$.  

![Table](image)

Figure 6. RSNS Vectors for Sub-Channels 0, 1 and 2.

9
A plot of the RSNS sub-channel waveforms in Figure 6 is shown in Figure 7. Each channel has $N = 3$ sub-channels. From Figure 7, it can be seen that Type 2 ambiguities are eliminated, leaving only Type 0 and 1 ambiguities.

As the waveforms are folded and symmetric, each residue value occurs twice in a single folding period, except for the minimum and the maximum value, which occur only once. Using this fact, we obtain the congruence equations describing the position of a RSNS residue vector for Sub-Channel 0 as [2]:

$$
g \equiv s_1 \pmod{2m_1} \quad \text{or} \quad g \equiv 2m_1 - s_1 \pmod{2m_1},$$
$$
g \equiv s_2 \pmod{2m_2} \quad \text{or} \quad g \equiv 2m_2 - s_2 \pmod{2m_2},$$
$$
g \equiv s_3 \pmod{2m_3} \quad \text{or} \quad g \equiv 2m_3 - s_3 \pmod{2m_3}. \quad (7)$$

Figure 7. Plot of Sub-Channels 0, 1 and 2.
The congruence equations for Sub-Channel 1 are:

\[ g \equiv s_1 \pmod{2m_1} \quad \text{or} \quad g \equiv 2m_1 - s_1 \pmod{2m_1}, \]
\[ g \equiv s_2 \pmod{2m_2} \quad \text{or} \quad g \equiv 2m_2 - s_2 \pmod{2m_2}, \]
\[ g \equiv s_3 - 1 \pmod{2m_3} \quad \text{or} \quad g \equiv 2m_3 - s_3 - 1 \pmod{2m_3}. \]  

(8)

The congruence equations for Sub-Channel 2 are:

\[ g \equiv s_1 \pmod{2m_1} \quad \text{or} \quad g \equiv 2m_1 - s_1 \pmod{2m_1}, \]
\[ g \equiv s_2 - 1 \pmod{2m_2} \quad \text{or} \quad g \equiv 2m_2 - s_2 - 1 \pmod{2m_2}, \]
\[ g \equiv s_3 - 1 \pmod{2m_3} \quad \text{or} \quad g \equiv 2m_3 - s_3 - 1 \pmod{2m_3}. \]  

(9)

Equations (7)–(9) show that there are three equations for each sub-channel, with two choices for each equation. Thus, each RSNS residue vector can produce up to $2^3 = 8$ unique systems of equations. This means that any RSNS vector can have up to eight ambiguities within the fundamental period.

The equations also reveal that the start position of the DR, $h$, can be found by determining the sub-channel of a particular RSNS vector, solving the equivalent set of equations to obtain $g$, and converting $g$ to find $h$, using (6). To determine which sub-channel a RSNS vector is from, the even-odd structure of each sub-channel has to be investigated.

4. Even-Odd Analysis

The even-odd structures ($e = \text{even}$, $o = \text{odd}$) of each sub-channel, and the overall even-odd structure of a three-channel RSNS with $m_i = [7 \ 8 \ 9]$, are illustrated in Figures 8 and 9.

From Figure 8, it can be seen that each sub-channel produces RSNS vectors with two unique even-odd structures. Thus, the Sub-Channel 0 equations in (7) can be applied if the RSNS vector is found to be of form $[e\ e\ e]^T$ or $[o\ o\ o]^T$. Similarly, the Sub-Channel 1 equations in (8) are used if the RSNS vector is of form $[e\ e\ o]^T$ or $[o\ o\ e]^T$, and the Sub-Channel 2 equations in (9) are applied if the RSNS vector is of form $[e\ o\ o]^T$ or $[o\ e\ e]^T$. 
This even-odd structure repeats in blocks of six, after cycling through the set of sub-channels twice, as shown in Figure 9. This means that the minimum distance between ambiguous parity vectors is always a multiple of six for a three-channel RSNS, and a multiple of $2N$ for the $N$-channel case.

Figure 9. Overall Even-Odd Structure of RSNS Vectors.

It was shown in [2] that for the Sub-Channel 1 and 2 cases, the equations in (6) and (7) actually convert the even-odd structure of the RSNS vectors to the form $[ee e]^T$ or $[o o o]^T$. Thus, the Sub-Channel 0 case can be exploited as a base case to develop an efficient RSNS-binary conversion, explained in Section C of this chapter.
B. RSNS DYNAMIC RANGE SEARCH ALGORITHM

An efficient RSNS dynamic range search algorithm was developed in [6] and [7], which makes use of the cyclical and symmetrical properties of the RSNS structure to cut down on the solution space when searching for the DR. This is faster than searching through the whole solution space, which is computationally intensive. A theoretical derivation of the DR, including its start and end positions, for a folding ADC of Moduli 7, 8 and 9, based on this algorithm, is provided in this section.

1. Dynamic Range Upper Bound

The upper limit of $\hat{M}$ is defined as [6]:

$$\hat{M} = N \min_{i \neq j} \left[ \prod_{i} m_{i} + 2 \prod_{j} m_{j} \right] - 1$$  \hspace{1cm} (10)

The DR upper bound for an ADC of Moduli 7, 8 and 9 is calculated to be 221:

$$\hat{M}_{1} = 3 \left[ 1 + 2 \cdot (7 \cdot 8 \cdot 9) \right] - 1 = 3026$$
$$\hat{M}_{2} = 3 \left[ 7 + 2 \cdot (8 \cdot 9) \right] - 1 = 452$$
$$\hat{M}_{3} = 3 \left[ 8 + 2 \cdot (7 \cdot 9) \right] - 1 = 401$$
$$\hat{M}_{4} = 3 \left[ 9 + 2 \cdot (7 \cdot 8) \right] - 1 = 362$$
$$\hat{M}_{5} = 3 \left[ (7 \cdot 8) + 2 \cdot (9) \right] - 1 = 221$$  \hspace{1cm} (11)
$$\hat{M}_{6} = 3 \left[ (7 \cdot 9) + 2 \cdot (8) \right] - 1 = 236$$
$$\hat{M}_{7} = 3 \left[ (8 \cdot 9) + 2 \cdot (7) \right] - 1 = 257$$
$$\hat{M}_{8} = 3 \left[ (7 \cdot 8 \cdot 9) + 2 \cdot (1) \right] - 1 = 1517$$

$$\therefore \hat{M} = \min \hat{M}_{i} = 221$$

2. RSNS Vector Ambiguity Locations

The solutions to the RSNS vector ambiguity locations for a three-channel case are shown in Figure 10. Note that all of the ambiguities smaller than the fundamental period are symmetric around a Center of Ambiguity (COA), as intuitively shown in Figure 4 [6].
The three identifier digits in the Case Label refer to the number of Type 1 ambiguities, combination number and sub-channel number respectively. They are used to provide a logical case numbering system for implementation in a computer algorithm [2].

<table>
<thead>
<tr>
<th>Case Label</th>
<th>Ambiguities occur at ( h ) and ( h + k ), where ( h ) is</th>
<th>( k ) is a multiple of</th>
<th>COR</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>Any position in the fundamental period</td>
<td>( 6m_1m_2m_3 )</td>
<td>N/A</td>
</tr>
<tr>
<td>110</td>
<td>( h = a(3m_1) - k/2 )</td>
<td>( 6m_2m_3 )</td>
<td>( a(3m_1) )</td>
</tr>
<tr>
<td>111</td>
<td>( h = a(3m_1) + 1 - k/2 )</td>
<td>( 6m_2m_3 )</td>
<td>( a(3m_1) + 1 )</td>
</tr>
<tr>
<td>112</td>
<td>( h = a(3m_1) + 2 - k/2 )</td>
<td>( 6m_2m_3 )</td>
<td>( a(3m_1) + 2 )</td>
</tr>
<tr>
<td>120</td>
<td>( h = a(3m_2) - k/2 )</td>
<td>( 6m_3 )</td>
<td>( a(3m_2) )</td>
</tr>
<tr>
<td>121</td>
<td>( h = a(3m_2) + 1 - k/2 )</td>
<td>( 6m_3 )</td>
<td>( a(3m_2) + 1 )</td>
</tr>
<tr>
<td>122</td>
<td>( h = a(3m_2) - 1 - k/2 )</td>
<td>( 6m_3 )</td>
<td>( a(3m_2) - 1 )</td>
</tr>
<tr>
<td>130</td>
<td>( h = a(3m_3) - k/2 )</td>
<td>( 6m_1m_2 )</td>
<td>( a(3m_3) )</td>
</tr>
<tr>
<td>131</td>
<td>( h = a(3m_3) - 2 - k/2 )</td>
<td>( 6m_1m_2 )</td>
<td>( a(3m_3) - 2 )</td>
</tr>
<tr>
<td>132</td>
<td>( h = a(3m_3) - 1 - k/2 )</td>
<td>( 6m_1m_2 )</td>
<td>( a(3m_3) - 1 )</td>
</tr>
<tr>
<td>210</td>
<td>( h = a(3m_1m_2) - k/2 )</td>
<td>( 6m_3 )</td>
<td>( a(3m_1m_2) )</td>
</tr>
<tr>
<td>211</td>
<td>( h = a(3m_1m_2) + h_{s1} - k/2 )</td>
<td>( 6m_3 )</td>
<td>( a(3m_1m_2) + h_{s1} )</td>
</tr>
<tr>
<td>212</td>
<td>( h = a(3m_1m_2) + h_{s2} - k/2 )</td>
<td>( 6m_3 )</td>
<td>( a(3m_1m_2) + h_{s2} )</td>
</tr>
<tr>
<td>220</td>
<td>( h = a(3m_1m_3) - k/2 )</td>
<td>( 6m_2 )</td>
<td>( a(3m_1m_3) )</td>
</tr>
<tr>
<td>221</td>
<td>( h = a(3m_1m_3) + h_{s1} - k/2 )</td>
<td>( 6m_2 )</td>
<td>( a(3m_1m_3) + h_{s1} )</td>
</tr>
<tr>
<td>222</td>
<td>( h = a(3m_1m_3) + h_{s2} - k/2 )</td>
<td>( 6m_2 )</td>
<td>( a(3m_1m_3) + h_{s2} )</td>
</tr>
<tr>
<td>230</td>
<td>( h = a(3m_2m_3) - k/2 )</td>
<td>( 6m_1 )</td>
<td>( a(3m_2m_3) )</td>
</tr>
<tr>
<td>231</td>
<td>( h = a(3m_2m_3) + h_{s1} - k/2 )</td>
<td>( 6m_1 )</td>
<td>( a(3m_2m_3) + h_{s1} )</td>
</tr>
<tr>
<td>232</td>
<td>( h = a(3m_2m_3) + h_{s2} - k/2 )</td>
<td>( 6m_1 )</td>
<td>( a(3m_2m_3) + h_{s2} )</td>
</tr>
<tr>
<td>310</td>
<td>( h = a(3m_1m_2m_3) - k/2 )</td>
<td>( 6 )</td>
<td>( a(3m_1m_2m_3) )</td>
</tr>
<tr>
<td>311</td>
<td>( h = a(3m_1m_2m_3) + h_{s1} - k/2 )</td>
<td>( 6 )</td>
<td>( a(3m_1m_2m_3) + h_{s1} )</td>
</tr>
<tr>
<td>312</td>
<td>( h = a(3m_1m_2m_3) + h_{s2} - k/2 )</td>
<td>( 6 )</td>
<td>( a(3m_1m_2m_3) + h_{s2} )</td>
</tr>
</tbody>
</table>

Figure 10. RSNS Vector Ambiguity Locations (Three-Channel Case).

From Figure 10, it can be seen that the ambiguities in an RSNS structure occur at position \( h \) and \( h + k \), where \( k \) is a multiple of the moduli combinations for each case. There is an inverse relation between the spacing between the ambiguous vectors \( (k) \) and the spacing between the COA.
Recall that a left-shift \( \text{shift}_i = [0 \ 1 \ 2] \) system was implemented to exhibit gray-code properties. Thus, the base cases involving Sub-Channel 0 (Case XX0) has a COA shift of \( h_{i_0} = 0 \). The cases involving Sub-Channel 1 (Case XX1) and Sub-Channel 2 (Case XX2) will have a COA shifts of \( h_{i_1} \) and \( h_{i_2} \), respectively. These are the least positive solutions to the following two sets of congruence equations [7]:

\[
\begin{align*}
\frac{h_{i_1} - 1}{3} &\equiv 0 \pmod{7} & \frac{h_{i_2} - 2}{3} &\equiv 0 \pmod{7} \\
\frac{h_{i_1} - 1}{3} &\equiv 0 \pmod{8} & \frac{h_{i_2} + 1}{3} &\equiv 0 \pmod{8} \\
\frac{h_{i_1} + 2}{3} &\equiv 0 \pmod{9} & \frac{h_{i_2} + 1}{3} &\equiv 0 \pmod{9}
\end{align*}
\]  

(12)

The COA shifts are computed to be \( h_{i_1} = 1 \) and \( h_{i_2} = 23 \) using the generalized Chinese Remainder Theorem (CRT) procedure described in the Appendix.

The solutions to the RSNS vector ambiguity locations for a RSNS with Moduli 7, 8 and 9, are derived from Figure 10 and summarized in Figure 11. The rows highlighted in grey have ambiguity pairs with a length greater than \( \left\lceil \frac{M}{2} \right\rceil = 221 \) and can be ignored in the DR computation.
<table>
<thead>
<tr>
<th>Case Label</th>
<th>Ambiguities occur at $h$ and $h+k$, where $h$ is</th>
<th>$k$ is a multiple of</th>
<th>COA</th>
</tr>
</thead>
<tbody>
<tr>
<td>010</td>
<td>Any position in the fundamental period</td>
<td>3024</td>
<td>N/A</td>
</tr>
<tr>
<td>110</td>
<td>$h = a(21) - 216$</td>
<td>432</td>
<td>$a(21)$</td>
</tr>
<tr>
<td>111</td>
<td>$h = a(21) - 215$</td>
<td>378</td>
<td>$a(24) + 1$</td>
</tr>
<tr>
<td>112</td>
<td>$h = a(21) - 214$</td>
<td>336</td>
<td>$a(24) - 1$</td>
</tr>
<tr>
<td>120</td>
<td>$h = a(24) - 189$</td>
<td>54</td>
<td>$a(168)$</td>
</tr>
<tr>
<td>121</td>
<td>$h = a(24) - 188$</td>
<td>48</td>
<td>$a(189) + h_{s1}$</td>
</tr>
<tr>
<td>122</td>
<td>$h = a(24) - 190$</td>
<td>42</td>
<td>$a(216)$</td>
</tr>
<tr>
<td>130</td>
<td>$h = a(27) - 168$</td>
<td>6</td>
<td>$a(1512)$</td>
</tr>
<tr>
<td>131</td>
<td>$h = a(27) - 170$</td>
<td>$a(27) - 2$</td>
<td></td>
</tr>
<tr>
<td>132</td>
<td>$h = a(27) - 169$</td>
<td>$a(27) - 1$</td>
<td></td>
</tr>
<tr>
<td>210</td>
<td>$h = a(168) - 27$</td>
<td>311</td>
<td>$a(1512) + h_{s1}$</td>
</tr>
<tr>
<td>211</td>
<td>$h = a(168) + h_{s1} - 27$</td>
<td>212</td>
<td>$a(1512) + h_{s2}$</td>
</tr>
<tr>
<td>220</td>
<td>$h = a(189) - 24$</td>
<td>312</td>
<td>$a(1512) + h_{s2}$</td>
</tr>
<tr>
<td>221</td>
<td>$h = a(189) + h_{s1} - 24$</td>
<td></td>
<td></td>
</tr>
<tr>
<td>222</td>
<td>$h = a(189) + h_{s2} - 24$</td>
<td></td>
<td></td>
</tr>
<tr>
<td>230</td>
<td>$h = a(216) - 21$</td>
<td></td>
<td></td>
</tr>
<tr>
<td>231</td>
<td>$h = a(216) + h_{s1} - 21$</td>
<td></td>
<td></td>
</tr>
<tr>
<td>232</td>
<td>$h = a(216) + h_{s2} - 21$</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 11. RSNS Vector Ambiguity Locations (for Moduli 7, 8 and 9).

3. Minimal Ambiguity Pair Locations

Due to the symmetry of the RSNS vector ambiguity locations about $P_f / 2$, only ambiguity pairs from $h = -N$ to $(P_f / 2) + N$ need to be considered when computing $\bar{M}$ [7]. All the minimal ambiguity pair $(h_1, h_2)$ locations, derived by substituting integer values of $a$, $h_{s1} = 1$ and $h_{s2} = 23$ into Figure 11 for each of the cases, are shown in Figure 12, for $h = -3$ to 1515.
### Figure 12. Minimal Pair Locations.

#### 4. Consecutive Minimal Pair Locations

In Figure 12, all minimal pairs with a starting position $h_i$ earlier than the starting position of the previous pair are removed. The remaining minimal pairs are sorted such that $h_2$ is monotonically increasing and are defined as consecutive minimal pairs [7]. These consecutive minimal pairs are derived from Figure 12 and shown in Figure 13.
The DR $\tilde{M}$ is the largest distance between endpoints of two consecutive minimal pairs, computed in Figure 13. The result is a $\tilde{M} = 133$ starting at $h = h_1 + 1 = 733$ and ending at $h = h_2 - 1 = 865$, which is in agreement with (5).

![Figure 13. Consecutive Minimal Pair Locations.](image-url)
C. RSNS-TO-BINARY CONVERSION ALGORITHM

With a good understanding of the underlying RSNS structure, an efficient RSNS-to-binary conversion can be achieved by exploiting the relationship between the RSNS and the Residue Number System (RNS) and using the RNS Least Positive Solution (LPS) and positional alignment techniques to solve for the DR position. These are summarized in this section.

1. RSNS-RNS Relationship

It was shown in [2] that there is a one-to-one correspondence between the RSNS and the RNS. This is the key to achieving an efficient RSNS-to-binary conversion as the RNS has no ambiguities in a fundamental period, unlike the RSNS.

This one-to-one correspondence between the RSNS and RNS vectors, using the Sub-Channel 0 case as a base case for conversion, is demonstrated in Figure 14. Each RSNS residue is converted to a unique RNS residue such that there is no ambiguity within a single channel period.

![Figure 14. One-to-One Correspondence between RSNS and RNS Vectors.](image)

Another useful RNS property is that every $XR_g$ vector is either all even or odd, unlike the RSNS.
It is possible to simplify the conversion by considering only the even \(XR_g\) vectors (grey-colored columns in Figure 14) and dividing their values and the index \(g\) by two. This is illustrated in Figure 15.

<table>
<thead>
<tr>
<th>RSNS Vectors (XR_g/2)</th>
<th>(m_1=7)</th>
<th>0</th>
<th>2</th>
<th>4</th>
<th>6</th>
<th>6</th>
<th>4</th>
<th>2</th>
<th>0</th>
<th>2</th>
</tr>
</thead>
<tbody>
<tr>
<td>(m_2=8)</td>
<td>0</td>
<td>2</td>
<td>4</td>
<td>6</td>
<td>8</td>
<td>6</td>
<td>4</td>
<td>2</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>(m_3=9)</td>
<td>0</td>
<td>2</td>
<td>4</td>
<td>6</td>
<td>8</td>
<td>8</td>
<td>6</td>
<td>4</td>
<td>2</td>
<td></td>
</tr>
<tr>
<td>RNS Vectors (g)</td>
<td>(g)</td>
<td>0</td>
<td>2</td>
<td>4</td>
<td>6</td>
<td>8</td>
<td>10</td>
<td>12</td>
<td>14</td>
<td>16</td>
</tr>
<tr>
<td>(m_1=7)</td>
<td>0</td>
<td>1</td>
<td>2</td>
<td>3</td>
<td>4</td>
<td>5</td>
<td>6</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>(m_2=8)</td>
<td>0</td>
<td>1</td>
<td>2</td>
<td>3</td>
<td>4</td>
<td>5</td>
<td>6</td>
<td>7</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>(m_3=9)</td>
<td>0</td>
<td>1</td>
<td>2</td>
<td>3</td>
<td>4</td>
<td>5</td>
<td>6</td>
<td>7</td>
<td>8</td>
<td></td>
</tr>
</tbody>
</table>

Figure 15. RSNS and RNS Vectors for Even Index \(g\).

From Figure 15, it can be seen that the RSNS vectors are transformed into RNS vectors with the same PRP moduli. The index position \(g/2\) can now be solved directly using the standardized CRT [10]. However, there are still up to \(2^3\) or eight systems of equations to solve in order to find the positions of a single RSNS vector within the fundamental period. This is due to the symmetry of each RSNS channel period and three sub-channel structure within each channel period.

This process can be simplified by limiting the solution range to within the DR. The problem is then reduced to finding the least positive solution of the eight systems of equations, explained in the next section.

2. Dynamic Range Compression

A closed-form solution for the start and end DR positions for moduli of form \((2^r - 1, 2^r, 2^r + 1)\) was derived in [6]. The radix \(r\) is 3 for an RSNS with moduli \(m_i = [7 8 9]\). The start and end positions can be calculated using [6]:

\[
\text{Start Position of } \hat{M}: h_l = 3\left(2^{3r-1} - 2^{r-1} - 2^r\right) + 1
\]

(13)
and
End Position of $\hat{M}$: $h_2 = 3 \left( 2^{5r-1} + 2^{2r-1} \right) + 1.$ \hspace{1cm} (14)

The DR range is from $h_1 = 733$ and $h_2 = 865$ for a RSNS with $m_i = [7 \ 8 \ 9]$. The corresponding RSNS vectors are $X_{733} = [6 \ 4 \ 7]^T$ and $X_{865} = [6 \ 0 \ 1]^T$ using the method described in [5].

Recall that this algorithm is applied to the $[e \ e \ e]^T$ vectors in the Sub-Channel 0 case only. Thus, the closest $[e \ e \ e]^T$ vectors to $X_{733}$ and $X_{865}$ must be chosen for this conversion to work. They are $X_{732} = [6 \ 4 \ 8]^T$ and $X_{864} = [6 \ 0 \ 0]^T$.

At this juncture, it must be noted that the chosen start position $h_i = 732$ falls outside the DR, which will produce ambiguous results during implementation. This is a special case where the DR does not start with a Sub-Channel 0 vector and end with a Sub-Channel 2 vector, as required in Figure 9.

There are two methods to overcome this. The first is to truncate the DR to a multiple of six, so that the DR will always start with a Sub-Channel 0 vector. Alternatively, the boundary (start and end) vectors have to be treated as special cases in the LabVIEW implementation. The details of both methods will be addressed in Chapters IV and V.

Applying (6), we calculate the corresponding start and end indices for the RNS $XR_g$ vectors as:

$$g_1 = \frac{h_1}{3} = \frac{732}{3} = 244,$$
$$g_2 = \frac{h_2}{3} = \frac{864}{3} = 288.$$ \hspace{1cm} (15)

Using the results from Figure 14, we consider only the even RNS $XR_g$ vectors. The corresponding start and end indices for the RNS $XR_g/2$ vectors are calculated as:

$$\frac{g_1}{2} = \frac{244}{2} = 122,$$  
$$\frac{g_2}{2} = \frac{288}{2} = 144.$$ \hspace{1cm} (16)
Using the results from (16), we obtain the total number of RNS vectors required to find the LPS for the index $g$ as 

\[ \frac{g_2}{2} - \frac{g_1}{2} + 1 = 144 - 122 + 1 = 23 \]

shown in Figure 16. The RNS vectors in Figure 16 are derived from Figure 15 by extending the $g'/2$ index from 122 to 144. The representation of the DR is now compressed from a length of 133 vectors to 23 vectors.

<table>
<thead>
<tr>
<th>RNS</th>
<th>$m_1=7$</th>
<th>$m_2=8$</th>
<th>$m_3=9$</th>
<th>$g'/2$</th>
</tr>
</thead>
<tbody>
<tr>
<td>Vectors</td>
<td>3 4 5 6 0 1 2 3 4 5 6 0 1 2 3 4 5 6 0 1 2 3 4 5 6 0 1 2 3 4 5 6 0 1 2 3 4 5 6 0 1 2 3 4 ...</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>XR $g'/2$</td>
<td>2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7 0 1 2 3 4 ...</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>LPS</td>
<td>0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 ...</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 16. RNS Vectors Spanning DR (Before and After Shifting Start Position).

This compression is possible because using only Sub-Channel 0 vectors compresses the DR by three, and exploiting its even-odd structure yields an additional compression factor of two. Thus, the total compression factor is $2N$, and the number of RNS vectors required to find the LPS for the index $g$ is [2]:

\[ L = \left\lceil \frac{\hat{M}}{2N} \right\rceil = \left\lceil \frac{133}{6} \right\rceil = 23. \]  

\[ (17) \]
Another useful RNS property is that subtracting a particular RNS vector from all other RNS vectors in the fundamental period shifts the start of the RNS sequence to the position of the same vector [2].

From this fact, the RNS vector \( \frac{XR_{g/2}}{2} \) is subtracted from all RNS vectors between \( \frac{XR_{122}}{2} \) and \( \frac{XR_{144}}{2} \) to obtain the shifted RNS sequence in the bottom row of Figure 16. This means that the solution for the index \( h \) is now shifted to the range \( 0 \leq h' \leq 132 \) rather than \( 733 \leq h \leq 865 \). This is desirable as the former can be represented in an 8-bit binary number, while the latter requires 10 bits.

3. Alignment of RNS Least Positive Solution

A method of finding the LPS to multiple systems of equations is a positional alignment solution. This method asserts the positions of the RNS residues for each channel of the \( \frac{XR_{g/2}}{2} \) vectors, shown in Figure 16. The LPS is the position \( g' \) of the first \( \frac{XR_{g/2}}{2} \) vector in which all three asserted residues align [2].

After finding the LPS \( g' \) for a particular RSNS vector \( X_h = [s_1, s_2, s_3]^T \), the LPS is converted back to the shifted index \( h' \) by reversing the sub-channel and even-odd compression process carried out before the LPS alignment. Using \( F_{sc} \) to denote the sub-channel compensation factor, \( F_{odd} \) as the even-odd compensation factor, and (6), the expression to obtain \( h' \) is [2]:

\[
h' = 3(g' + F_{odd}) + F_{sc},
\]

where
\[
F_{\text{odd}} = \begin{cases} 
0, & \text{if residue } s_i \text{ from } X_h \text{ is even} \\
1, & \text{if residue } s_i \text{ from } X_h \text{ is odd} 
\end{cases}, 
\]

\[
F_{\text{SC}} = \begin{cases} 
0, & \text{if } X_h \text{ is from Sub-Channel 0} \\
1, & \text{if } X_h \text{ is from Sub-Channel 1} \\
2, & \text{if } X_h \text{ is from Sub-Channel 2} 
\end{cases}.
\]

(19)

Since \( h' \) is the index \( h \) after shifting the DR start position to zero, the position of the RSNS vector within the DR, or index \( h \), can simply be obtained by adding the DR start position \( h_1 \):

\[ h = h_1 + h'. \]

(20)

The key principles and steps of the RSNS-to-binary conversion algorithm described in this chapter are encapsulated in Figure 17. An efficient RSNS-to-binary conversion can be achieved by exploiting the RSNS-RNS relationship, as well as using the RNS LPS and positional alignment techniques to solve for the DR position.

Figure 17. RSNS-to-Binary Conversion Algorithm (After [2]).

The translation of the principles of this RSNS-to-binary conversion algorithm into a feasible logic block diagram is explained in the next chapter.
III. RSNS-TO-BINARY CONVERSION

Given the key principles of the RSNS-to-binary conversion algorithm described in the last chapter, the translation of this algorithm into a feasible logic block diagram for implementation in the LabVIEW programming environment is explained in this chapter.

A. LOGIC BLOCK DIAGRAM OF RSNS-TO-BINARY CONVERTER

The overall logic block diagram of this converter that can be implemented in LabVIEW and the input/output variables for each block are shown in Figure 18. The subsequent sections will detail why each logic block is required and how it is derived.

![Logic Block Diagram of RSNS-to-Binary Converter](image)

Figure 18. Logic Block Diagram of RSNS-to-Binary Converter (After [4]).

The inputs of this conversion system come from a bank of 24 comparators at the end of a photonic analog folding circuit and can be represented as a three-channel RSNS vector as shown in (2). These comparator outputs are separated into three channels of seven, eight and nine comparators, according to the Moduli $m_i = [7 \ 8 \ 9]$.
The input residues $[s_1, s_2, s_3]^T$ are encoded in a thermometer code for this implementation, according to (3). Each of the bits in the thermometer code is labeled as $s_{ik}$, where the index $i$ represents the channel of the RSNS residue vector, and the index $k$ is the bit position in the thermometer code, with $k = 0$ corresponding to the position of the Least Significant Bit (LSB). The RSNS thermometer code bits for $m_i = [7 \ 8 \ 9]$ are shown in Figure 19.

<table>
<thead>
<tr>
<th>RSNS Residue Value</th>
<th>RSNS Thermometer Bits</th>
<th>RSNS Residue Value</th>
<th>RSNS Thermometer Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>$s_1$</td>
<td>$s_{16}$  $s_{15}$  $s_{14}$  $s_{13}$  $s_{12}$  $s_{11}$  $s_{10}$</td>
<td>$s_2$</td>
<td>$s_{27}$  $s_{26}$  $s_{25}$  $s_{24}$  $s_{23}$  $s_{22}$  $s_{21}$  $s_{20}$</td>
</tr>
<tr>
<td>0</td>
<td>0         0         0         0         0         0         0         0</td>
<td>0</td>
<td>0         0         0         0         0         0         0         0</td>
</tr>
<tr>
<td>1</td>
<td>0         0         0         0         0         0         1</td>
<td>1</td>
<td>0         0         0         0         0         0         0         1</td>
</tr>
<tr>
<td>2</td>
<td>0         0         0         0         0         1         1</td>
<td>2</td>
<td>0         0         0         0         0         1         1         1</td>
</tr>
<tr>
<td>3</td>
<td>0         0         0         0         1         1         1</td>
<td>3</td>
<td>0         0         0         0         1         1         1         1</td>
</tr>
<tr>
<td>4</td>
<td>0         0         0         1         1         1         1</td>
<td>4</td>
<td>0         0         0         1         1         1         1         1</td>
</tr>
<tr>
<td>5</td>
<td>0         0         1         1         1         1         1</td>
<td>5</td>
<td>0         0         1         1         1         1         1         1</td>
</tr>
<tr>
<td>6</td>
<td>0         1         1         1         1         1         1</td>
<td>6</td>
<td>0         1         1         1         1         1         1         1</td>
</tr>
<tr>
<td>7</td>
<td>1         1         1         1         1         1         1</td>
<td>7</td>
<td>1         1         1         1         1         1         1         1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>8</td>
</tr>
</tbody>
</table>

Figure 19. RSNS Thermometer Codes for $m_i = [7 \ 8 \ 9]$.  

26
B. POSITION BIT CONVERSION

The next step is to convert the RSNS thermometer code residues into RNS residues using the one-to-one correspondence property of the RSNS-RNS relationship. Each RNS residue can be represented by a unique position bit.

The position bits are denoted as \( p_k \), where the index \( i \) is the channel and \( k \) is the RNS residue value with \( 0 \leq k \leq (m_i - 1) \). The LPS is then found by finding the position \( g' / 2 \) where the three position bits from each channel are asserted and aligned.

1. RSNS Thermometer Code to RNS Residue/Position Bit Conversion

The simplest case for this conversion is to consider the residues for Channel 1. From Equations (7), (8) and (9), we see that the top row of each set of equations is identical. This means that the conversion of RSNS residues to RNS residues for Channel 1 is the same regardless of the sub-channel that the residue comes from. The conversion process for Channel 1 \((m_i = 7)\) is shown in Figure 20.

<table>
<thead>
<tr>
<th>RSNS Residue</th>
<th>RNS Residue</th>
<th>Even RNS Residue</th>
<th>RNS Residue for PRP Moduli</th>
</tr>
</thead>
<tbody>
<tr>
<td>( s_i )</td>
<td>( s_i )</td>
<td>( 14 - s_i )</td>
<td>( \text{even}(s_i) )</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>13</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
<td>12</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>3</td>
<td>11</td>
<td>2</td>
</tr>
<tr>
<td>4</td>
<td>4</td>
<td>10</td>
<td>4</td>
</tr>
<tr>
<td>5</td>
<td>5</td>
<td>9</td>
<td>4</td>
</tr>
<tr>
<td>6</td>
<td>6</td>
<td>8</td>
<td>6</td>
</tr>
<tr>
<td>7</td>
<td>7</td>
<td>7</td>
<td>6</td>
</tr>
</tbody>
</table>

Figure 20. Channel 1 RSNS-to-RNS Conversion for all Sub-Channels (After [2]).
Recall that each RSNS residue value \( s_i \) can be represented by two unique RNS residues to prevent ambiguity within a single channel period, as illustrated in Figure 14 previously. This conversion is shown as Step 0 to 1 in Figure 20.

The RNS residues are then rounded down to the nearest even RNS residues and divided by two to obtain RNS residues with the same PRP moduli as the RSNS, as illustrated in Figure 15 previously. This conversion is shown as Steps 1 to 3 in Figure 20. The asserted position bits corresponding to each of the RSNS and RNS residues are shown in Figure 21.

<table>
<thead>
<tr>
<th>RSNS Residue</th>
<th>RNS Residue for PRP Moduli</th>
<th>Position Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>( s_i )</td>
<td>even(( s_i ))</td>
<td>even(14 – ( s_i ))</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>6</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>6</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>5</td>
</tr>
<tr>
<td>4</td>
<td>2</td>
<td>5</td>
</tr>
<tr>
<td>5</td>
<td>2</td>
<td>4</td>
</tr>
<tr>
<td>6</td>
<td>3</td>
<td>4</td>
</tr>
<tr>
<td>7</td>
<td>3</td>
<td>3</td>
</tr>
</tbody>
</table>

Figure 21. Channel 1 RSNS-RNS-Position Bit Correspondences for all Sub-Channels (After [2]).

The conversion process for Channel 2 \( (m_2 = 8) \) and Channel 3 \( (m_3 = 9) \) are similar to that of Channel 1, except that they are left-shifted by one and two positions, respectively. Examination of (7), (8) and (9) reveals that this impacts the conversion of RSNS residues from different sub-channels.

The RSNS to position bit conversion process for Sub-Channels 0 and 1 of Channel 2 are illustrated in Figures 22 and 23. The same process for Sub-Channel 2 is illustrated in Figures 24 and 25.
Note that Sub-Channel 2 is shifted by one relative to Sub-Channels 0 and 1, from (7), (8) and (9). A comparison of Figures 23 and 25 shows that the position bits of Sub-Channel 2 are the reversed of those for Sub-Channels 0 and 1.

<table>
<thead>
<tr>
<th>RSNS Residue</th>
<th>Even RNS Residue</th>
<th>RNS Residue for PRP Moduli</th>
</tr>
</thead>
<tbody>
<tr>
<td>$s_2$</td>
<td>$s_2$</td>
<td>$16 - s_2$</td>
</tr>
<tr>
<td>--------------</td>
<td>------------------</td>
<td>-----------------------------</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>15</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>14</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>13</td>
<td>2</td>
</tr>
<tr>
<td>4</td>
<td>12</td>
<td>4</td>
</tr>
<tr>
<td>5</td>
<td>11</td>
<td>4</td>
</tr>
<tr>
<td>6</td>
<td>10</td>
<td>6</td>
</tr>
<tr>
<td>7</td>
<td>9</td>
<td>6</td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td>8</td>
</tr>
</tbody>
</table>

Figure 22. Channel 2 RSNS-to-RNS Conversion for Sub-Channels 0 and 1 (After [2]).

<table>
<thead>
<tr>
<th>RSNS Residue</th>
<th>RNS Residue for PRP Moduli</th>
</tr>
</thead>
<tbody>
<tr>
<td>$s_2$</td>
<td>even($s_2$) even(16 - $s_2$)</td>
</tr>
<tr>
<td>--------------</td>
<td>-------------------------------</td>
</tr>
<tr>
<td>0</td>
<td>0 0 0 0 0 0 0 0 0 0 1</td>
</tr>
<tr>
<td>1</td>
<td>1 0 0 0 0 0 0 0 1</td>
</tr>
<tr>
<td>2</td>
<td>1 0 0 0 0 0 1 0</td>
</tr>
<tr>
<td>3</td>
<td>0 1 0 0 0 0 1 0</td>
</tr>
<tr>
<td>4</td>
<td>0 1 0 0 0 1 0 0</td>
</tr>
<tr>
<td>5</td>
<td>0 0 1 0 0 1 0 0</td>
</tr>
<tr>
<td>6</td>
<td>0 0 1 0 1 0 0 0</td>
</tr>
<tr>
<td>7</td>
<td>0 0 0 1 1 0 0 0</td>
</tr>
<tr>
<td>8</td>
<td>0 0 0 0 1 0 0 0</td>
</tr>
</tbody>
</table>

Figure 23. Channel 2 RSNS-RNS-Position Bit Correspondences for Sub-Channels 0 and 1 (After [2]).
<table>
<thead>
<tr>
<th>RSNS Residue</th>
<th>RNS Residue</th>
<th>Even RNS Residue</th>
<th>RNS Residue for PRP Moduli</th>
</tr>
</thead>
<tbody>
<tr>
<td>$s_2$</td>
<td>$s_2-1$</td>
<td>$15-s_2$</td>
<td>$\text{even}(s_2-1)$</td>
</tr>
<tr>
<td>0</td>
<td>15</td>
<td>15</td>
<td>14</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>14</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>13</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>2</td>
<td>12</td>
<td>2</td>
</tr>
<tr>
<td>4</td>
<td>3</td>
<td>11</td>
<td>2</td>
</tr>
<tr>
<td>5</td>
<td>4</td>
<td>10</td>
<td>4</td>
</tr>
<tr>
<td>6</td>
<td>5</td>
<td>9</td>
<td>4</td>
</tr>
<tr>
<td>7</td>
<td>6</td>
<td>8</td>
<td>6</td>
</tr>
<tr>
<td>8</td>
<td>7</td>
<td>7</td>
<td>6</td>
</tr>
</tbody>
</table>

Figure 24. Channel 2 RSNS-to-RNS Conversion for Sub-Channel 2 (After [2]).

<table>
<thead>
<tr>
<th>RSNS Residue</th>
<th>RNS Residue for PRP Moduli</th>
<th>Position Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>$s_2$</td>
<td>$\text{even}(s_2)$</td>
<td>$\text{even}(15-s_2)$</td>
</tr>
<tr>
<td>0</td>
<td>7</td>
<td>7</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>6</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>6</td>
</tr>
<tr>
<td>4</td>
<td>1</td>
<td>5</td>
</tr>
<tr>
<td>5</td>
<td>2</td>
<td>5</td>
</tr>
<tr>
<td>6</td>
<td>2</td>
<td>4</td>
</tr>
<tr>
<td>7</td>
<td>3</td>
<td>4</td>
</tr>
<tr>
<td>8</td>
<td>3</td>
<td>3</td>
</tr>
</tbody>
</table>

Figure 25. Channel 2 RSNS-RNS-Position Bit Correspondences for Sub-Channel 2 (After [2]).
The RSNS to position bit conversion process for Sub-Channel 0 of Channel 3 are illustrated in Figures 26 and 27. The same process for Sub-Channels 1 and 2 is illustrated in Figures 28 and 29. Note that Sub-Channels 1 and 2 are shifted by one relative to Sub-Channel 0, from (7), (8) and (9). A comparison of Figures 27 and 29 shows that the position bits of Sub-Channels 1 and 2 are the reversed of those for Sub-Channel 0.

<table>
<thead>
<tr>
<th>RSNS Residue</th>
<th>RNS Residue</th>
<th>Even RNS Residue</th>
<th>RNS Residue for PRP Moduli</th>
</tr>
</thead>
<tbody>
<tr>
<td>$s_3$</td>
<td>$s_3$</td>
<td>$18 - s_3$</td>
<td>$\text{even}(s_3)$</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>17</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
<td>16</td>
<td>2</td>
</tr>
<tr>
<td>3</td>
<td>3</td>
<td>15</td>
<td>2</td>
</tr>
<tr>
<td>4</td>
<td>4</td>
<td>14</td>
<td>4</td>
</tr>
<tr>
<td>5</td>
<td>5</td>
<td>13</td>
<td>4</td>
</tr>
<tr>
<td>6</td>
<td>6</td>
<td>12</td>
<td>6</td>
</tr>
<tr>
<td>7</td>
<td>7</td>
<td>11</td>
<td>6</td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td>10</td>
<td>8</td>
</tr>
<tr>
<td>9</td>
<td>9</td>
<td>9</td>
<td>8</td>
</tr>
</tbody>
</table>

Figure 26. Channel 3 RSNS-to-RNS Conversion for Sub-Channel 0 (After [2]).

<table>
<thead>
<tr>
<th>RSNS Residue</th>
<th>RNS Residue for PRP Moduli</th>
<th>Position Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>$s_3$</td>
<td>$\text{even}(s_3)$</td>
<td>$\text{even}(18 - s_3)$</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>3</td>
<td>0</td>
</tr>
<tr>
<td>4</td>
<td>4</td>
<td>0</td>
</tr>
<tr>
<td>5</td>
<td>5</td>
<td>0</td>
</tr>
<tr>
<td>6</td>
<td>6</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>7</td>
<td>0</td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td>0</td>
</tr>
<tr>
<td>9</td>
<td>9</td>
<td>0</td>
</tr>
</tbody>
</table>

Figure 27. Channel 3 RSNS-RNS-Position Bit Correspondences for Sub-Channel 0 (After [2]).
<table>
<thead>
<tr>
<th>RSNS Residue</th>
<th>RNS Residue</th>
<th>Even RNS Residue</th>
<th>RNS Residue for PRP Moduli</th>
</tr>
</thead>
<tbody>
<tr>
<td>$s_3$</td>
<td>$s_3 - 1$</td>
<td>$17 - s_3$</td>
<td>even($s_3$)</td>
</tr>
<tr>
<td>0</td>
<td>17</td>
<td>17</td>
<td>16</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>16</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>15</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>2</td>
<td>14</td>
<td>2</td>
</tr>
<tr>
<td>4</td>
<td>3</td>
<td>13</td>
<td>2</td>
</tr>
<tr>
<td>5</td>
<td>4</td>
<td>12</td>
<td>4</td>
</tr>
<tr>
<td>6</td>
<td>5</td>
<td>11</td>
<td>4</td>
</tr>
<tr>
<td>7</td>
<td>6</td>
<td>10</td>
<td>6</td>
</tr>
<tr>
<td>8</td>
<td>7</td>
<td>9</td>
<td>6</td>
</tr>
<tr>
<td>9</td>
<td>8</td>
<td>8</td>
<td>8</td>
</tr>
</tbody>
</table>

Figure 28. Channel 3 RSNS-to-RNS Conversion for Sub-Channels 1 and 2 (After [2]).

<table>
<thead>
<tr>
<th>RSNS Residue</th>
<th>RNS Residue for PRP Moduli</th>
<th>Position Bits</th>
</tr>
</thead>
<tbody>
<tr>
<td>$s_3$</td>
<td>even($s_3 - 1$)</td>
<td>even($17 - s_3$)</td>
</tr>
<tr>
<td>0</td>
<td>8</td>
<td>8</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>8</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>7</td>
</tr>
<tr>
<td>4</td>
<td>1</td>
<td>6</td>
</tr>
<tr>
<td>5</td>
<td>2</td>
<td>6</td>
</tr>
<tr>
<td>6</td>
<td>2</td>
<td>5</td>
</tr>
<tr>
<td>7</td>
<td>3</td>
<td>5</td>
</tr>
<tr>
<td>8</td>
<td>3</td>
<td>4</td>
</tr>
<tr>
<td>9</td>
<td>4</td>
<td>4</td>
</tr>
</tbody>
</table>

Figure 29. Channel 3 RSNS-RNS-Position Bit Correspondences for Sub-Channels 1 and 2 (After [2]).
2. Position Bit Equations

Using logic tables and Karnaugh mapping, we can show that the general equations of the position bits for even and odd moduli are [2]:

For even moduli, and

\[
p_{i0} = s_{i1},
\]
\[
p_{i1} = s_{i1}s_{i3},
\]
\[
p_{i2} = s_{i3}s_{i5},
\]
\[...
\]
\[
p_{i\left(\frac{m}{2}\right)-1} = s_{i\left(m-3\right)}s_{i\left(m-1\right)},
\]
\[
p_{i\left(\frac{m}{2}\right)} = s_{i\left(m-2\right)},
\]
\[
p_{i\left(\frac{m}{2}\right)+1} = s_{i\left(m-4\right)}s_{i\left(m-2\right)},
\]
\[...
\]
\[
p_{i\left(m-3\right)} = s_{i4}s_{i6},
\]
\[
p_{i\left(m-2\right)} = s_{i2}s_{i4},
\]
\[
p_{i\left(m-1\right)} = s_{i0}s_{i2},
\]

(21)

for even moduli, and

For odd moduli, and

\[
p_{i0} = s_{i1},
\]
\[
p_{i1} = s_{i1}s_{i3},
\]
\[
p_{i2} = s_{i3}s_{i5},
\]
\[...
\]
\[
p_{i\left(\frac{m}{2}\right)-1} = s_{i\left(m-4\right)}s_{i\left(m-2\right)},
\]
\[
p_{i\left(\frac{m}{2}\right)} = s_{i\left(m-2\right)},
\]
\[
p_{i\left(\frac{m}{2}\right)+1} = s_{i\left(m-3\right)}s_{i\left(m-1\right)},
\]
\[...
\]
\[
p_{i\left(m-3\right)} = s_{i4}s_{i6},
\]
\[
p_{i\left(m-2\right)} = s_{i2}s_{i4},
\]
\[
p_{i\left(m-1\right)} = s_{i0}s_{i2},
\]

(22)

for odd moduli.
Equations (21) and (22) are used to generate the position bits as follows:

\[
\begin{align*}
    p_{10} &= s_{11}, \\
    p_{11} &= s_{11}s_{13}, \\
    p_{12} &= s_{13}s_{15}, \\
    p_{13} &= s_{15}, \\
    p_{14} &= s_{14}s_{16}, \\
    p_{15} &= s_{12}s_{14}, \\
    p_{16} &= s_{10}s_{12},
\end{align*}
\]  

(23)

for \( m_1 = 7 \), and

\[
\begin{align*}
    p_{20} &= s_{21}, \\
    p_{21} &= s_{21}s_{23}, \\
    p_{22} &= s_{23}s_{25}, \\
    p_{23} &= s_{25}s_{27}, \\
    p_{24} &= s_{26}, \\
    p_{25} &= s_{24}s_{26}, \\
    p_{26} &= s_{22}s_{24}, \\
    p_{27} &= s_{20}s_{22},
\end{align*}
\]  

(24)

for \( m_2 = 8 \), and

\[
\begin{align*}
    p_{30} &= s_{31}, \\
    p_{31} &= s_{31}s_{33}, \\
    p_{32} &= s_{33}s_{35}, \\
    p_{33} &= s_{35}s_{37}, \\
    p_{34} &= s_{37}, \\
    p_{35} &= s_{36}s_{38}, \\
    p_{36} &= s_{34}s_{36}, \\
    p_{37} &= s_{32}s_{34}, \\
    p_{38} &= s_{30}s_{32},
\end{align*}
\]  

(25)

for \( m_3 = 9 \).
C. EVEN RESIDUE AND SUB-CHANNEL FLAGS

From Figures 20–29, it can be seen that only the position bits representing even RSNS residues for all three channels require bit reversal, depending on the sub-channel they come from. This means that a logic block is required in the converter diagram to check for even residues and their sub-channels.

1. Even Residue Flags

The letter ‘e’ is used to represent an even residue flag, with the subscript denoting the channel. Each flag will be asserted when the RSNS residue is even. It was shown in [2] that the general equations of the even residue flags are:

\[
evenmoduli = s_{i0} + s_{i1}s_{i2} + s_{i3}s_{i4} + \cdots + s_{i(m-1)},
\]

and

\[
oddmoduli = s_{i0} + s_{i1}s_{i2} + s_{i3}s_{i4} + \cdots + s_{i(m-2)}s_{i(m-1)}.
\]

Equations (26) and (27) are used to generate the even residue flags as follows:

Channel 1: \( e_1 = s_{01} + s_{11}s_{12} + s_{13}s_{14} + s_{16} \)

Channel 2: \( e_2 = s_{20} + s_{21}s_{22} + s_{23}s_{24} + s_{26} + s_{27} \)

Channel 3: \( e_3 = s_{30} + s_{31}s_{32} + s_{33}s_{34} + s_{36} + s_{38} \).

2. Sub-Channel Flags

The symbol ‘SC’ is used to represent a sub-channel flag, with the subscript denoting the channel. Each flag is used to determine if the position bits of each RSNS residue require reversal, depending on their sub-channels. With the sub-script \( N \) to denote the number of channels in the system, it was shown in [2] that the general equations of the sub-channel flags are:
\[ SC_{N-1} = e_1 \oplus e_2, \]
\[ SC_{N-2} = e_2 \oplus e_3, \]
\[ \vdots \]
\[ SC_2 = e_{N-2} \oplus e_{N-1}, \]
\[ SC_1 = e_N \oplus e_{N-1}, \]
\[ \overline{SC_0} = e_N \oplus e_1, \]

where \( \oplus \) denotes an XOR operation.

Equation (29) is used to generate the sub-channel flags as follows:

\[ \overline{SC_0} = e_3 \oplus e_1, \]
\[ SC_1 = e_3 \oplus e_2, \]
\[ SC_2 = e_2 \oplus e_1. \] (30)

D. CONDITIONAL BIT REVERSAL

Conditional bit reversal of the position bits is based on the sub-channel flags. In order to maintain proper housekeeping of variable-naming, all position bits after inversion have an additional subscript ‘\( a \)’.

Based on Figures 20–29, the position bits of Channel 1 are never reversed. The position bits of Channel 2 are reversed if the residue is from Sub-Channel 2, i.e., when \( SC_2 \) is asserted. The position bits of Channel 3 are reversed if the residue is from Sub-Channel 1 or 2, i.e., when \( \overline{SC_0} \) is asserted. Note that \( SC_1 \) is not required for this shift sequence.

This reversal procedure can be accomplished via multiplexer circuits using the sub-channel flags as control signals and will be shown in Chapter IV.
E. LEAST POSITIVE SOLUTION ALIGNMENT

After determining the position bits for each channel, the position bits from all three channels are then used to compute the LPS of the positional alignment. One useful property is to make use of the one-to-one correspondence between the RNS residues and the position bits. This allows the RNS residues to be replaced by the position bits in Figure 16. This is shown in Figure 30.

Recall from (15) and (16) that the RNS vector \( \frac{XR_{g/2}}{2} \) corresponds to the RSNS vector \( X_{732} = [6 4 8]^T \), which is of form \([e	ext{ e e}]^T\) and from Sub-Channel 0. From Figure 21, the RSNS Channel 1 residue \( s_1 = 6 \) corresponds to RNS residues of 3 and 4, which are asserted and highlighted in Figure 30. Similarly, from Figure 23, the RSNS Channel 2 residue \( s_2 = 4 \) corresponds to RNS residues of 2 and 6, and the RSNS Channel 3 residue \( s_3 = 8 \) corresponds to RNS residues of 3 and 5 from Figure 27.

| RNS Vectors | \( m_1 = 7 \) | 3 | 4 | 5 | 6 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 0 | 1 | 2 | 3 | 4 | ... |
| \( m_2 = 8 \) | 2 | 3 | 4 | 5 | 6 | 7 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 0 | ... |
| \( m_3 = 9 \) | 5 | 6 | 7 | 8 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 0 | ... |
| LPS \( g/2 \) | 122 | 123 | 124 | 125 | 126 | 127 | 128 | 129 | 130 | 131 | 132 | 133 | 134 | 135 | 136 | 137 | 138 | 139 | 140 | 141 | 142 | 143 | 144 | ...

| Position Bits | \( m_1 = 7 \) | \( \ldots \) | \( \ldots \) | \( \ldots \) | \( P_{13} \) | \( P_{14} \) | \( P_{15} \) | \( P_{16} \) | \( P_{10} \) | \( P_{11} \) | \( P_{12} \) | \( P_{13} \) | \( P_{14} \) | \( P_{15} \) | \( P_{16} \) | \( P_{10} \) | \( P_{11} \) | \( P_{12} \) | \( P_{13} \) | \( P_{14} \) | \( \ldots \) |
| \( m_2 = 8 \) | \( \ldots \) | \( \ldots \) | \( \ldots \) | \( \ldots \) | \( P_{22} \) | \( P_{23} \) | \( P_{24} \) | \( P_{25} \) | \( P_{26} \) | \( P_{27} \) | \( P_{20} \) | \( P_{21} \) | \( P_{22} \) | \( P_{23} \) | \( P_{24} \) | \( P_{25} \) | \( P_{26} \) | \( P_{27} \) | \( P_{20} \) | \( \ldots \) |
| \( m_3 = 9 \) | \( \ldots \) | \( \ldots \) | \( \ldots \) | \( \ldots \) | \( P_{35} \) | \( P_{36} \) | \( P_{37} \) | \( P_{38} \) | \( P_{30} \) | \( P_{31} \) | \( P_{32} \) | \( P_{33} \) | \( P_{34} \) | \( P_{35} \) | \( P_{36} \) | \( P_{37} \) | \( P_{38} \) | \( P_{30} \) | \( \ldots \) |
| LPS \( g/2 \) | \( \ldots \) | \( 0 \) | \( 1 \) | \( 2 \) | \( 3 \) | \( 4 \) | \( 5 \) | \( 6 \) | \( 7 \) | \( 8 \) | \( 9 \) | \( 10 \) | \( 11 \) | \( 12 \) | \( 13 \) | \( 14 \) | \( 15 \) | \( 16 \) | \( 17 \) | \( 18 \) | \( 19 \) | \( 20 \) | \( 21 \) | \( 22 \) | ...

Figure 30. LPS Alignment using Position Bits.
The asserted RNS residues for the three channels are shown in Figure 30. Ideally, only one LPS should be active within the DR to prevent ambiguities. However, there is more than one LPS ($LPS0$ and $LPS8$) asserted for this case.

There is an ambiguity in this case because the DR length (133) is not evenly divisible by six, and the DR starts at an index position (733) that is not evenly divisible by six. There are two methods to overcome this, and these are explained below.

1. **Full Dynamic Range With LPS Priority**

   If the DR is not truncated to a length that is evenly divisible by six, it is possible that two LPS equations will be asserted at the same time – one of the boundary LPS equations (i.e., $LPS0$ or $LPS22$) and $LPSX$. If the full DR is to be maintained, the boundary LPS equation should always be ignored in favor of the $LPSX$ solution.

   This can be done by using additional logic circuitry to check for such cases and giving priority to the $LPSX$ solution over the boundary LPS equations. The details of this circuitry are elaborated in Chapter V.

2. **Truncated Dynamic Range**

   The DR can be truncated to a length that is evenly divisible by six, i.e., 126, so that it starts with a Sub-Channel 0 vector and ends with a Sub-Channel 2 vector, as required in Figure 9. The number of RNS vectors required to span the DR is now:

   $$L = \left\lfloor \frac{\hat{M}}{2N} \right\rfloor = \left\lfloor \frac{126}{6} \right\rfloor = 21.$$  \hspace{1cm} (31)

   For the first case where the full DR is maintained, the number of RNS vectors required to span the DR is 23, in accordance with (17). The full 23 alignment equations are given by
These operations can be accomplished using 3-input NAND gates. Note that the last two LPS equations (LPS21 and LPS22) are not required for the truncated DR case.
F. ENCODER

The next step is to convert from the LPS index $g/2$ to a binary representation of the position $h$ of the RSNS vector within the DR bounds. Since only one of the $LPSX$ equations will be asserted at any one time, an encoder can be used to convert the 23 possible outputs to a binary representation using $B$ bits, calculated via

$$B = \log_2 \left\lceil \frac{L}{2} \right\rceil.$$  \hspace{1cm} (33)

Five bits are required for both the full and truncated DR cases, with a 23-to-5 encoder for the full DR case and a 21-to-5 encoder for the truncated DR case.

G. ADDER

As the output of the encoder is a five-bit representation of $g/2$, a left-shifted version of $g/2$ is equivalent to a multiplication by two and converts it to a six-bit index $g$. From (18), the $F_{odd}$ compensation factor has to be computed next, as the DR was compressed using even residues only. The factor $F_{odd}$ is equal to $\overline{e_i}$ since the complement of $e_i$ is asserted when the Channel 1 residue $s_i$ is odd, as shown in (28). The LSB of $g$ is guaranteed to be zero, as $g$ is a left-shifted version of $g/2$. Thus, the even residue flag $\overline{e_i}$ can replace the LSB of $g$.

From Equation (18), the computation of $3(g + \overline{e_i})$ is also required. It is easier to implement this as $3X = 2X + X$ in hardware using a wired shift and an adder rather than a multiplication by three using a multiplexer. To achieve this, $(g + \overline{e_i})$ is shifted one position left to form $2(g + \overline{e_i})$ and used as the input to an eight-bit carry-look-ahead adder. This concept is illustrated in Figure 31, where the notation $g_b$ refers to the $b^{th}$ bit of the binary representation of index $g$ [2].
Lastly, Equation (18) requires the addition of the $F_{sc}$ compensation factor, as the DR was compressed using Sub-Channel 0 vectors only. The $F_{sc}$ compensation factor is represented by the signals $SC2$ and $\overline{SC0}$ from (30), which are asserted if the Channel 2 residue is from Sub-Channel 2, and the Channel 3 residue is from Sub-Channel 1 or 2, respectively.

Fortunately, the left shift of $(g + \overline{e_i})$ provides a LSB slot guaranteed to be zero, and the carry-in to the adder provides another LSB slot. This allows $(g + \overline{e_i}), 2(g + \overline{e_i}), \overline{SC0}$, and $SC2$ to be summed in a single adder [2], shown in Figure 32.

The output of this adder is the binary representation of the position $h$ within the DR for the RSNS vector $X_h = [s_1, s_2, s_3]^T$. The LabVIEW circuit schematics that implement the logic equations developed in this chapter are provided in the next chapter.
IV. LABVIEW IMPLEMENTATION OF RSNS-TO-BINARY CONVERSION

Using the logic equations developed in the previous chapter, we document the process of implementing the RSNS-to-binary converter in the NI LabVIEW programming environment in this chapter.

A. LABVIEW SCHEMATICS OF RSNS-TO-BINARY CONVERTER

The NI LabVIEW programming environment was specifically selected as its programming structure is modular in nature. This allows the codes for each logic block to be stored as sub-routines or sub-Virtual Instruments (sub-VIs) and run as part of a larger routine or Virtual Instrument (VI).

This modular structure is beneficial for the future expansion of such RSNS ADC system as it allows additional sub-routines to be designed and added to existing routines should it be decided to scale the ADC to higher moduli configurations in future.

In addition, if the ADC requires future upgrading, it is relatively easy to replace current FPGA modules with other higher-speed and higher-bandwidth NI modules with minimal disruption to existing codes due to its plug-and-play features.

The overall schematics of this converter in LabVIEW are shown in Figure 33 based on the major logic blocks developed in Chapter III. The process of constructing each logic block as a sub-routine and implementing it as part of the overall routine is detailed in the subsequent sections.
B. POSITION BIT CONVERSION AND EVEN RESIDUE/SUB-CHANNEL FLAGS

The logic blocks for position bit conversion and even residue flags are combined, as both of them can be calculated using the thermometer codes from the comparators. The Boolean equations used are modified from those in Chapter III. The only changes are the application of DeMorgan’s Theorem to use NAND, NOR and inverter gates predominantly.

1. Channel 1

DeMorgan’s Theorem was applied to equations (23) and (28) to obtain:
\[ p_{10} = s_{11}, \]
\[ p_{11} = s_{11} \cdot s_{13} = s_{11} + s_{13}, \]
\[ p_{12} = s_{13} \cdot s_{15} = s_{13} + s_{15}, \]
\[ p_{13} = s_{15}, \]
\[ p_{14} = s_{14} \cdot s_{16} = s_{14} + s_{16}, \]
\[ p_{15} = s_{12} \cdot s_{14} = s_{12} + s_{14}, \]
\[ p_{16} = s_{10} \cdot s_{12} = s_{10} + s_{12}, \]  \hspace{1cm} (34)

and

\[ e_1 = s_{10} + s_{11} \cdot s_{12} + s_{13} \cdot s_{14} + s_{15} \cdot s_{16} = s_{10} \left( s_{11} \cdot s_{12} \right) \left( s_{13} \cdot s_{14} \right) \left( s_{15} \cdot s_{16} \right). \]  \hspace{1cm} (35)

The implementation of equations (34) and (35) in LabVIEW is shown in Figure 33.

Figure 34. LabVIEW Schematics of Channel 1 Position Bit and Even Residue Flag.
2. Channel 2

DeMorgan’s Theorem was applied to equations (24) and (28) to obtain

\[
\begin{align*}
p_{20} &= s_{21}, \\
p_{21} &= s_{21}s_{23} = s_{21} + s_{23}, \\
p_{22} &= s_{23}s_{25} = s_{23} + s_{25}, \\
p_{23} &= s_{25}s_{27} = s_{25} + s_{27}, \\
p_{24} &= s_{26}, \\
p_{25} &= s_{24}s_{26} = s_{24} + s_{26}, \\
p_{26} &= s_{22}s_{24} = s_{22} + s_{24}, \\
p_{27} &= s_{20}s_{22} = s_{20} + s_{22},
\end{align*}
\]

and

\[
\begin{align*}
e_2 &= s_{20} + s_{21}s_{22} + s_{23}s_{24} + s_{25}s_{26} + s_{27} = s_{20}(s_{21}s_{22})(s_{23}s_{24})(s_{25}s_{26})s_{27},
\end{align*}
\]

The implementation of equations (36) and (37) in LabVIEW is shown in Figure 35.

Figure 35. LabVIEW Schematics of Channel 2 Position Bit and Even Residue Flag.
3. Channel 3

DeMorgan’s Theorem was applied to equations (25) and (28) to obtain

\[ p_{30} = s_{31}, \]
\[ p_{31} = s_{31}s_{33} = s_{31} + s_{33}, \]
\[ p_{32} = s_{33}s_{35} = s_{33} + s_{35}, \]
\[ p_{33} = s_{35}s_{37} = s_{35} + s_{37}, \]
\[ p_{34} = s_{37}, \] \hspace{1cm} (38)
\[ p_{35} = s_{36}s_{38} = s_{36} + s_{38}, \]
\[ p_{36} = s_{34}s_{36} = s_{34} + s_{36}, \]
\[ p_{37} = s_{32}s_{34} = s_{32} + s_{34}, \]
\[ p_{38} = s_{30}s_{32} = s_{30} + s_{32}, \]

and

\[ e_3 = s_{30} + s_{31}s_{32} + s_{33}s_{34} + s_{35}s_{36} + s_{39}s_{38} = s_{30}\left( s_{31}s_{32} \right)\left( s_{33}s_{34} \right)\left( s_{35}s_{36} \right)\left( s_{37}s_{38} \right). \] \hspace{1cm} (39)

The implementation of equations (38) and (39) in LabVIEW is shown in Figure 36.
4. Sub-Channel Flags

Equation (30) was used to construct the Sub-Channel flags in Figures 37 and 38 using XOR gates. They are used to check if the position bits of each RSNS residue require bit reversal, depending on which sub-channel it is from.

Figure 37. Sub-Channel 0 Flag.
C. CONDITIONAL BIT REVERSAL

Each inverted position bit was mapped from two possible states, depending on whether it was inverted or not. For example, the position bit $p_{20a}$ was mapped from $p_{20}$ if it was not inverted and mapped from $p_{27}$ if it was inverted. Thus, the Boolean expression for position bit $p_{20a}$ can be expressed as: $p_{20a} = p_{27}SC_2 + p_{20}SC_2 = \overline{(p_{27}SC_2)} \cdot \overline{(p_{20}SC_2)}$.

The conditional bit reversal for each position bit can be accomplished by the use of a 2-to-1 multiplexer, shown in Figure 39, using the sub-channel flag as a control signal. The desired output is either Input 1 or Input 2, depending on whether the control signal is asserted or not asserted, respectively. This procedure can be applied to all the other position bits.

![Diagram of a 2-to-1 Multiplexer](image)

Given Figure 39 as a basic building block, the multiplexer architecture is extended to form the Channel 2 and Channel 3 bit reversal circuits, shown in the next two sections. The only modifications are that NAND gates are predominantly used to achieve the same logic operation as the AND and OR gates in Figure 39.
1. **Channel 2 Reversal**

Recall that the position bits of Channel 1 are never reversed from Figure 21. Thus, a Channel 1 reversal circuit is not required for this implementation. For Channel 2, the position bits are reversed if the residue is from Sub-Channel 2, i.e., when $SC_2$ is asserted, from a comparison of Figures 23 and 25. The LabVIEW schematics of the Channel 2 conditional bit reversal circuit are shown in Figure 40.

![Figure 40. LabVIEW Schematics of Channel 2 Conditional Bit Reversal.](image)

2. **Channel 3 Reversal**

For Channel 3, the position bits are reversed if the residue is from Sub-Channel 1 or 2, i.e., when $SC_0$ is asserted, from a comparison of Figures 27 and 29. The LabVIEW schematics of the Channel 3 conditional bit reversal circuit are shown in Figure 41.
D. ALIGNMENT LOGIC

The LabVIEW schematics of the alignment logic circuit to achieve the full DR of 133 are shown in Figure 42. It is a direct mapping of equation (32). The only modification is the insertion of inverters to allow the proper functioning of the encoder circuit.
Figure 42. LabVIEW Schematics of Alignment Logic (Full DR).

Note that the last two LPS equations ($LPS21$ and $LPS22$) are not required for the truncated DR case, and have to be removed if it is implemented.
E.  ENCODER

Since only one of the LPSX equations will be asserted at any one time in the Alignment Logic circuit in Figure 42, an encoder can be used to convert the 23 possible outputs to a 5-bit representation.

To achieve this, a logic table is derived in Table 2. The function of the encoder is to convert the LPS number of the asserted NAND gate into a five-bit output. For example, if n22 is the active NAND gate, the encoder output will be 10110.

Table 2.  Encoder Logic Table.

<table>
<thead>
<tr>
<th>Active NAND Gate</th>
<th>g4</th>
<th>g3</th>
<th>g2</th>
<th>g1</th>
<th>g0</th>
</tr>
</thead>
<tbody>
<tr>
<td>n0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>n1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>n2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>n3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>n4</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>n5</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>n6</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>n7</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>n8</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>n9</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>n10</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>n11</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>n12</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>n13</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>n14</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>n15</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>n16</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>n17</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>n18</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>n19</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>n20</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>n21</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>n22</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>
The output bits of the encoder are thus the OR combination of all the logic 1s in their respective columns in Table 2. For example, g4 will be asserted if any of the n16, n17, n18, n19, n20, n21 and n22 gate is active. Again, note that the last two gates are not required for the truncated DR case and have to be removed if it is implemented.

The LabVIEW implementation of the encoder for the truncated DR and the full DR cases are highlighted in the next two sections.

1. **Truncated Dynamic Range**

The logical binary expressions for the 21-to-5 encoder for the truncated DR case, derived from Table 2, are given by

\[
\begin{align*}
    g_0 &= (n_1 + n_3 + n_5)(n_7 + n_9 + n_{11})(n_{13} + n_{15})(n_{17} + n_{19}) \\
    g_1 &= (n_2 + n_3 + n_6)(n_7 + n_{10} + n_{11})(n_{14} + n_{15})(n_{18} + n_{19}) \\
    g_2 &= (n_4 + n_5 + n_6)(n_7 + n_{12} + n_{13})(n_{14} + n_{15} + n_{20}) \\
    g_3 &= (n_8 + n_9 + n_{10})(n_{11} + n_{12} + n_{13})(n_{14} + n_{15}) \\
    g_4 &= (n_{16} + n_{17} + n_{18})(n_{19} + n_{20}).
\end{align*}
\]  

The implementation of equation (40) in LabVIEW as an encoder circuit to achieve the truncated DR of 128 is shown in Figure 43.
2. Full Dynamic Range

The logical binary expressions for the 23-to-5 encoder for the full DR case, derived from Table 2, are given by

\[
\begin{align*}
    g_0 &= (n_1 + n_3 + n_5)(n_7 + n_9 + n_{11})(n_{13} + n_{15} + n_{17})(n_{19} + n_{21}) \\
    g_1 &= (n_2 + n_3 + n_6)(n_7 + n_{10} + n_{11})(n_{14} + n_{15} + n_{18})(n_{19} + n_{22}) \\
    g_2 &= (n_4 + n_5 + n_6)(n_7 + n_{12} + n_{13})(n_{14} + n_{15} + n_{20})(n_{21} + n_{22}) \\
    g_3 &= (n_8 + n_9 + n_{10})(n_{11} + n_{12} + n_{13})(n_{14} + n_{15}) \\
    g_4 &= (n_{16} + n_{17} + n_{18})(n_{19} + n_{20})(n_{21} + n_{22}).
\end{align*}
\]
The implementation of equation (41) in LabVIEW as an encoder circuit is shown in Figure 44.

Figure 44. LabVIEW Schematics of Encoder (Full DR).
F. ADDER

The LabVIEW schematics of the adder circuit to convert the encoder’s 5-bit representation to a binary representation of the position $h$ within the DR are shown in Figure 45. It is a direct implementation of Figure 32.

![Figure 45. LabVIEW Schematics of Adder.](image)

The implementation of the logic blocks of the RSNS-to-binary converter in LabVIEW was shown in this chapter. The simulation and testing of this converter to verify that the conversion logic is functioning properly is documented in the next chapter.
V. SIMULATION OF RSNS-TO-BINARY CONVERSION

The simulation and testing of the RSNS-to-binary converter to verify that the conversion logic is functioning properly is contained in this chapter. The first section of this chapter is a description of the creation of thermometer codes for each channel in LabVIEW to simulate as the inputs to the conversion algorithm. The second section contains the key results obtained for three simulation models (truncated DR, full DR, and full DR with LPS Priority cases).

A. LABVIEW THERMOMETER CODE GENERATORS

The LabVIEW software does not have functions to generate the thermometer codes directly. However, the one-to-one correspondence between the RNS and RSNS vectors can be exploited to convert a RNS structure into a RSNS thermometer code. Previously, it was demonstrated in Figure 14 that each RSNS thermometer code can be mapped to a unique RNS state such that there is no ambiguity within a single channel period. Thus, LabVIEW functions can be created to act as counters to cycle through the RNS states for each channel, and digital logic can be added to map each RNS state to the required RSNS thermometer code. The next three sections contain the details of the procedure to generate the thermometer codes for each of the three channels.

1. Channel 1

The logic table for Channel 1 is shown in Table 3. The RNS states are represented by the bits \(i_{13}, i_{12}, i_{11}, i_{10}\) and are the inputs to the Channel 1 thermometer code generator. The desired thermometer code output is represented by the RSNS bits \(s_{16}, s_{15}, s_{14}, s_{13}, s_{12}, s_{11}, s_{10}\).

Karnaugh maps are used to carry out logic minimization for Table 3, shown in Figure 46.
Table 3. Channel 1 ($m_1 = 7$) Logic Table.

<table>
<thead>
<tr>
<th>RNS State</th>
<th>$i_{13}$</th>
<th>$i_{12}$</th>
<th>$i_{11}$</th>
<th>$i_{10}$</th>
<th>RSNS State</th>
<th>$s_{16}$</th>
<th>$s_{15}$</th>
<th>$s_{14}$</th>
<th>$s_{13}$</th>
<th>$s_{12}$</th>
<th>$s_{11}$</th>
<th>$s_{10}$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>6</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>7</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>8</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>6</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>9</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>5</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>10</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>11</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>12</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>13</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

Figure 46. Channel 1 Logic Minimization of Table 3 (After [4]).
The logic minimization in Figure 46 is used to produce the logic equations

\[ s_{10} = i_3 + i_2 + i_1 + i_0 = \overline{i_3 + i_2 + i_1 + i_0} \]

\[ s_{11} = i_1 + \overline{i_3i_2} + i_3i_2 + i_3i_0 = \overline{i_1 \left( i_3i_2 \right) (i_3i_2)} \]

\[ s_{12} = \overline{i_3i_2} + \overline{i_3i_2i_0} = i_1 \left( i_3i_2 \right) \overline{i_3i_0} \]

\[ s_{13} = \overline{i_3i_2} + i_3i_2i_1 + i_3i_2i_0 = i_1 \left( i_3i_2i_1 \right) \overline{i_3i_2i_0} \]

\[ s_{14} = i_2i_1 + i_3i_2i_0 + \overline{i_3i_2i_1} = \left( i_2i_1 \right) \left( i_3i_2i_0 \right) \overline{i_3i_2i_1} \]

\[ s_{15} = i_2i_1 + i_3i_2i_0 = \left( i_2i_1 \right) \left( i_3i_2i_0 \right) \]

\[ s_{16} = i_2i_1i_0 = \overline{i_2} + i_1 + i_0 \]

These logic equations are used to implement the Channel 1 thermometer code generator in LabVIEW, shown in Figure 47.
Note that DeMorgan’s Theorem was used to achieve a convenient pipelined implementation of all bits in the three channels.

2. Channel 2

The logic table for Channel 2 is shown in Table 4. The RNS states are represented by the bits \( \{i_{23}, i_{22}, i_{21}, i_{20}\} \) and are the inputs to the Channel 2 thermometer code generator. The desired thermometer code output is represented by the RSNS bits \( \{s_{27}, s_{26}, s_{25}, s_{24}, s_{23}, s_{22}, s_{21}, s_{20}\} \).

Table 4. Channel 2 (\( m_2 = 8 \)) Logic Table.

<table>
<thead>
<tr>
<th>RNS State</th>
<th>( i_{23} )</th>
<th>( i_{22} )</th>
<th>( i_{21} )</th>
<th>( i_{20} )</th>
<th>RSNS State</th>
<th>( s_{27} )</th>
<th>( s_{26} )</th>
<th>( s_{25} )</th>
<th>( s_{24} )</th>
<th>( s_{23} )</th>
<th>( s_{22} )</th>
<th>( s_{21} )</th>
<th>( s_{20} )</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>6</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>7</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>8</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>8</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>9</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>7</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>10</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>6</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>11</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>12</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>13</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>14</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>15</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Karnaugh maps are used to carry out logic minimization for Table 4, shown in Figure 48.
The logic minimization in Figure 48 is used to produce the logic equations

\[
\begin{align*}
S_{20} &= i_3 + i_2 + i_1 + i_0 = \overline{i_3} + i_2 + l_1 + i_0 \\
S_{21} &= i_3 i_2 + i_3 i_1 + i_2 i_1 + i_3 i_0 = \left(\overline{i_3} i_2\right) + \left(i_3 \overline{i_1}\right) + \left(i_2 i_1\right) + \left(i_3 \overline{i_0}\right) \\
S_{22} &= i_3 i_2 + i_2 i_1 + i_1 i_0 + i_3 i_0 = \left(i_3 \overline{i_2}\right) + \left(i_2 i_1\right) + \left(i_1 i_0\right) + \left(i_3 i_0\right) \\
S_{23} &= i_3 i_2 + i_3 i_2 + i_3 i_1 i_0 = \left(i_3 i_2\right) + \left(i_3 \overline{i_1}\right) + \left(i_3 i_0\right) \\
S_{24} &= i_3 i_2 + i_3 i_2 i_0 + i_3 i_2 l_1 = \left(i_3 \overline{i_2}\right) + \left(i_3 i_2 i_0\right) + \left(i_3 i_2 l_1\right) \\
S_{25} &= i_3 i_2 l_1 + i_3 i_2 i_0 + i_3 i_2 l_1 = \left(i_3 \overline{i_2}\right) + \left(i_3 i_2 i_0\right) + \left(i_3 i_2 l_1\right) \\
S_{26} &= i_3 i_2 l_1 + i_3 i_2 i_0 = \left(i_3 \overline{i_2}\right) + \left(i_3 i_2 i_0\right) \\
S_{27} &= i_3 i_2 l_1 i_0 = i_3 + i_2 + l_1 + i_0
\end{align*}
\]
These logic equations are used to implement the Channel 2 thermometer code generator in LabVIEW, shown in Figure 49.
3. Channel 3

The logic table for Channel 3 is shown in Table 5. The RNS states are represented by the bits \( \{i_{34}, i_{33}, i_{32}, i_{31}, i_{30}\} \) and are the inputs to the Channel 3 thermometer code generator. The desired thermometer code output is represented by the RSNS bits \( \{s_{38}, s_{37}, s_{36}, s_{35}, s_{34}, s_{33}, s_{32}, s_{31}, s_{30}\} \).

Table 5. Channel 3 \((m_3 = 9)\) Logic Table.

<table>
<thead>
<tr>
<th>RNS State</th>
<th>(i_{34})</th>
<th>(i_{33})</th>
<th>(i_{32})</th>
<th>(i_{31})</th>
<th>(i_{30})</th>
<th>RSNS State</th>
<th>(s_{38})</th>
<th>(s_{37})</th>
<th>(s_{36})</th>
<th>(s_{35})</th>
<th>(s_{34})</th>
<th>(s_{33})</th>
<th>(s_{32})</th>
<th>(s_{31})</th>
<th>(s_{30})</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>5</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>6</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>7</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>8</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>8</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>9</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>9</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>10</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>8</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>11</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>7</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>12</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>6</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>13</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>5</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>15</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>3</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>16</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>2</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>17</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>

Karnaugh maps are used to carry out logic minimization for Table 5, shown in Figure 50.
Figure 50. Channel 3 Logic Minimization of Table 5 (After [4]).
The logic minimization in Figure 50 is used to produce the logic equations

\[ s_{30} = i_4 + i_3 + i_2 + i_1 + i_0 = (i_4 + i_3 + i_2) (i_1 + i_0) \]
\[ s_{31} = i_4 i_0 + i_3 + i_2 + i_1 = (i_4 i_0) (i_3 + i_2 + i_1) \]
\[ s_{32} = i_3 + i_2 + i_1 i_0 = (i_3 + i_2) (i_1 i_0) \]
\[ s_{33} = i_3 i_2 + i_3 i_1 + i_3 i_2 + i_3 i_0 = (i_3 i_2) (i_3 i_1) (i_3 i_0) \]
\[ s_{34} = i_3 i_2 + i_3 i_1 + i_2 i_1 i_0 + i_3 i_2 i_1 = (i_3 i_2) (i_3 i_1) (i_2 i_1 i_0) (i_3 i_2 i_1) \] (44)
\[ s_{35} = i_3 i_2 + i_3 i_1 i_0 + i_3 i_1 i_0 = (i_3 i_2) (i_3 i_1 i_0) \]
\[ s_{36} = i_2 i_1 i_0 + i_3 i_2 = (i_3 i_2 i_1 i_0) (i_3 i_2) \]
\[ s_{37} = i_3 i_2 i_1 + i_3 i_2 i_0 = (i_3 i_2 i_1) (i_3 i_2 i_0) \]
\[ s_{38} = i_3 i_2 i_1 i_0 = i_3 + i_2 + i_1 + i_0 \]

These logic equations are used to implement the Channel 3 thermometer code generator in LabVIEW, shown in Figure 51.
Figure 51. LabVIEW Channel 3 Thermometer Code Generator.
B. SIMULATION MODEL

To test the RSNS-to-binary conversion, a simulation model was created with the thermometer code generators from the three channels enclosed within a case structure, shown in Figure 52. A ‘Master Clock’ global variable was created to determine the starting channel and to step through each of the three channels. Three ‘Channel Count’ global variables were used to set the channel start positions.

Figure 52. LabVIEW Simulation of RSNS-to-Binary Conversion.
C. SIMULATION RESULTS

After running the simulation model in Figure 52, the thermometer code inputs and the RSNS-to-binary conversion output can be viewed on the respective scopes located in the LabVIEW Front Panel.

1. Truncated Dynamic Range

The thermometer code inputs and the simulated RSNS-to-binary output with no ambiguities within the truncated DR of 126 are shown in Figure 53. The RSNS position index $h$ is from 733 to 857.

![Simulated RSNS-to-Binary Output (Truncated DR Case)](image)

Figure 53. Simulated RSNS-to-Binary Output (Truncated DR Case).
2. **Full Dynamic Range**

To achieve the full DR, the encoder circuit in Figure 44 was used in place of Figure 43 in the RSNS-to-binary conversion. The ambiguities in the simulated RSNS-to-binary output within the full DR of 133 are shown in Figure 54. The RSNS position index \( h \) is from 733 to 865.

![Simulated RSNS-to-Binary Output (Full DR Case with Ambiguities)](image)

Figure 54. Simulated RSNS-to-Binary Output (Full DR Case with Ambiguities).

3. **LPS Priority Circuit**

The ambiguities in Figure 54 occur because the DR does not start with a Sub-Channel 0 vector and end with a Sub-Channel 2 vector, as required in Figure 9. As a result, a start position with a Sub-Channel 0 vector \( h_i = 732 \) has to be chosen outside the DR, during the DR compression process in Chapter II.
As the DR is not truncated to a length evenly divisible by six, there may be ambiguities where two LPS equations will be asserted at the same time – one of the boundary LPS equations (i.e. \textit{LPS0} or \textit{LPS22}) and \textit{LPSX}. If the full DR is to be maintained with no ambiguities, the boundary LPS equation should always be ignored in favor of the \textit{LPSX} solution.

This can be done by implementing an encoder with an addition of a LPS Priority circuit to check for such cases, and giving priority to the center 21 NAND gates over the first and last NAND gates. This is shown in Figure 55.
4. **Full Dynamic Range with LPS Priority Circuit**

To achieve the full DR with no ambiguities, the encoder circuit in Figure 55 was used in place of Figures 43 and 44 in the RSNS-to-binary conversion. From Figure 56, it can be seen that there are no ambiguities in the simulated RSNS-to-binary output within the full DR of 133. The RSNS position index \( h \) is from 733 to 865.

![Dynamic Range = 133](image)

Figure 56. Simulated RSNS-to-Binary Output (Full DR Case with No Ambiguities).

<table>
<thead>
<tr>
<th>Model</th>
<th>Position Index ( h )</th>
<th>Dynamic Range</th>
<th>Ambiguities?</th>
</tr>
</thead>
<tbody>
<tr>
<td>Truncated DR</td>
<td>733 – 857</td>
<td>126</td>
<td>No</td>
</tr>
<tr>
<td>Full DR</td>
<td>733 – 865</td>
<td>133</td>
<td>Yes</td>
</tr>
<tr>
<td>Full DR with LPS Priority</td>
<td>733 – 865</td>
<td>133</td>
<td>No</td>
</tr>
</tbody>
</table>

Table 6. Comparison of Dynamic Range.
A comparison of the dynamic range achieved by the three different cases is shown in Table 6. The simulation proves that an eight-bit DR of 133 can be achieved for a three-channel RSNS ADC with Moduli $m_1 = 7$, $m_2 = 8$ and $m_3 = 9$. This is in agreement with the theoretical DR calculated from (5), and a one-bit improvement over that achieved in [4].

Simulation of the RSNS-to-binary conversion algorithm was successfully carried out to verify that it is working properly in this chapter. In the next chapter, the implementation of the comparator circuit and RSNS-to-binary conversion algorithm on a FPGA to allow the code to run at a higher sampling rate and frequency is elaborated. The FPGA is then integrated with the front-end photonics implementation to form the overall folding ADC architecture.
VI. ADC INTEGRATION

The integration process to form an overall folding ADC system is documented in this chapter. The first section of this chapter contains an illustration of the implementation of the comparator circuit design and RSNS-to-binary conversion algorithm on an NI FPGA to form the DDS module. The integration of the DDS module with the front-end PES module in [5] is highlighted in the second section.

A. DIGITAL DECODING SUB-SYSTEM

An overview of the DDS module from the bank of comparators to the FPGA is shown in Figure 57. An NI-9215 Analog Input Module is used to connect the three analog photo-detector inputs from the front-end PES module to the NI-9111 Chassis with an onboard XILINX Virtex-5 LX30 FPGA. The FPGA output is then sent to the NI-9012 CompactRIO (cRIO) Real-Time Controller (RTC), and can be saved to a file using a LabVIEW Host Interface VI.
The comparator speed was a limiting factor in the ADC system speed as actual comparator ICs were used for sampling outside the FPGA in [3]. The key improvement made in the DDS module setup in Figure 57 is that the comparator circuits reside in the FPGA, allowing them to sample at a rate equal to the FPGA speed.

Lastly, the comparator circuit and RSNS-to-binary conversion logics are run on the FPGA to guarantee a higher FPGA execution speed as opposed to running it on the RTC with a lower processing speed.

B. COMPARATORS

In the actual ADC architecture, comparators are used to convert the analog photodetector outputs into thermometer codes for each channel in place of thermometer code generators. The threshold values for the comparators can be expressed as [3]:

\[
T(k, m_i) = V_{fs_i} \cos^2 \left( \frac{\pi}{2} \left( \frac{\pi(kN + 1)}{P_{RSNS}} + \frac{\pi}{2P_{RSNS}} \right) \right)
\]  \hspace{1cm} (45)

where \( k = 0, 1, \ldots, m_i - 1 \), \( V_{fs} \) = full-scale voltage for channel Moduli \( m_i \), \( N \) = number of channels, and \( P_{RSNS} \) = period of RSNS channel = \( 2Nm_i \).

The full-scale voltage is defined as the maximum amplitude of the modulated signal for each channel and determined in [5].

1. **Channel 1**

Using (45) with \( V_{fs} = 2.5 \) (from [5]), we calculate the quantized threshold values for Channel 1 as:

\[
T(k, m_1) = [0.0313, 0.2727, 0.7076, 1.2500, 1.7924, 2.2273, 2.4687]. \hspace{1cm} (46)
\]
The implementation of the Channel 1 comparators in LabVIEW using the threshold voltages calculated in (46) is shown in Figure 58.

![LabVIEW Schematics of Channel 1 Comparators.](image)

Figure 58. LabVIEW Schematics of Channel 1 Comparators.

2. **Channel 2**

Using (45) with $V_{f_{s}} = 5.11$ (provided from [5]), we calculate the quantized threshold values for Channel 2 as

$$T(k, m_{1}) = [0.0419, 0.4306, 1.1355, 2.0565, 3.0535, 3.9745, 4.6794, 5.0609].$$ (47)

The implementation of the Channel 2 comparators in LabVIEW using the threshold voltages calculated in (47) is shown in Figure 59.
3. Channel 3

Using (45) with $V_{fs} = 4.96$ (provided from [5]), we calculate the quantized threshold values for Channel 3 as

$$T(k, m_3) = [0.0377, 0.3323, 0.8859, 1.6318, 2.4800, 3.3282, 4.0741, 4.6277, 4.9223].$$  (48)

The implementation of the Channel 3 comparators in LabVIEW using the threshold voltages calculated in (48) is shown in Figure 60.
C. FPGA IMPLEMENTATION

In order to implement the comparators and RSNS-to-binary conversion on the FPGA, a LabVIEW FPGA project was created as ‘FPGA789.lvproj’. An overview of this FPGA project is shown in Figure 61.

The FPGA has a Dynamic Memory Allocation (DMA) First-In-First-Out (FIFO) buffer, which is used to transfer data from the FPGA to a host computer for this project. LabVIEW also requires the creation of an FPGA VI to run the necessary codes on the FPGA and a Host VI to communicate with the FPGA VI, which will be explained in the next two sections.
1. FPGA VI

In the FPGA VI, the three photo-detector inputs were read in using the NI-9215 Analog Input Module, sampled using the comparator circuits, and processed using the RSNS-to-binary conversion algorithm. The RSNS-to-binary output was then stored in the DMA FIFO. The number of elements in the FIFO can be set in Figure 61 by double-clicking on the FIFO icon and changing its properties. The LabVIEW schematics of the FPGA VI are shown in Figure 62.

A point to note is that the thermometer code displays were removed from the Front Panel of the VI, as it slowed down the FPGA execution speed when it was required to display any data.
The truncated DR case was used for the RSNS-to-binary conversion for this integration as the interferometers used in [5] could not create enough folds of the modulated signals to exploit the whole DR.

Figure 62. LabVIEW Schematics of FPGA VI.
2. Host Interface VI

In the Host VI, LabVIEW requires that a reference to the FPGA VI be opened before the Host VI can communicate with the FPGA VI. Thereafter, a ‘FIFO Read’ action was invoked by the Host VI to read the DMA FIFO data in the FPGA VI. The data was then saved in a text file, using the ‘Write to Measurement File’ VI. The LabVIEW schematics of the Host VI are shown in Figure 63.

![LabVIEW Schematics of Host VI](image)

Figure 63. LabVIEW Schematics of Host VI.

3. Results

After compiling and running the FPGA and Host VIs, proper alignment of the modulated signals had to be carried out to ensure that the RSNS vectors were lined up correctly to achieve accurate decoding. The DDS outputs for a 1-kHz triangular and 1-kHz sine input signal are shown in Figures 64 and 65, respectively.
Figure 64. DDS Output for a 1-kHz Triangular Input Signal.

Figure 65. DDS Output for a 1-kHz Sine Input Signal.
It is seen from Figures 64 and 65 that the DDS module was able to decode the input signals with some signal clipping and uneven step sizes in the output waveforms.

Implementations of the comparator circuit and RSNS-to-binary conversion algorithm on the FPGA to form the DDS module and DDS module integration with the front-end PES module to form the overall folding ADC architecture were carried out in this chapter. An analysis of the ADC performance characteristics is provided in the next chapter.
VII. ADC PERFORMANCE

In this chapter, a number of important parameters that describe an ADC’s performance are presented. Differential and integral linearity errors are plotted for the ADC to analyze the linearity errors. The ADC dynamic range is determined using a full-scale sinusoid and a Fourier spectrum analysis of the noise floor. Finally, the ADC dynamic performance is characterized by the Signal-to-Noise Ratio (SNR), SNR plus distortion (SINAD), Total Harmonic Distortion (THD) and the Effective Number of Bits (ENOB) parameters.

A. LINEARITY ERRORS

A comparison of the ADC 1-kHz sine input signal and the DDS output signal is shown in Figure 66, where it can be seen that the DDS output signal is able to follow the input signal, with some quantization and linearity errors.

Figure 66. Comparison of PES Input Signal and DDS Output Signal.
The characteristic transfer function of a 1-kHz triangular waveform is used to quantify the linearity errors. A plot of the ADC transfer function using a 1-kHz triangular input signal is shown in Figure 67. The quantization errors of the ADC transfer function in Figure 67 are shown in Figure 68. Quantization error is present as there is no one-to-one correspondence between the input and output voltage.

Figure 67. Photonic ADC Transfer Function using a 1-kHz Triangular Input Signal.

Figure 68. Quantization Errors.
1. ADC Resolution

The LSB size for this RSNS ADC is defined as:

$$\text{LSB}_{\text{RSNS}} = \frac{V_{fs}}{M}$$

(49)

where $\text{LSB}_{\text{RSNS}}$ is the ADC resolution, $V_{fs}$ is the full-scale voltage and $M$ is the maximum system dynamic range.

2. Differential Non-Linearity

The Differential Non-Linearity (DNL) is expressed as [10]:

$$DNL_k = (V_k - V_{k-1}) - \text{LSB}$$

(50)

where $V_k$ and $V_{k-1}$ are two consecutive code transition points, and $(V_k - V_{k-1})$ is the step-size. The DNL is the maximum deviation in the output step-size from the ideal value of one LSB.

3. Integral Non-Linearity

The Integral Non-Linearity (INL) is defined as [10]:

$$INL_j = \sum_{k=1}^{j} DNL_k = V_j - j\text{LSB}$$

(51)

where $V_j = \sum_{k=1}^{j} (V_k - V_{k-1})$ is the sum of the step-size from zero to the $j^{th}$ transition point, and $j\text{LSB}$ is the ideal value at that transition point. The INL is the maximum deviation of the input/output characteristic from a straight line passed through its end points. A good ADC typically has linearity error $\leq 0.5 \text{ LSB}$. [10]

The linearity errors (step-size, DNL and INL) of the quantized signal in Figure 67 are shown in Figure 69. The step-size plot depicts the length of input voltage
corresponding to each quantization level as the input voltage increases. It shows that the maximum step-size is 2.7 LSB, which corresponds to the code transition points with a maximum DNL value of 1.7 LSB.

A maximum INL value of 7.8 LSB is also obtained in Figure 69. The INL increases with a larger input voltage, indicating that the slope of the ADC transfer function is deviating from that of an ideal ADC transfer function at larger input voltages.

Figure 69. Linearity Parameters – Step-Size, DNL and INL.
B. NOISE FLOOR ANALYSIS

The process for computing the frequency spectrum and analyzing the ADC noise floor is illustrated in Figure 70.

This process involves passing a sinusoid input signal through the ADC. During quantization, a white noise process (quantization noise) $\gamma_k$ is added to the analog signal. The ADC noise floor is analyzed by windowing 20 sets of 4,096 digitized samples using a Blackman-Harris window, with the window samples represented by $w_k$. The Blackman-Harris window is chosen because of the low side-lobe levels it can achieve [10].

The average magnitude spectrum response is obtained by using the Discrete Fourier Transform (DFT) to transform the time-domain signals into the frequency domain and performing asynchronous point-by-point spectral averaging of the 20 sets of data.

The purpose of conducting this noise floor analysis is to determine the dominant noise sources in the ADC system, explained in the next two sections.

1. Quantization Noise

The theoretical noise floor can be evaluated by examining the SNR and considering the presence of quantization noise only. By normalizing the square of the
magnitude of the spectral average with the fundamental signal, the equation to calculate
the noise floor using a Blackman-Harris window is [10]:

\[ F_{M^2} = 10\log_{10}\left(\frac{3M}{4E_B}\right) + 6.02n \text{ [dB]} \]  

(52)

where \( n = \text{Number of ADC Bits} = \log_2 \hat{M} = \log_2 (41) = 5.26 \text{ bits}, \ E_B = \text{Equivalent Noise Bandwidth of Blackman-Harris Window} = 2.0, \text{ and } M = \text{Number of Samples} = 4096.

The theoretical noise floor is calculated as \( F_{M^2} = -64.13 \text{ dB} \) using (52). The procedure in Figure 70 is then used to obtain actual ADC noise floor measurements for comparison.

For this analysis, a 1-kHz sinusoidal signal was sampled at 100-kHz. Twenty sets of 4,096 digitized signals were acquired asynchronously and windowed using a Blackman-Harris window. The MATLAB Fast Fourier Transform (FFT) function was used to compute the signal spectrum. The point-by-point spectral average of the twenty sets of data was then calculated.

The spectral average of the 1-kHz sinusoidal signal is shown in Figure 71, using a Blackman-Harris window.

![Normalized Magnitude Squared Spectrum Using Blackman-Harris Window](image_url)

**Figure 71.** Spectral Average of a 1-kHz Sinusoidal Signal.
Since the noise floor in Figure 71 is –64.5 dB, which is close to the theoretical noise floor of –64.13 dB, other additive noise sources (such as thermal noise) are less dominant in the system compared to quantization noise.

2. Clock Jitter

Two frequencies can be used to test if clock jitter is a dominant noise source, with the higher frequency being twice that of the first frequency [10]. A 2-kHz sinusoidal signal was sampled to compare its noise floor with that obtained for the 1-kHz sinusoidal signal in Figure 71. The same process in Figure 70 was adhered to in calculating the magnitude square spectrum of both signals.

The spectral average of the 2-kHz sinusoidal signal with a noise floor of –59.5 dB, using a Blackman-Harris window, is shown in Figure 72. Since the difference between both noise floor levels is 5 dB (less than 6 dB), clock jitter is not the dominant noise source [10]. This is expected as clock jitter is not expected to be significant at these relatively low frequencies.

![Normalized Magnitude Squared Spectrum Using Blackman-Harris Window](image)

Figure 72. Spectral Average of a 2-kHz Sinusoidal Signal.
C. DYNAMIC PERFORMANCE ANALYSIS

Lastly, the ADC performance is characterized using the following dynamic performance parameters: SNR, THD, SINAD and ENOB. Two different frequencies (1-kHz and 2-kHz) were used for comparison.

1. Signal-to-Noise Ratio

The ideal SNR equation assumes only quantization noise and is expressed as [10]:

\[ SNR(dB) = 6.02n + 1.76 \]  

where \( n \) = Number of ADC Bits = \( \log_2 M = \log_2(41) = 5.36 \text{ bits.} \)

2. Total Harmonic Distortion

The THD measures the harmonics of the input signal that show up at integral multiples of the fundamental frequency, and is a measure of the ADC’s non-linearity. It is defined as [10]:

\[ THD(-dB) = 20\log\sqrt{(10^{2nd\ HAR/10})^2 + (10^{3rd\ HAR/10})^2} \ldots \]  

For the purpose of this analysis, the input signal’s first five harmonics were measured in decibels and used in (54).

3. SNR Plus Distortion

The SINAD equation takes into account all of the noise (including harmonics) to give an indication of the useful ADC dynamic range, but excludes the DC component. It is expressed as [10]:

\[ SINAD(+dB) = -20\log\sqrt{10^{-(SNR/10)} + 10^{THD/10}}. \]  

4. Effective Number of Bits

The ENOB is a measure of the usable ADC dynamic range, which is reduced due to noise. It is defined as [10]:
5. Summary of ADC Dynamic Performance Parameters

A summary of the calculated parameter values, using (53) to (56) is shown in Table 7.

Table 7. ADC Dynamic Performance Parameters.

<table>
<thead>
<tr>
<th>Frequency</th>
<th>Ideal SNR (dB)</th>
<th>SINAD (dB)</th>
<th>THD (dB)</th>
<th>ENOB (Bits)</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 kHz</td>
<td>34.22</td>
<td>34.21</td>
<td>-61.68</td>
<td>5.39</td>
</tr>
<tr>
<td>2 kHz</td>
<td>34.22</td>
<td>34.21</td>
<td>-61.01</td>
<td>5.39</td>
</tr>
</tbody>
</table>

From Table 7, it is observed that the THD for the 2-kHz signal is 0.67 dB higher than that for the 1-kHz signal. The SINAD and ENOB values are similar for both frequencies, indicating that there was insignificant signal distortion when the frequency is increased from 1-kHz to 2-kHz.

An enabler to achieving this is the design of comparator circuits in the FPGA, which has significantly reduced the distortion caused by sampling errors, as compared to using actual comparator ICs.

D. SUMMARY

In this chapter, the ADC performance was described in three ways. First, the ADC transfer function was examined for linearity errors. Second, the noise floor was analyzed to determine the main sources of noise in the system. Lastly, the dynamic performance parameters of the ADC system were characterized. Key conclusions and recommendations for future research will be provided in the next chapter.
THIS PAGE INTENTIONALLY LEFT BLANK
VIII. CONCLUSION

The key conclusions obtained from this project and recommendations for future research are provided in this chapter.

A. KEY CONCLUSIONS

The goal of this thesis was to conduct hardware and software implementation of the DDS module of the folding ADC architecture (for Moduli 7, 8, 9) from the bank of comparators to the RSNS-to-binary conversion within the FPGA as well as integration with the front-end PES module of this ADC design. This was accomplished via several milestones described below.

Firstly, the RSNS dynamic range computation algorithm in [6] and [7] was verified to be correct, proving that an eight-bit DR of 133 can be achieved theoretically for a three-channel RSNS ADC with Moduli $m_1 = 7$, $m_2 = 8$ and $m_3 = 9$.

Secondly, the RSNS-to-binary algorithm was implemented in LabVIEW and shown to achieve the DR value of 133, which is in agreement with [6] and [7], and a one-bit improvement over that achieved in [4]. Design of thermometer code generator circuits and simulation of this algorithm were carried out to verify that it is working properly before connecting to actual signals.

Thirdly, the comparator circuits and RSNS-to-binary conversion algorithm were implemented on the FPGA, allowing the ADC to achieve a higher sampling frequency.

Lastly, the DDS module was integrated with the front-end PES module in [5] to form a folding ADC system and characterization of the ADC performance was carried out. Analysis of the results attributed the dominant noise source in the ADC system to quantization noise, with the ADC remaining resilient to errors caused by other additive noise sources and comparator sampling.
This electro-optic RSNS ADC system has been demonstrated to work and produces a seven-bit output with relatively simple hardware and software. Due to the reduced number of hardware and software components and the large bandwidth of the photonics components, the energy and size savings, as well as increase in speed, make this folding ADC design appealing for defense applications, such as unmanned systems, direction-finding antenna architectures and electronic warfare system-on-a-chip applications.

B. RECOMMENDATIONS FOR FUTURE RESEARCH

While this thesis is concerned with optimizing the DDS module implementation of the folding ADC system, various system trade-offs had to be made for integration purposes. Further upgrades and research can be carried out in various aspects of the system, detailed below.

1. Bandwidth Upgrade

The bandwidth of this ADC system is currently limited by the NI-9215 Analog Input Module’s data rate of 100 kS/s. The highest frequency it can sample is 50 kHz, based on the Nyquist criteria. There are several wider-bandwidth NI modules available to replace this, such as the NI-5761 Digitizer Adapter Module, which has a data rate of 250 MS/s and can sample frequencies up to 125 MHz [11]. The only drawback is that choices of wide-bandwidth modules are limited due to lack of commercial development and require impedance-matching for maximum power transfer.

2. FPGA Upgrade

The speed of this ADC system is currently limited by the XILINX Virtex-5 LX-30 FPGA on the NI-9111 Chassis. There are several higher-capacity NI FPGA modules available to replace this, such as the FlexRIO PXIe-7965R module, which has a XILINX Virtex-5 SX-95T FPGA with a clock speed of 550 MHz and the ability to handle single-ended Input/Output (I/O) up to 800 Mbps [12]. This module did not arrive in time for the project due to procurement delay, but can be easily substituted when it is available.
There are other high-speed FPGAs (up to 1 GHz) that could not be used as they do not interface with NI LabVIEW. Nevertheless, it is envisaged that an Application-Specific Integrated Circuit (ASIC) can be developed for testing once the FPGA circuit design has been fixed. This will remove the constraint of having to rely only on the NI programming environment.

The envisaged DDS setup, after incorporating the component upgrades, is illustrated in Figure 73.

3. Higher-Moduli Configurations

The modular structure of the RSNS-to-binary converter allows the ADC system to be easily scalable to higher-moduli configurations or configurations with more than three channels. This will increase the ADC resolution and enable the ADC system to achieve a dynamic range that is better than the current eight-bit DR of 133.
The COA shift $h_{s_1}$ is the least positive solution to the following sets of congruence equations:

\[
\begin{align*}
\frac{h_{s_1} - 1}{3} & \equiv 0 \pmod{7} \quad \implies h_{s_1} \equiv 1 \pmod{21} \\
\frac{h_{s_1} - 1}{3} & \equiv 0 \pmod{8} \quad \implies h_{s_1} \equiv 1 \pmod{24} \\
\frac{h_{s_1} + 2}{3} & \equiv 0 \pmod{9} \quad \implies h_{s_1} \equiv -2 \pmod{27}
\end{align*}
\]

Equation (57) cannot be solved directly using the standardized Chinese Remainder Theorem (CRT) as the three moduli are not Pair-Wise Relatively Prime (PRP). The generalized CRT procedure must be used. The first step is to break each equation into its constituent equations [10]:

\[
\begin{align*}
h_{s_1} &\equiv 1 \pmod{21} \quad \left\{ 
\begin{array}{l}
h_{s_1} \equiv 1 \pmod{7} \\
h_{s_1} \equiv 1 \pmod{3}
\end{array} \right. \\
h_{s_1} &\equiv 1 \pmod{24} \quad \left\{ 
\begin{array}{l}
h_{s_1} \equiv 1 \pmod{8} \\
h_{s_1} \equiv 1 \pmod{3}
\end{array} \right. \\
&\equiv -2 \pmod{27} \quad \left\{ 
\begin{array}{l}
h_{s_1} \equiv -2 \pmod{3} \\
h_{s_1} \equiv -2 \pmod{3} \\
h_{s_1} \equiv -2 \pmod{3}
\end{array} \right.
\]
\]

The second step is to group all constituent equations with the same moduli together, and solve for the remaining congruence equations using the standardized CRT method:

\[
\begin{align*}
h_{s_1} &\equiv 1 \pmod{7} \\
h_{s_1} &\equiv 1 \pmod{8} \\
h_{s_1} &\equiv -2 \pmod{3}
\end{align*}
\]
The standardized CRT solution is:

$$h_{x1} = \sum_{i=1}^{N} \frac{M}{m_i} b_i a_i$$

where

$$M = \prod m_i = (7)(8)(3) = 168$$

$$m_i = \text{Moduli } i = [m_1, m_2, m_3] = [7, 8, 3]$$

$$a_i = \text{Residue of Moduli } i = [a_1, a_2, a_3] = [1, 1, -2]$$

The coefficients $b_i$ can be found via the following procedure:

Find $b_1 : \left(\frac{M}{m_1}, m_1\right) = \left(\frac{168}{7}, 7\right) = (24, 7)$

$$24(1) + 7(0) = 24$$
$$24(0) + 7(1) = 7 \quad \{ \frac{24}{7} \} = 3$$

$$24 \left[ (1) - (0) \left(\frac{24}{7}\right) \right] + 7 \left[ (0) - (1) \left(\frac{24}{7}\right) \right] = 24(1) + 7(-3) = 3 \quad \{ \frac{7}{3} \} = 2$$

$$24 \left[ (0) - (1) \left(\frac{7}{3}\right) \right] + 7 \left[ (1) - (-3) \left(\frac{7}{3}\right) \right] = 24(-2) + 7(7) = 1 \quad \therefore b_1 = -2$$

Find $b_2 : \left(\frac{M}{m_2}, m_2\right) = \left(\frac{168}{8}, 8\right) = (21, 8)$

$$21(1) + 8(0) = 21$$
$$21(0) + 8(1) = 8 \quad \{ \frac{21}{8} \} = 2$$

$$21 \left[ (1) - (0) \left(\frac{21}{8}\right) \right] + 8 \left[ (0) - (1) \left(\frac{21}{8}\right) \right] = 21(1) + 8(-2) = 5 \quad \{ \frac{8}{5} \} = 1$$

$$21 \left[ (0) - (1) \left(\frac{8}{5}\right) \right] + 8 \left[ (1) - (-2) \left(\frac{8}{5}\right) \right] = 21(-1) + 8(3) = 3 \quad \{ \frac{5}{3} \} = 1$$

$$21 \left[ (1) - (-1) \left(\frac{5}{3}\right) \right] + 8 \left[ (-2) - (3) \left(\frac{5}{3}\right) \right] = 21(2) + 8(-5) = 2 \quad \{ \frac{3}{2} \} = 1$$

$$21 \left[ (-1) - (2) \left(\frac{3}{2}\right) \right] + 8 \left[ (3) - (-5) \left(\frac{3}{2}\right) \right] = 21(-3) + 8(8) = 1 \quad \therefore b_2 = -3$$
Find $b_3 \colon \left(\frac{M}{m_3}, m_3\right) = \left(\frac{168}{3}, 3\right) = (56, 3)$

\[
\begin{align*}
56(1) + 3(0) &= 56 \\
56(0) + 3(1) &= 3
\end{align*}
\]

\[
\begin{align*}
56 \left(1 - (0) \left[\frac{56}{3}\right]\right) + 3 \left(0 - (1) \left[\frac{56}{3}\right]\right) &= 56(1) + 3(-18) = 2 \\
56 \left(0 - (1) \left[\frac{3}{2}\right]\right) + 3 \left(1 - (-18) \left[\frac{3}{2}\right]\right) &= 56(-1) + 3(19) = 1
\end{align*}
\]

\[
\therefore b_3 = -1
\]

\[
h_{s_1} = \left(\frac{M}{m_1}b_1a_1 + \frac{M}{m_2}b_2a_2 + \frac{M}{m_3}b_3a_3\right) \mod M
\]

\[
\therefore h_{s_1} = \left[24(-2)(1) + 21(-3)(1) + 56(-1)(-2)\right] \mod 168 = 1 \mod 168
\]

Similarly, the COA shift $h_{s_2}$ is the least positive solution to the following sets of congruence equations:

\[
\frac{h_{s_2} - 2}{3} \equiv 0 \mod 7 \quad \rightarrow \quad h_{s_2} \equiv 2 \mod 21
\]

\[
\frac{h_{s_2} + 1}{3} \equiv 0 \mod 8 \quad \rightarrow \quad h_{s_2} \equiv -1 \mod 24
\]

\[
\frac{h_{s_2} + 1}{3} \equiv 0 \mod 9 \quad \rightarrow \quad h_{s_2} \equiv -1 \mod 27
\]

Equation (61) cannot be solved directly using the standardized CRT as the three moduli are not PRP. The generalized CRT procedure must be used. Again, the first step is to break each equation into its constituent equations [10]:
The second step is to group all constituent equations with the same moduli together and solve for the remaining congruence equations using the standardized CRT method:

\[ h_{s2} \equiv 2 \pmod{7} \]
\[ h_{s2} \equiv -1 \pmod{8} \]
\[ h_{s2} \equiv -1 \pmod{3} \]  \hspace{1cm} (62)

\[ h_{s2} \equiv -1 \pmod{24} \]
\[ h_{s2} \equiv -1 \pmod{8} \]
\[ h_{s2} \equiv -1 \pmod{3} \]  \hspace{1cm} (63)

\[ h_{s2} \equiv -1 \pmod{27} \]
\[ h_{s2} \equiv -1 \pmod{3} \]
\[ h_{s2} \equiv -1 \pmod{3} \]

The standardized CRT solution is:

\[ h_{s2} = \sum_{i=1}^{N} \frac{M}{m_i} b_i a_i \]

where \( M = \prod m_i = (7)(8)(3) = 168 \)
\( m_i = \text{Moduli}\ i = [m_1, m_2, m_3] = [7, 8, 3] \)
\( a_i = \text{Residue of Moduli}\ i = [a_1, a_2, a_3] = [2, -1, -1] \)  \hspace{1cm} (64)

The coefficients \( b_i \) are the same as for \( h_{s1} \), as the moduli configuration is the same for both COA shifts:

\[ h_{s2} = \left( \frac{M}{m_1} b_1 a_1 + \frac{M}{m_2} b_2 a_2 + \frac{M}{m_3} b_3 a_3 \right) \pmod{M} \]  \hspace{1cm} (65)

\[ \therefore h_{s2} = [24(-2)(2) + 21(-3)(-1) + 56(-1)(-1)] \pmod{168} = 23 \pmod{168} \]
LIST OF REFERENCES


INITIAL DISTRIBUTION LIST

1. Defense Technical Information Center  
   Fort Belvoir, Virginia

2. Dudley Knox Library  
   Naval Postgraduate School  
   Monterey, California

3. Chairman, Code ECE  
   Naval Postgraduate School  
   Monterey, California

4. Professor Phillip Pace  
   Naval Postgraduate School  
   Monterey, California

5. Professor David Jenn  
   Naval Postgraduate School  
   Monterey, California

6. Dr. James Calusdian  
   Naval Postgraduate School  
   Monterey, California

7. Professor Tat Soon Yeo  
   Temasek Defence Systems Institute  
   Singapore

8. Miss Lai Poh Tan  
   Temasek Defence Systems Institute  
   Singapore