University of Rome "La Sapienza"



## School of Engineering Graduate Course in Telecommunications INFOCOM Department

Degree Thesis of Second Level about Ultra Wide Band and Optical Communication Systems Academic Year 2004/2005

# **CONVERGENCE BETWEEN ULTRA WIDE BAND** AND OPTICAL COMMUNICATION SYSTEMS

Tutors: **Prof. Rafael Pérez Jiménez Prof. Maria-Gabriella Di Benedetto** Cotutor: **Eng. Santiago T. Pérez Suárez** 

Author: **Eugenio Manlio Ducci** Reg. N. 794700

La palabra progreso no tiene ningún sentido mientras haya niños infelices Albert Einstein

A mi padre

Por su inestimable apoyo, su generosa sabiduría y su persistente espíritu de amistad, que serán por mí unas huellas permanentes que indican la justa dirección

A mi madre

Por su fuerza de ánimo, su riqueza espiritual y su bondad, que se quedarán para siempre en mi mundo interior

A mis hermanos Que el camino que elegí hasta ahora pueda ser para ellos un buen ejemplo para su vida futura

Agradecimientos

Antes que nada mi gratitud se dirige hacia mi tutora Maria-Grabriella que me ha permitido comenzar y seguir serenamente esta maravillosa experiencia en un lugar en el cual la naturaleza ha sido tan generosa.

En segundo lugar, nunca podría haber ni planeado ni desarrollado el siguiente trabajo sin el amable soporte de Santiago acerca de mi inglés, mi español y mi proyecto; sin la sabiduría y cultura ecléctica de Rafael, que me han consentido en cada paso dirigirme hacia las soluciones más eficientes y originales; sin la preparación técnica y la cordialidad de José; sin el apoyo de Arthemy y Rufo, siempre buenos compañeros; y más que nada sin Ayaya, cuyas ayudas, consejos y charlas me han acompañado día tras día a través del camino de este proyecto.

En tercer lugar, quisiera dar las gracias a aquellos que formaron mi familia durante estos meses, compartiendo conmigo felicidades y tristezas: Davinia "Mariposa", Cristina "Chiuri", Espe "Ranza", Juan Luis "el Campesino", Miguel "el Diablo", Andrea, Simone, Reinhard, el "Compare" Fulvio, Sandra "Saxilo", Manu "Chao" y Daiana la cual, con cada gesto de amor desinteresado, me recuerda sin quererlo que nunca conocí una persona capaz de dar tanto amor. Ellos fueron mi familia, la familia Arehucas, y gracias a ellos pude añadir, a mi ya rica experencia profesional, aquella interior, sin duda la que más me formó como hombre y que yacerá indeleblemente en mi corazón de cara al futuro.

Por último no podría jamás despedirme sin agradecer, por su constante apoyo, a quienes son mis amigos de siempre: Ignazio y Ettore.

Eugenio Manlio Ducci

9 de Abril de 2006

# Index

| CHAPTER 1 INTRODUCTION                          | 1  |
|-------------------------------------------------|----|
| 1.1. Motivations underlying the work            | 2  |
| 1.2. Purposes                                   | 2  |
| 1.3. Description of the work                    |    |
| 1.4. Material means and tools used              | 3  |
| CHAPTER 2 THE OPTICAL COMMUNICATION SYSTEM      | 5  |
| 2.1. Introduction to the optical communications | 6  |
| 2.2. The electrical driver                      | 6  |
| 2.3. The optical emitter                        | 6  |
| 2.4. The lenses                                 | 10 |
| 2.5. The channel                                |    |
| 2.5.1. The optical fiber                        | 10 |
| 2.5.2. The wireless channel                     | 14 |
| 2.6. Noise and interference                     | 19 |
| 2.7. Lenses and interferometer optical filter   |    |
| 2.8. The photodiode                             | 24 |
| 2.9. The electrical processing                  |    |
| 2.10. Appendix: the solitons                    |    |
| CHAPTER 3 MODULATION AND CODING SCHEMES         | 29 |
| 3.1. Introduction                               |    |
| 3.2. Spread spectrum techniques                 |    |
| 3.2.1. Direct Sequence Spread Spectrum          |    |
| 3.2.2. Time Hopping Spread Spectrum             |    |
| 3.3. On Off Keying modulation                   |    |
| 3.4. Pulse Position Modulation                  |    |

| CHAPTER 4 THE ULTRA WIDE BAND COMMUNICATION SYSTEM                        | 45   |
|---------------------------------------------------------------------------|------|
| 4.1. Introduction                                                         | 46   |
| 4.2. Definition of UWB signal and its generation                          | 48   |
| 4.2.1. Generation of TH-PPM-UWB signals and their PSD                     | 49   |
| 4.2.2. Generation of TH-PAM-UWB signals and their PSD                     | 53   |
| 4.2.3. Generation of MB-UWB signals and their PSD                         | 55   |
| 4.3. Pulse shaping in UWB systems                                         | 56   |
| CHAPTER 5 WIRELESS ACCESS CONTROL PROTOCOLS                               | 59   |
| 5.1. Introduction                                                         | 60   |
| 5.2. Random access protocols                                              | 62   |
| 5.2.1. Aloha                                                              | 63   |
| 5.2.2. CSMA                                                               | 66   |
| 5.2.3. In-Band CA: MACA                                                   | 69   |
| 5.2.4. Out-Of-Band CA: BTMA                                               | 70   |
| 5.3. Scheduled protocols and hybrid protocols                             | 73   |
| 5.4. Examples of standardized MAC protocols                               | 74   |
| 5.4.1. MAC protocol for 802.11 standard: DFWMAC                           | 74   |
| 5.4.2. MAC protocol for IrDA standard: IrLAP                              | 79   |
| 5.4.3. UWB systems: MAC protocols for the standards 802.15.3 and 802.15.4 | ! 83 |
| 5.4.4. The (UWB) <sup>2</sup> MAC protocol                                | 85   |

| 6.1 Introduction                        | 94  |
|-----------------------------------------|-----|
| 6.2. Optical transmitter                |     |
| 6.3. Optical receiver                   | 102 |
| 6.4. Optical terminal                   | 105 |
| 6.5. Optical system                     | 106 |
| 6.6. Masters, slaves and relative EPLDs | 108 |

| CHAPTER 7 IMPLEMENTATION OF (UWB) <sup>2</sup> OVER AN OPTICAL SYS <sup>7</sup><br>RESULTS | ГЕМ:<br>117 |
|--------------------------------------------------------------------------------------------|-------------|
| 7.1. Introduction                                                                          |             |
| 7.2. (UWB) <sup>2</sup> : software implementation                                          |             |
| 7.3. Optical System: hardware implementation                                               | 134         |
| CHAPTER 8 BIBLIOGRAPHY AND WEB PAGES                                                       | 141         |
| 8.1. Bibliography                                                                          | 142         |
| 8.2. Web Pages                                                                             | 145         |
| ANNEX I. SCHEMATICS AND PCBS                                                               | 147         |
| AI.1. Schematic of the optical transmitter                                                 | 149         |
| AI.2. Schematic of the optical receiver                                                    | 151         |
| AI.3. Schematic of the optical terminal                                                    | 153         |
| AI.4. Schematic of the EPLD relative to the master number one                              | 155         |
| AI.5. Schematic of the EPLD relative to the master number two                              | 157         |
| AI.6. Schematic of the EPLD relative to the slave number one                               | 159         |
| AI.7. Schematic of the EPLD relative to the slave number two                               | 161         |
| AI.8. Schematic of the EPLDs of the optical system                                         |             |
| AI.9. PCB of the optical transmitter                                                       | 165         |
| AI.10. PCB of the optical receiver                                                         | 169         |
| AI.11. PCB of the optical terminal                                                         | 173         |
| AI.12. PCB of the optical system                                                           | 177         |
| AI.13. PCB of the EPLDs of the optical system                                              |             |
| AI.14. Schematic of the drive logic of the master number 1 and number 2                    |             |
| AI.15. Schematic of the drive logic of the slave number 1 and number 2                     |             |
| AI.16. Schematic of the 4 taps shift register                                              |             |
| AI.17. Schematic of the 16 taps shift register                                             |             |
| AI.18. Schematic of the Pseudo Random Number Generator                                     |             |
| AI.19. Schematic of the optical system used in the software simulation                     | 199         |

| ANNEX II. COMPONENTS'S SPECIFICATIONS                                  | 201 |
|------------------------------------------------------------------------|-----|
| AII.1. Technical specifications of the quad 2-input AND gate CD74AC08  | 202 |
| AII.2. Technical specifications of the Infrared LED L7558 series       | 203 |
| AII.3. Technical specifications of the Si PIN photodiode S6468 series  | 205 |
| AII.4. Technical specifications of the Amplifier MAX410                | 207 |
| AII.5. Technical specifications of the Differential Comparator LM360   | 222 |
| AII.6. Technical specification of the 5.0V TTL Clock Oscillator F1100E | 230 |
| AII.7. Altera MAX 9000 programmable logic device family data sheet     | 231 |
| AII.8. Altera device package information for EPM9320ALC84-10           | 239 |
|                                                                        |     |

| ANNEX III. VHDL CODE                                                  | 243 |
|-----------------------------------------------------------------------|-----|
| AIII.1. Masters: VHDL code of the block "Recognize Header"            | 244 |
| AIII.2. Masters: VHDL code of the block "Buffer"                      | 247 |
| AIII.3. Masters: VHDL code of the block "Parallel Serial Converter"   | 250 |
| AIII.4. Masters: VHDL code of the block "Multiplexer"                 | 253 |
| AIII.5. Masters: VHDL code of the block "Compare Header"              | 254 |
| AIII.6. Masters: VHDL code of the block "Vector to Integer Converter" | 255 |
| AIII.7. Slaves: VHDL code of the block "Recognize Header "            | 256 |
| AIII.8. Slaves: VHDL code of the block "Buffer"                       | 259 |
| AIII.9. Slaves: VHDL code of the block "Parallel Serial Converter"    | 261 |
| AIII.10. Slaves: VHDL code of the block "Multiplexer"                 | 263 |
| AIII.11. Slaves: VHDL code of the block "Compare Header"              |     |
| AIII.12. Slaves: VHDL code of the block "Compare Payload"             | 265 |
|                                                                       |     |

| ANNEX IV. ACRONYMS | 267 |
|--------------------|-----|
| AIV.1. Acronyms    | 268 |

# Figures

| Figure 2.1: Block Diagram of an Optical Communication System                           | 6  |
|----------------------------------------------------------------------------------------|----|
| Figure 2.2: Effect of the temperature changing on the LED linearity                    | 7  |
| Figure 2.3: Effect of the temperature changing on the optical spectra                  | 7  |
| Figure 2.4: Spontaneous emission                                                       | 8  |
| Figure 2.5: Stimulated emission                                                        | 8  |
| Figure 2.6: Effect of the current threshold                                            | 9  |
| Figure 2.7: Effect of the temperature on the input-output curve                        | 9  |
| Figure 2.8: The lens are used to focus the emitted beam on a reduced area, just like a |    |
| fiber's core                                                                           | 10 |
| Figure 2.9: Typical aspect of an optical fiber                                         | 11 |
| Figure 2.10: Multiple reflections at core-cladding separation interface                | 11 |
| Figure 2.11: Attenuation as function of the frequency                                  | 12 |
| Figure 2.12: Effect of the intermodal dispersion                                       | 12 |
| Figure 2.13: Curves of several chromatic dispersion parameters                         | 13 |
| Figure 2.14: Two rays model                                                            | 15 |
| Figure 2.15: Blade of knife model                                                      | 16 |
| Figure 2.16: Indoor application scenarios                                              | 17 |
| Figure 2.17: Outdoor application scenarios (MAN UOWC)                                  | 18 |
| Figure 2.18: Spectrum of the noise optical sources                                     | 19 |
| Figure 2.19: Solar Spectral Irradiance through the atmosphere                          | 20 |
| Figure 2.20: Typical electrical spectrum of a 60 W, 50 Hz tungsten-filament            | 21 |
| Figure 2.21: Power spectral density of shot noise of a fluorescent lamp                | 22 |
| Figure 2.22: Example of performance obtained with several modulation techniques        | 23 |
| Figure 2.23: Example of multipath effect inside the lenses                             | 23 |
| Figure 2.24: WDM access's scheme                                                       | 24 |
| Figure 2.25: Absorption of a photon                                                    | 25 |
| Figure 2.26: Effect of the temperature increasing on the dark current                  | 25 |

| 30         |
|------------|
| 31         |
| 32         |
| 32         |
| 33         |
| 35         |
|            |
| 36         |
| 37         |
| 38         |
| 39         |
| 40         |
| 41         |
| 41         |
| 42         |
| 43         |
| 3333334444 |

| Figure 4.1: FCC indoor and outdoor emission masks                                            | 46  |
|----------------------------------------------------------------------------------------------|-----|
| Figure 4.2: Energy spectrum of a modulated signal                                            | 48  |
| Figure 4.3: Rectangular modulated signals and their spectrum                                 | 48  |
| Figure 4.4: Block scheme for a TH-PPM-UWB transmission system                                | 49  |
| Figure 4.5: Example of a 2PPM-TH-UWB emitted signal                                          | 50  |
| Figure 4.6: Graphical representation of a 2PPM-TH-UWB signal with $N_s = N_p = 3 \dots$      | 51  |
| Figure 4.7: Effect of increasing $N_s = N_p$ on a 2PPM-TH-UWB signal                         | 52  |
| Figure 4.8: Block scheme for a DS-PAM-UWB transmission system                                | 53  |
| Figure 4.9: Example of a 2PAM-DS-UWB emitted signal                                          | 54  |
| Figure 4.10: Effect of increasing $N_p$ , maintaining constant $N_s$ , on a 2PAM-DS-UWB sign | ıal |
|                                                                                              | 55  |
| Figure 4.11: PSD of an MB-OFDM-UWB signal                                                    | 56  |
| Figure 4.12: Effect of changing the shaper factor of the gaussian pulse                      | 57  |
| Figure 4.13: Effect on the peak frequency of modifying the differentiation order             | 57  |
| Figure 4.14: Effect on the PSD of modifying the differentiation order                        | 58  |

| Figure 5.1: ISO/OSI stack model for a data network                                 | 60   |
|------------------------------------------------------------------------------------|------|
| Figure 5.2: Wireless MAC protocols                                                 | 61   |
| Figure 5.3: Examples of possible scenarios for transmitting of packets             | 63   |
| Figure 5.4: Unslotted Aloha and ideal MAC throughputs                              | 63   |
| Figure 5.5: Example of scenario in the Aloha slotted protocol                      | 64   |
| Figure 5.6: Slotted Aloha, unslotted Aloha and ideal MAC throughputs               | 64   |
| Figure 5.7: Unslotted Aloha, Unslotted Aloha with capture effect and ideal MAC     | 65   |
| Figure 5.8: Typical cause of collision for CSMA protocol                           | 66   |
| Figure 5.9: Comparison between the throughputs seen until now                      | 67   |
| Figure 5.10: Example of scenario relative to the hidden terminal phenomena         | 68   |
| Figure 5.11: An other hidden terminal scenario potentially subjected to collision  | 68   |
| Figure 5.12: Example of scenario for the exposed terminal issue                    | 69   |
| Figure 5.13: Steps in the scenario considered for the handshaking                  | 69   |
| Figure 5.14: Example of centralized architecture using BTMA protocol               | 71   |
| Figure 5.15: Example of the amplification of the exposed terminal problem          | 72   |
| Figure 5.16: Main characteristics of 802.11 wireless LAN standard                  | 74   |
| Figure 5.17: Example of a 2-way handshaking in the DFWMAC                          | 76   |
| Figure 5.18: Example of a 4-way handshaking in the DFWMAC                          | 77   |
| Figure 5.19: Rates available in the IrDA physical layer evolution                  | 79   |
| Figure 5.20: The IrDA architecture                                                 | 80   |
| Figure 5.21: IrLAP logical flow between nonoperational and operational mode        | 80   |
| Figure 5.22: The discovery procedure in IrDA                                       | 81   |
| Figure 5.23: Connection establishment                                              | 82   |
| Figure 5.24: Superframe used by PNC for the piconet global timing in 802.15.3 MAC. | 84   |
| Figure 5.25: Superframe used by a PAN Coordinator in 802.15.4 MAC (beacon mode)    | ) 85 |
| Figure 5.26: Structure of the LE PDU in (UWB) <sup>2</sup>                         | 87   |
| Figure 5.27: Structure of the DATA PDU in (UWB) <sup>2</sup>                       | 87   |
| Figure 5.28: Flow chart of the transmission procedure in (UWB) <sup>2</sup>        | 89   |
| Figure 5.29: Structure of the LC PDU in (UWB) <sup>2</sup>                         | 90   |
| Figure 5.30: Structure of the ACK PDU in (UWB) <sup>2</sup>                        | 91   |
| Figure 5.31: Flow chart of the reception procedure in (UWB) <sup>2</sup>           | 92   |

| Figure 6.1: Circuital scheme of the optical transmitter                                  | 95    |
|------------------------------------------------------------------------------------------|-------|
| Figure 6.2: Some input-output characteristics of the LED L7558 useful to design the      |       |
| physical layer of the optical system                                                     | 96    |
| Figure 6.3: Physical appearance of the optical transmitter                               | 97    |
| Figure 6.4: Outputs of the AND Port CD74AC08 used for the LED array                      | 98    |
| Figure 6.5: Circuital scheme of the optical transmitter using the array of two LEDs      | 98    |
| Figure 6.6: Physical aspect of the optical transmitter using the array of LEDs           | 99    |
| Figure 6.7: Output of the AND gate CD74AC08                                              | 99    |
| Figure 6.8: Output of the circuit of pre-emphasis                                        | . 100 |
| Figure 6.9: Block scheme of the physical optical system                                  | . 101 |
| Figure 6.10: Hardware implementation of the block scheme represented in the Figure       | 6.9   |
|                                                                                          | . 101 |
| Figure 6.11: Circuital scheme of the optical receiver                                    | . 102 |
| Figure 6.12: Appearance of the optical receiver                                          | . 103 |
| Figure 6.13: Input to the amplifier                                                      | . 103 |
| Figure 6.14: Output of the amplifier                                                     | . 104 |
| Figure 6.15: Output of the comparator                                                    | . 104 |
| Figure 6.16: Circuital scheme of the optical terminal                                    | . 105 |
| Figure 6.17: Physical aspect of the optical terminal                                     | . 106 |
| Figure 6.18: Physical aspect of the optical system                                       | . 107 |
| Figure 6.19: Graphical representation of the connections of the pins for the masters     | . 111 |
| Figure 6.20: Graphical representation of the connections of the pins for the slaves      | . 112 |
| Figure 6.21: Schematic of the EPLD related to the master #1                              | . 114 |
| Figure 6.22: Schematic of the EPLD related to the slave #1                               | . 115 |
| Figure 7.1: Throughputs Obtained Simulating the UWB <sup>2</sup> Protocol                | . 121 |
| Figure 7.2: LE and LC packets relative to both the pairs of terminals and obtained thr   | ough  |
| the Max+Plus simulator                                                                   | . 122 |
| Figure 7.3: DATA and ACK packets relative to both the pairs of terminals                 | . 123 |
| Figure 7.4: Example of exchange of the packets defined by the $(UWB)^2$ protocol for the | е     |
| couple of terminal master #2 - slave #2                                                  | . 125 |
| Figure 7.5: Example of sequential transmissions without errors                           | . 126 |

| Figure 7.7: Another example of packet collision between a DATA packet and a LE pack        | et  |
|--------------------------------------------------------------------------------------------|-----|
|                                                                                            | 130 |
| Figure 7.8: An interesting example of packet collision                                     | 132 |
| Figure 7.9: An example of a set of sequential transmissions and receptions                 | 133 |
| Figure 7.10: Operative context of work in the laboratory                                   | 134 |
| Figure 7.11: A visual particularity of the Figure 7.10                                     | 135 |
| Figure 7.12: An other visual particularity of the Figure 7.10                              | 135 |
| Figure 7.13: Signals obtained at the output of the terminals in absence of interference.   | 136 |
| Figure 7.14: A first situation in which the terminals begin to be affected by interference | 137 |
| Figure 7.15: A second situation in which the interference begins to be noticeable          | 138 |
| Figure 7.16: A third situation in which the interference affects strongly each terminal    | 138 |
| Figure 7.17: A fourth situation in which the interference affects strongly each terminal   | 139 |

# Tables

| Table 2.1: Coefficient of attenuation at several and typical wavelength                   |     |
|-------------------------------------------------------------------------------------------|-----|
| Table 2.2: General characteristics of IR and RF channel                                   | 14  |
| Table 2.3: Parameter $\gamma$ as function of the building structure                       |     |
| Table 2.4: Effect of optical filtering in the d.c. photocurrent                           |     |
|                                                                                           |     |
| Table 3.1: Truth table for the $\overline{XOR}$ multiplication                            |     |
|                                                                                           |     |
| Table 5.1: Main characteristics for the IrDA LAN standard                                 |     |
| Table 6.1: Roles of the terminals involved in the simulations                             | 106 |
| Table 6.2: Values chosen for some fixed fields defined by the (UWB) <sup>2</sup> protocol | 110 |
| Table 6.3: Main features of the EPLDs belonging to the family MAX 9320                    |     |
| Table 6.4: User pins employed in to the EPLDs of the masters                              |     |
| Table 6.5: User pins employed in to the EPLDs of the slaves                               |     |
|                                                                                           |     |

Table 7.1: Throughputs obtained by the software simulation of the (UWB)<sup>2</sup> protocol .... 120

# **Chapter 1**

# Introduction

Contents

| 1.1 M  | otivations underlying the work | 2 |
|--------|--------------------------------|---|
| 1.2 Pu | irposes                        | 2 |
| 1.3 De | escription of the work         | 3 |
| 1.4 Ma | aterial means and tools used   | 3 |

### **1.1. Motivations underlying the work**

Nowadays, as never, it is becoming necessary to develop technological systems that satisfy the requirements of the more various operative contests. This is evident giving a look to the deep changes that technological devices like notebook, PCs, PDAs, mobiles, cameras, storage devices, etc., have brought and are bringing in the common life. At first coming out, they do not represent a necessity, but with the daily use one can experience the utility, the comfort, of those commodities. In this case it can be created a collective demand regarding improvements, modifies and even new features of those devices. We could affirm that sometimes the technology creates itself and, obviously, it will have to conform its characteristics according to the heterogeneous requests of the market. Among those we can cite the necessity to transmit using high or low bit rate, to get directional or diffused transmission systems, to cope efficiently to the interference generated either by other pre-existing systems or by other devices using the same technology, to manage an access more or less regulated, to allow scalability and interoperability among different systems, etc. In order to get the previous "system specifications" often, and quite obviously, a join between several existent technological solutions are employed. We could call them "hybrid solutions". Just for giving an example, we can mention that the IrDA standard, even if having its MAC protocol, can employ optionally the RTS/CTS mechanism, used as main access strategy by the 802.11 standard.

### 1.2. Purposes

Following the "hybrid solutions" philosophy presented at the end of the previous paragraph, the present investigation work wants to analyze the behaviour, the efficiency and the characteristics of adaptability of the (UWB)<sup>2</sup> MAC protocol when it is implemented over an optical system. The (UWB)<sup>2</sup> MAC protocol, based on the Aloha access strategy and described in (Di Benedetto et al., 2004), has been developed for working over UWB systems, those relating to the 802.15.4 standard, characterized by low bit rate over medium-long range.

What we want to develop is an Optical Communication System (OCS) formed by four terminals. As to the physical layer, each terminal can both transmit, and receive; hence, at least as regards this layer, differences between them do not exist. At the MAC layer, two terminals are masters of the communication, and the remaining two are slaves.

This choice was a hardware constraint related to the restricted resources of the EPLDs. The terminals transmit to a given data rates, using an OOK modulation. The presence of the interference between the slaves is ensured through the use in the masters of an array of two LEDs.

#### **1.3. Description of the work**

First of all, it has been undertaken the research of the documentation that could provide the necessary theoretical groundwork over which to develop the work. This study concerned both the Ultra Wide Band technology and the Optical Communication Systems. As regards the UWB systems, the interest of the writer has been directed both to the high bit rate over short range case and to the low bit rate over medium to long range version, whose respective standards are 802.15.3 and 802.15.4. Secondly, a study and analysis of the MAC protocol (UWB)<sup>2</sup> has been undertaken. Finally, as to the optical systems, the attention has been focused on the IrDA standard and on its successive versions.

As second step, it has been developed, using the software *Protel* for electronic design, the physical part of the optical transmission system, taking into account that  $(UWB)^2$  is a MAC protocol developed for the low bit rate over medium to long range case and that therefore the data rate of the system could be set to 32 Kbps.

Subsequently, using the software application Max+Plus II,  $(UWB)^2$  has been implemented and simulated in the calculator, ready to be transferred into the EPLDs.

Finally, the optical system has been built up.

### 1.4. Material means and tools used

As regards the software, the following applications were used:

- Microsoft Office Word 2003, Microsoft Office PowerPoint 2003 and Microsoft Office Excel 2003
- > Adobe Photoshop CS
- Adobe Acrobat 7.0 Professional
- ➤ Matlab 7.0
- ➢ Protel 99 SE
- ➤ Max+Plus II

As to the hardware employed for the project, it has been made use of:

- > Notebook
- Power supplies
- Signal generators
- Analogic oscilloscopes
- Digital oscilloscopes
- Spectrum analyzers
- Electronic components and tools as: integrated circuits, LEDs, photodiodes, EPLDs, resistances, capacitors, welders, cables, screwdrivers, etc.
- Digital Camera

# Chapter 2

# **The Optical Communication System**

### Contents

| 2.1  | Introduction to the optical communications | 6  |
|------|--------------------------------------------|----|
| 2.2  | The electrical driver                      | 6  |
| 2.3  | The optical emitter                        | 6  |
| 2.4  | The lenses                                 | 10 |
| 2.5  | The channel                                | 10 |
|      | 2.5.1 The optical fiber                    | 10 |
|      | 2.5.2 The wireless channel                 | 14 |
| 2.6  | Noise and interference                     | 19 |
| 2.7  | Lenses and interferometer optical filter   | 23 |
| 2.8  | The photodiode                             | 24 |
| 2.9  | The electrical processing                  | 27 |
| 2.10 | Appendix: the solitons                     | 28 |

## 2.1. Introduction to the optical communications

The physical layer of the system in analysis is represented by an *OCS* (*Optical Communication System*) whose block diagram is represented in the following figure:



Figure 2.1: Block Diagram of an Optical Communication System

In the continue of this chapter, we will give a description, with some detail, of each component that composes the above diagram.

## 2.2. The electrical driver

The Electrical driver is necessary to provide the following function:

- To feed the optical emitter by the needed current
- To adapts the input signal as to power, modulation, etc
- Since the optical emitters are susceptible to temperature changes, it is needed a thermal control in order to keep constant the emitted optical power

## 2.3. The optical emitter

Nowadays two important classes of emitter are used: *LEDs* and *Laser Diodes*. The main characteristics of a LED are:

 $\setminus$ 

- Typically, it is characterized by low cost
- The input-output curve is temperature dependent being anyhow more robust to the external conditions than laser diodes



Figure 2.2: Effect of the temperature changing on the LED linearity

- With reference to the electrical driver, it is electrically simple to use and control
- Depending on the emitting window, the available transmission rates reach several hundred of MHz
- It produces scattered incoherent light
- It needs subsequent lens in order to shore up directive the Led beam
- Its use is restricted to large core fibers
- Broad spectral width, which is temperature dependent, generates material dispersion



Figure 2.3: Effect of the temperature changing on the optical spectra

As regards the laser diode, its major characteristics are:

• It is based on spontaneous and stimulated emission



Figure 2.4: Spontaneous emission



Figure 2.5: Stimulated emission

• The laser presents a current threshold below of which dominates the spontaneous emission



Figure 2.6: Effect of the current threshold

- Typically, it is characterized by high cost
- The available transmission rates arrive up to tens of GHz
- It produces coherent light (in phase, frequency and direction)
- It allows obtaining high optical power output
- Because of its dependence from external changes (as temperature), it requires more complex control than a LED



 $I_t(T_2) = I_t(T_1) \exp[(T_2 - T_1)/T_0]$ where  $T_0 = 150 \ ^oK$ 



## 2.4. The lenses

In order to match as better as possible the emitter with the channel (typically, as we will show, fibers or wireless channel), lenses are interposed between the optical emitter and the channel.



Figure 2.8: The lens are used to focus the emitted beam on a reduced area, just like a fiber's core

Though using lenses, we experiment three sources of loss:

- Since the emitter must be positioned at the focal distance, if some imprecision on its spatial position occurs, some rays are not concentrated and may be lost
- Because of the imperfections of the lenses, some ray may be sent backwards
- The material composing the lenses, constitutes itself a first attenuation in the rays path

## 2.5. The channel

As mentioned before, the channels that we are going to consider in the prosecution will be wireless channels and fibers.

### 2.5.1. The optical fiber

A fiber is composed by an internal core, an external cladding and a covering that preserves the integrity of the device from the external environment.



Figure 2.9: Typical aspect of an optical fiber

As known, the basic functioning principle of a fiber is to guide the luminous rays in the core by multiple reflections on the cladding internal surface that works as a mirror. In order to achieve total reflection, as application of the Snell law

$$n_1 \sin \theta_1 = n_2 \sin \theta_2,$$

we have to use a core with a reflection index  $n_1 > n_2$ . In this way we may define the *critical angle* as

$$\theta_c = \arcsin(n_2/n_1)$$

over which occurs total reflection between core and cladding.



Figure 2.10: Multiple reflections at core-cladding separation interface

The most used fibers are the *step index fibers* and the *graded index fibers* and they can be either single mode or multi mode, having respectively a core of diameter within the range of  $3-20 \,\mu m$  and  $50-400 \,\mu m$ .

As shown in the following figure, depending on the window used for the transmission, we can experience different values of attenuation.



Figure 2.11: Attenuation as function of the frequency

Typical values are those shown in the following table:

| λ       | $lpha_{dB}$ |
|---------|-------------|
| 0.85 µm | 2.5 dB/Km   |
| 1.31 µm | 0.4 dB/Km   |
| 1.55 µm | 0.25 dB/Km  |

 Table 2.1: Coefficient of attenuation at several and typical wavelength

In addition to the attenuation, two aspects that a fiber designer has to valuate closely are the intermodal and the chromatic dispersion. The first one is generated by the presence of multiple modes propagating in the core. Since each mode follows a specific path the original waveform of the signal transmitted is modified as shown in the following figure:



Figure 2.12: Effect of the intermodal dispersion

Nowadays, this issue is overcome using mono mode fibers that allow a unique mode of propagation.

The chromatic dispersion is generated because of using of light emitters not perfectly monochromatic and thus having several propagation velocities on dependence of the wavelength. In order to mitigate this issue, we can use either an emitter characterized by a reduced spectrum, like a good laser, or we can take into account that fibers lead to different chromatic dispersions depending on the used windows. In particular, it is introduced a chromatic dispersion parameter  $D(\lambda) = D_M(\lambda) + D_W(\lambda)$ , that measures the intensity of the chromatic dispersion.  $D_M(\lambda)$  and  $D_W(\lambda)$  are respectively the material dispersion and the wave guide dispersion. Typically,  $D(\lambda) = 0$  for  $\lambda = 1.310 \,\mu m$  (second window) but we have also special fibers, as *DS fibers* (Dispersion Shifted) and *DF fibers* (Dispersion Flattened), that allow modifying the dependence of the chromatic dispersion parameter from the wavelength  $\lambda$ . As shown in the following figure, DS fibers get the zero dispersion in the third window ( $\lambda = 1.550 \,\mu m$ ) whereas DF fibers have the chromatic dispersion parameter almost constant.



Figure 2.13: Curves of several chromatic dispersion parameters

For example, we may desire to get simultaneously a minimum both as to chromatic dispersion and for the attenuation, getting this purpose by means of a DS fiber.

Finally, it is important to notice that there are some other, important, effects limiting the performance of the transmission over optical fibers as, for example:

- *SPM* (Self Phase Modulation): in the propagation, the impulse suffers a non stationary phase displacement
- *XPM* (Cross Phase Modulation): if two or more channels are transmitted using different wavelengths simultaneously within the same fiber, an impulse can suffer a non linear phase displacement that depends on the intensity of the signals transmitted on the other channels

*FWM* (Four Wave Mixing): it occurs when are presented in the fiber three simultaneous channels, with ω<sub>1</sub>, ω<sub>2</sub> and ω<sub>3</sub> as respective pulsations, generating a new channel with pulsation ω<sub>FWM</sub> = ω<sub>1</sub> + ω<sub>2</sub> - ω<sub>3</sub>

These and other non linear effects are currently important matter of analysis and studies of physical researchers.

### 2.5.2. The wireless channel

Because of its intrinsic nature, the wireless channel presents specific properties and characteristics that are mostly dependent by two variables: the frequency of the radiation and the orography of the region. As to the frequency (or, equivalently, the wavelength), we must remember that, changing it, mutates the way to react of the transmission medium. As examples, the frequency can set variations in transmittance, absorptance, reflectance, attenuation and, since, in our channel modelling. For a fixed orography and taking into account IR and RF radiation (which will be mostly analysed in this work), we can summarize the effect of changing the frequency of radiation in the following table.

| Properties                               | IR                   | RF          |
|------------------------------------------|----------------------|-------------|
| Paraxial gaussian approximation          | Yes                  | No          |
| Multi-path fading                        | No                   | Yes         |
| Multi-path dispersion                    | Yes                  | Yes         |
| Transmission through walls and obstacles | No                   | Yes         |
| Dominant noise source                    | Illumination / Other | Other users |
|                                          | users                |             |
| Propagation losses                       | Very high            | High        |

**Table 2.2:** General characteristics of IR and RF channel

For fixed wavelength, the orography heavily determines our channel model. Numerous models have been introduced and, in the following of this subsection, we will provide a sufficiently deep description of the mostly used.

In literature typically we find two distinct kinds of models: deterministic (or statistic) models and empiric (or site specific) models.

### **Deterministic models**

They require a large amount of data with reference to the geometry, ground profile, position and characteristics of building, obstacles, etc. The use of these models leads to a great computational complexity and calculus resource but they provide to better and more accurate results.

Nowadays, the main and more used deterministic models are:

- Finite Differences Time Domain (FDTD)
- Method of Moment (MoM)

used principally for characterizing situations limited in space, as propagation in reduced environments or in proximity of the antennas (near field), and

• Ray tracing techniques

that is made use for

- link in sight (LOS)
- point to point links whose major contributes are the LOS ray and a unique reflected ray (ray tracing two rays model)



Figure 2.14: Two rays model

 point to point links in which the link can be represented by means of a single and simple diffraction mechanism generated by not much hills or buildings (blade of knife model)



Figure 2.15: Blade of knife model

### **Empiric models**

They are subdivided in the two big categories of models for indoor and outdoor links and they are based on simple analytic laws for the expected field that are derived from field measures performed with appropriate instruments.

As to the indoor models, they are based on an application of the *path loss* formula that, as known, is:

$$PL(dB) = 10 \log_{10} \frac{P_T}{P_R} = 10 \log_{10} \frac{(4\pi)^2 R^2}{G_T G_R \lambda^2}$$

and that, with some passage, can be rewritten as

$$PL(dB) = PL(R_0) + 10\log_{10}\frac{R^2}{R_0^2}$$

In this model, the key is to add a parameter  $\gamma$  whose role is to specify the particular indoor scenario. The parameter  $\gamma$  depends from the used frequency and the physical material used for the walls of the building but, typically, it has the following values:

| γ       | Typical situation                                          |
|---------|------------------------------------------------------------|
| 1.5-1.8 | Transmitter and receiver are in light of sight             |
| 2       | Free space                                                 |
| 3-4     | Transmitter and receiver are collocated in different rooms |

**Table 2.3:** *Parameter*  $\gamma$  *as function of the building structure* 

Introducing this parameter in the above equation, finally we obtain

$$PL(dB) = PL(R_0) + 10 \gamma \log_{10} \frac{R}{R_0}.$$

An example of an indoor scenario is shown in the following figure.



Figure 2.16: Indoor application scenarios

We can remember that, for our purposes, a typical indoor application scenario provides to:

- home networking and sensor interconnection
- cable replacement
- system interconnection

As regards the outdoor models, first we must notice the numerousity of them and then that they differ from each other for the approach, accuracy and complexity.

Some examples are:

- Okumura model (1968). It is one of the most used for planning mobile system (specially in Japan) and it is considered one of the better as to accuracy
- Hata model (1980). It introduced analytic explanation of the empiric results of the Okumura model
- Walfish Bertoni model (1988). It is oriented to estimate the signal strength as three contributes of loss: free space path loss, the reduction determined by the roofs, the reduction caused by the final path from the last roof to the receiver
- Ikegami model. It is a specific model used to estimate the final path of the Walfish Bertoni model
- COST-Walfish-Ikegami model (COST-WI). This model allows estimating the path loss introducing parameters of the environments in which the radiation is propagating

An example of an outdoor optical link may be that represented in the following figure.



Figure 2.17: Outdoor application scenarios (MAN UOWC)

For our scopes, an outdoor application scenario allows:

- last-mile access
- building interconnection
#### 2.6. Noise and interference

As regards the interference, we have already exposed that the main interference sources are caused by effects generated in the fiber because of the presence in the channel both of the interested channel and of multiple propagating channels.

Furthermore, the particular transmission system that we are analyzing possesses both classic noise sources, as the thermal noise, of which we have robust and consolidate theoretic models<sup>1</sup>, and specific (of an OCS) noise sources, as natural or artificial illuminations, whose effects in the transmission chain are nowadays under theoretical and experimental study and of which we are going to investigate with some detail the main characteristics.

The main noise sources that we must consider in an OCS are:

- Sunlight illumination. It generates into the receiver, the photodiode, shot noise that can be considered as white gaussian noise
- Artificial lamps irradiance, as incandescent, fluorescent, halogen lamps. It produces shot noise that can be considered as a narrowband interference



Figure 2.18: Spectrum of the noise optical sources

<sup>&</sup>lt;sup>1</sup> we will show some of them in the section dedicated to the receiver

Even employing optical filtering, the photodiode, that transform the radiation in d.c. photocurrent, can receive an average power that overcomes the signal of interest causing, in last analysis, bit error.

As one can verify using the Wien shift law

$$\lambda_{\max} = \frac{C}{T} \quad \text{where } C = 0.2897 \cdot 10^{-2} \ Km \,,$$

the solar irradiation comes to the Earth at wavelengths that are determined by the photospheric temperature of the sun, which peak is around 5600 °C. As shown in Figure 2.18, the main contributes are in the wavelength range of 0.2 and 3.4  $\mu m$  with the maximum around at 0.48  $\mu m$  which is in the visible green region. Moreover, as shown in the following figure, the spectral irradiance is reduced by the atmospherical absorption.



Figure 2.19: Solar Spectral Irradiance through the atmosphere

In order to limit the incident radiation of the ambient light noise, we can interpose lenses between the output of the channel and the input of the photodiode. This leads to a smaller d.c. photocurrent and thus to a reduced shot noise as it is shown in the following table.

|                    | Without optical<br>filter | With optical filter | Optical filter<br>reduction |
|--------------------|---------------------------|---------------------|-----------------------------|
| Direct sun light   | 5100 µA                   | 1000 μΑ             | 5.1                         |
| Indirect sun light | 740 <i>µA</i>             | 190 µA              | 3.9                         |
| Incandescent light | 84 <i>µA</i>              | 56 µA               | 1.5                         |
| Fluorescent Light  | 40 <i>µA</i>              | 2 µA                | 20                          |

**Table 2.4:** Effect of optical filtering on the d.c. photocurrent

By mean of experimentations, it has been shown that halogen and incandescent lamps can be modelled as sum of cosinusoids whose harmonics are multiple of 100 Hz. Over 800 Hz all the amplitude components are 60 dB below the fundamental and, therefore, negligible.

The following figure shows the typical electrical spectrum (namely, after transduction) of a 60 W, 50 Hz tungsten-filament incandescent lamp.



**Figure 2.20:** *Typical electrical spectrum of a 60 W, 50 Hz tungsten-filament incandescent lamp* 

Because of its limited spectral power, it is possible to reduce sufficiently the effect of incandescent lamps on IR signals.

Vice versa, the typical electrical spectrum of a fluorescent lamp holds components at harmonics up to tens of kilohertz.



Figure 2.21: Power spectral density of shot noise of a fluorescent lamp

Much more problems are generated if electronic ballast is used. In fact, in this case the electrical d.c. interference current generated after transduction holds components with elevated amplitude up to hundreds of kilohertz.

In order to mitigate the interference correlated to fluorescence lamps when, in particular, driven by an electronic ballast, it is possible to use either lenses or to exploit the code gain obtained using, as we will see in the next chapter, *spread spectrum* techniques.

In order to give an idea of what said, it is shown in the following figure (which displays the SNR requirement for several modulation techniques, fixed the BER at $10^{-9}$ ) the bit rate at 10 Mb/s, for two electronic ballasts.



Figure 2.22: Example of performance obtained with several modulation techniques

## 2.7. Lenses and interferometer optical filter

As seen above, the channel introduces noise and interference that we can mitigate first of all using tinted lenses. The use of lenses not only allows reducing sufficiently sun light but also to increase the *FOV* (Field Of View), as the CPCs, implying a large amount of received optical power and, as counterpart, a more intensive multipath dispersion caused by different paths inside the lenses. This effect is schematically shown in the following figure.



Figure 2.23: Example of multipath effect inside the lenses

The optical filters can be or less tunable. The most used are: Fabry Perot interferometer, Mach Zehnder interferometer, Bragg's grids.

The interferometer optical filters, over that to subsequently reduce ambient noise and interference, are used to isolate different channels in a *WDM* (Wavelength Division Multiplexing) scheme access. Some examples are: Mach Zehnder interferometer, waveguide grating, add/drop filter.



Figure 2.24: WDM access's scheme

#### 2.8. The photodiode

Nowadays, there are in commerce two kinds of photodiodes: *PIN* and *APD* photodiodes. In an OCS, both are used for the optical-electrical conversion. In the following of this section we are going to present with some details the physical effects and the main characteristics on which they are based.

When light of appropriate wavelength impress on a junction, because of the absorption of photons, electrons overcame the bandgap energy going from the valence band to the conduction band, therefore leading to generate photocurrent. In particular, the photodiode can work either in zero bias, in which way the device has the same behaviour as that shown above, or in reverse bias, in which it holds an extremely high resistance up to that light falls on the junction causing its reduction and thus leading to a high sensitivity to the light exposure.



Figure 2.25: Absorption of a photon

Working with reverse bias junction presents also a drawback. It consists in the presence of a small current, called *dark current*, even though there is no light falling on the junction. The presence of dark current leads to a reduced value of the total SNR and, since the dark current is temperature dependent, the amount of this leakage goes up increasing the temperature.



Figure 2.26: Effect of the temperature increasing on the dark current

When presents, the dark current is added to the useful current, the photocurrent, which is related to the optical power by the following formula:

$$i(t) = \rho \cdot p_{opt}(t) \quad [A]$$

where the quantity

$$\rho \stackrel{\text{def}}{=} \frac{I_{out}}{P_{in}^{(opt)}} = \frac{\eta q}{h\nu} = \frac{\eta}{1.24} \lambda_{\mu m} \quad \left[\frac{A}{W}\right]$$

is the *responsivity* and  $\eta$  the *quantum efficiency*. The dependence from the temperature of the quantum efficiency makes also the responsivity depending from the temperature and, thus, the photocurrent as well.

In order to obtain a sufficiently high value for the SNR we must limit both the thermal noise and the shot noise.

The first one is generated by the resistance of the device *R* and it is expressed by the well known Johnson formula

$$I_J = \sqrt{\frac{2RkFT_0 \cdot 2B}{R^2}} = \sqrt{\frac{4kFT_0B}{R}} \quad [A].$$

The contemporary presence of the useful current signal and the dark current leads to shot noise current that can be express by the following formula

$$I_{s} = \sqrt{(I_{d} + I_{p} + I_{B})q \cdot 2BM^{2}F_{e}} \quad [A]$$

where  $I_d$  is the dark current,  $I_p$  the photocurrent generated,  $I_B$  the ambient noise, B the system bandwidth and  $F_e = M^a$  a parameter related to the gain of the APD diode (M = 1 for the PIN diode).

The total SNR at the receiver is thus

$$SNR_{TOT} = \frac{I_p^2 M^2 R}{I_s^2 R + I_J^2 R} = \left( (SNR_s)^{-1} + (SNR_J)^{-1} \right)^{-1}.$$

Generally, we have the two following situations:

• in an APD diode the shot noise is dominant and we have:

$$SNR_{S} \cong \frac{I_{p}^{2}M^{2}}{I_{S}^{2}} \cong \frac{I_{p}}{q2BF_{e}} (I_{d} \cong 0)$$

• in a PIN diode the thermal noise is dominant and then we obtain:

$$SNR_{J} \cong \frac{I_{p}^{2}M^{2}}{I_{J}^{2}} = \frac{\left(\frac{\eta}{1.24}\lambda_{\mu m}P_{in}^{(opt)}\right)^{2}RM^{2}}{4kFT_{0}B}.$$

## 2.9. The electrical processing

The above physical SNR can be improve first of all by means of an electrical filtering and subsequently exploiting modulation techniques as we will show in the next chapter.

#### 2.10. Appendix: the solitons

The possibility to obtain solitons inside optical fibers has been theoretically foreseen in the 1973 by the derivation of the Schrödinger equation for the propagation of the wave packet inside fibers, while the experimental observation of the formation of a soliton has been obtained in the 1980.

The solitons possess a particular property of orthogonality: when two propagating solitons interact among themselves, as the case of two impulse impacting that are propagating in opposite direction, they don't influence reciprocally but maintain the own "individuality" after the interaction, that is, they preserve the same wave shape (property generally not valid in nonlinear propagation). The above property is valid when the solitons have different wavelength and allows controlling the nonlinear problem in the optical transmission.

As counterpart, the above characteristic limits the use of solitons as impulses that represent one and zero bit in a numeric transmission. In fact, solitons at the same frequency, as those relative to two adjacent bit intervals, are subjected to attraction or repulsion strength in dependence of the relative phase of the wave packet. In a numerical transmission using solitons, the impulses must be maintained to a minimum distance, not generating hence appreciable interaction between them. In the opposite case, a variation in the position of the pulses, respect to the transmission clock, is generated. If  $t_0$  is the time duration of the pulse, in order to avoid this problem, we must use at least a time separation  $T \ge 20 \cdot t_0$  that, evidently, is a limit to the maximum bit rate of a solitonic system. Despite this, it has been shown that these systems lead to a bandwidth ten times better than the common infrared systems characterized by the use of the second windows or those that employ the third windows with DS fibers.

Finally, one of the most recent discoveries (INFM, 2004) has seen Italian researchers to control the direction of emission of a soliton beam, leading to the technical capability of deviate the direction of propagation of the solitons.

# **Chapter 3**

## **Modulation and Coding Schemes**

## Contents

| 3.1 | Introduction                          | 30 |
|-----|---------------------------------------|----|
| 3.2 | 2 Spread spectrum techniques          |    |
|     | 3.2.1 Direct Sequence Spread Spectrum | 31 |
|     | 3.2.2 Time Hopping Spread Spectrum    | 35 |
| 3.3 | On Off Keying modulation              | 37 |
| 3.4 | Pulse Position Modulation             | 38 |

## **3.1. Introduction**

As first marking, the intent of this chapter is not to exhaust completely the modulation and coding schemes in each of them articulate parts, but to provide a sufficiently detailed description of the most important<sup>2</sup> modulation techniques and coding schemes used in optical communication systems.

In order to realize our scope and taking in to account that nowadays the most used schemes in the optical systems are those carrierless, we will show the basic principles about: *Spread Spectrum (SS)* techniques (*DSSS, THSS*) and *Intensity Modulation (IM)* techniques (*OOK* and *PPM*).

In the following figure are shown the modulation and coding schemes mostly used in an optical communication system.



Figure 3.1: Modulation and coding schemes

<sup>&</sup>lt;sup>2</sup> relatively both to the current use and to research for future implementations

#### 3.2. Spread spectrum techniques

As it is shown in Figure 2.1, spread spectrum techniques are divided in carrierless schemes, DSSS (Direct Sequence Spread Spectrum) and THSS (Time Hopping Spread Spectrum), and carrier based schemes, FHSS (Frequency Hopping Spread Spectrum).

In the following two subsections we will give, with some detail, the main and fundamental principles about them.

#### 3.2.1. Direct Sequence Spread Spectrum

The transmission scheme of a DSSS system is sketched in Figure 3.2.



Figure 3.2: Representation of the baseband transmission scheme of a DSSS system

Using the representation of Figure 3.2, one has to pay attention to the fact that the data rate before and after the multiplication by the code c(l) (l = 0, ..., N - 1) is different. In particular, being  $R_B = 1/T_B$  the bit rate,  $T_B$  the bit period and multiplying each bit to be transmitted by a code composed of N elements, denoted as *chips* whose duration is  $T_C = T_B/N$ , after multiplication one gets a chip rate equal to  $R_C = 1/T_C = N/T_B = N \cdot R_B$  leading (at least) to a bandwidth of  $B_C = 1/2T_C = N \cdot B_B$ . This feature justifies the name of the method, as the system spreads the transmit power over a spectrum that is larger by a factor N than the spectrum strictly required to send the original sequence of symbols.

For advantageous reasons that it will be shown in the following, the sequences c(l) used in DSSS systems are typically *pseudo-noise* and, optionally, *orthogonal* (for CDMA) sequences having unitary modulus, that is  $c^2(l) = 1$ . When both properties are used, the system takes the name of DS-CDMA system.

The pseudo-noise nature of the spreading sequence c(l) provides to a fundamental feature of the spread spectrum system called *Low Probability of Intercept (LPI)*, namely spread spreading signals are typically hard to detect, to intercept and to demodulate.

The orthogonal nature of the spreading sequence allows using CDMA techniques that are exploited in order to grant to many users the same portion of spectrum at the same time.

With the warning in mind about the rate change, the overall DSSS system can be represented as in Figure 3.3:



Figure 3.3: Representation of the baseband DSSS system

where i(t) represents the interference, whereas n(t) is noise. The final block in the receiving chain is a low-pass filter (LPF), with bandwidth  $B_B = 1/2T_B$ .

To have a physical insight into the properties of a DSSS system, it is useful to analyze how the spectrum of useful signals and interference change as they pass through the system. To this end, in Figure 3.3 we have labelled four points: A, B, C, and D. The power spectral densities in the points A and B, denoted by  $S_A(f)$  and  $S_B(f)$ , are shown in Figure 3.4.



Figure 3.4: Power spectral densities in the points A and B of the DSSS system

As it is depicted in Figure 3.5, the increased spectrum can be justified by the augmented rate that, in the point B, is N times that of the point A.



Figure 3.5: Effect in the time domain of the bit-chips multiplication

Comparing  $S_A(f)$  with  $S_B(f)$ , we can observe how multiplying by the code leads to spread the original spectrum. Furthermore, since the spreading sequence c(l) has unitary modulus, the multiplication does not alter the signal power. For this reason, the areas subtended by the two power spectral densities in Figure 3.4 are the same.

At the receiver, after multiplication for the spreading code c(l), exploiting the property that  $c^2(l) = 1$ , the power spectral density of useful signal shrinks back into the bandwidth between  $-1/2T_B$  and  $1/2T_B$ . Conversely, all the other signals, namely interference and noise, have a spectral density whose shape is like  $S_B(f)$ .

At the input of the final low-pass filter, the useful signal has then a spectrum like  $S_A(f)$ , whereas interference and noise, because of the multiplication by the code sequence, have a spectrum as  $S_B(f)$ . Hence, at the output of the final low-pass filter, we obtain that all the power of the useful signal passes, whereas only a fraction of the interference goes through the receiver. More specifically, we will show that the overall system holds a gain N in the total SNR, namely in the signal-to-noise-plus-interference ratio SNIR.

Let us consider the m-th transmitted bits:

$$y_m(n) = b(m)c(n) + i(n) + v(n),$$

where i(n) and v(n) are respectively the interference and the noise sequences. Let us denote with  $P_B^{IN}$ ,  $P_I^{IN}$  and  $P_N^{IN}$  respectively the power of signal, interference and noise at the input of the DSSS receiver. Let us compute the power of these three contributions at the output of the receiver. Multiplying  $y_m(n)$  by c(n) and summing over n, we obtain

$$z(m) = \sum_{n=0}^{N-1} c(n) y_m(n) = N s(m) + \sum_{n=0}^{N-1} c(n) i(n) + \sum_{n=0}^{N-1} c(n) v(n),$$

in which we have used the property  $c^2(n) = 1$ . To compute the power of the interference and noise contribution we exploit now the property that the spreading sequence is pseudonoise. In particular, considering the elements of c(n) as i.i.d. random variables with zero mean and unit variance, the power of the interference and noise at the output of the DSSS receiver are  $P_I^{out} = N P_I^{in}$  and  $P_N^{out} = N P_N^{in}$ , respectively. As a consequence, the SNIR at the output of the DSSS receiver is

$$SNIR^{out} = \frac{N^2 P_B^{in}}{N P_I^{in} + N P_N^{in}} = N \cdot SNIR^{in}.$$

This property explains one of the most fundamental reasons for using DSSS system: the relative immunity against interference, property denominated *Anti Jam (AJ)*. To this regard, we must introduce a fundamental parameter, the process gain  $G_p$ , expressed by the following formula:

$$G_p = \frac{W}{R_h},$$

namely by the ratio of the bandwidth occupation and the data bit rate. The processing gain  $G_p$  leads to a better capacity in the interference rejection (directly proportional to  $G_p$ ), and to an increased system capacity (directly proportional to  $G_p$ , as well).

Considering that spread spectrum techniques are jointed with Code Division Multiple Access (DS-CDMA systems), we can state by the above formula that the main limitation of a DS-CDMA system is the *Multiple User Interference (MUI)*.

Finally, we remind briefly that there can be different kinds of sequences and, depending of them, changes the particular multiplication used. For example, if the sequences were antipodal, we should use the typical multiplication among real numbers whereas, if they were binary sequences, as in the Optical Orthogonal Codes (*OOC*), the complemented XOR would be proper.

| $b_1$ | $b_2$ | $b_1 \overline{XOR} b_2$ |
|-------|-------|--------------------------|
| 1     | 0     | 0                        |
| 0     | 1     | 0                        |
| 0     | 0     | 1                        |
| 1     | 1     | 1                        |

 Table 3.1: Truth table for the  $\overline{XOR}$  multiplication

#### 3.2.2. Time Hopping Spread Spectrum

As shown above, the DSSS technique, multiplying the useful signal by a pseudonoise code, enlarges its spectrum. Another way to spread the spectrum of a signal is to divide the bit time  $T_b$  in  $N_s$  intervals of duration  $T_s$ , to subdivide them in  $N_h$  subintervals of duration  $T_c$  in which to transmit, depending of the code, a chip whose value is the same of the bit coded.

What said, can be shown considering the following scheme:



Figure 3.6: Block diagram of a THSS system

in which the Code Repetition Coder, introducing redundancy, has an input data rate of  $R_b = 1/T_b$ , and an output average data rate of  $R_s = 1/T_s = N_s/T_b = N_s \cdot R_b$ , being  $T_b$  the

bit period,  $T_s$  the average pulse repetition time and  $N_s$  the repetition parameter. The reader can check directly the analogy with what we have shown at the start of the section 3.2.1 for DSSS system.

The transmission coder, using a code c of length  $N_p$ , arranges the elements of the sequence a inside subintervals whose progressive index is given by

$$d_j = jT_S + c_jT_c,$$

where  $T_c$  is the chip time. Because of this, using a pulse waveform indicated with p(t), we can express analytically a THSS signal as follows

$$s(t) = \sum_{j=-\infty}^{\infty} a_j p(t-d_j) = \sum_{j=-\infty}^{\infty} a_j p(t-jT_s-c_jT_c).$$

The following figure displays the waveform of two bits "1" coded using a THSS modulation technique.



**Figure 3.7:** *Example of coding of two bits "1" using the THSS technique. The pulse waveform used, is a second order gaussian derivative* 

#### 3.3. On Off Keying modulation

As we will see, for practical reasons of implementation, the most used detection technique for infrared links is *Direct Detection (DD)*. It can be used with several *Intensity Modulation (IM)* techniques of which the simplest is the *OOK*.

The OOK modulation allows transmitting using either NRZ pulses or ZR. Transmitting NZR pulses, the rectangular waveform has a time length of T whereas using a ZR it has duration of  $\gamma T$ , where the parameter  $\gamma$  is the *duty cycle* defined as:

$$\gamma \stackrel{def}{=} \frac{T_S}{T_S^{(P)}}$$

where  $T_s$  is the effective duration of the waveform and  $T_s^{(P)}$  is the symbol period.

For a given available medium power per bit  $\overline{P} = P_t$ , the OOK modulation foresees either to transmit a rectangular pulse of amplitude  $2P_t/\gamma$  if the bit transmitted is "1", or to not transmit if the bit is set to the logical value "0".

The following figure shows two examples of OOK signals using respectively  $\gamma = 1$ and  $\gamma = 0.5$ .



Figure 3.8: Examples of two signals modulated OOK

For an OOK modulation, under AWGN hypothesis and supposing that the channel is distortion-free, the ideal maximum-likelihood (ML) receiver can be realized by the following chain: continuous-time filter matched to the pulse waveform, sampler, detector whose threshold is set to  $\frac{1}{2} \cdot (2P_t/\gamma) = \frac{P_t}{\gamma}$ .

Eventually, as it is displays in Figure 3.9, one must notice that using shorter pulses implies a larger bandwidth requirement of a factor  $1/\gamma$ .



**Figure 3.9:** *Effect on the bandwidth of reducing the duty cycle*  $\gamma$ 

### 3.4. Pulse Position Modulation

The pulse position modulation consists in transmitting a pulse waveform during a subinterval obtained dividing in several parts the symbol period  $T_s^{(P)}$ . In particular, if we are interested to transmit  $\log_2 L$  bits coded in a symbol (L-PPM) with the limit of an available medium power per bit equal to  $\overline{P} = P_t$ , we will have to use a constant power of  $L \cdot P_t$  assigned to every symbol. This can be shown recalling that the medium power per symbol is given by

$$\overline{P} = \sum_{i=0}^{L-1} p_{S_i} (T_{S_i} A) / T_{S_i}^{(P)}$$

where  $s_i$  is the i-th symbol, A the relative power assigned and  $p_{s_i}$  the correspondent probability. Obviously, if one is interested to calculate the medium power per bit, the above formula becomes

$$\overline{P_{bit}} = \frac{1}{\log_2 L} \sum_{i=0}^{L-1} p_{S_i}(T_{S_i} A) / T_{S_i}^{(P)} .$$

For a given symbol, this power  $(L \cdot P_t)$  is allocated to the correspondent pulse transmitted in one of the *L* subintervals in which the symbol period  $T_s^{(P)}$  is divided (remaining all the others with zero power transmitted).

The following figure displays two examples of signals L-PPM modulated.



Figure 3.10: Examples of two signals L-PPM modulated

One of the main advantage of using L-PPM consists in the fact that, increasing L, the peak power rises linearly with L whereas noise with  $L/\log_2 L$ . This implies a SNR that goes as  $\log_2 L$ . It can be shown that, under AWGN hypothesis and supposing that the receiver is optimum (ML detector), if the SNR is sufficiently elevated, in particular if  $E_b/N_0 > 4.43 \ dB$ , the symbol error probability is constrained by the following upper limit

$$\Pr_{e} < e^{-\log_{2} L (E_{b}/N_{0} - 2\log_{e} 2)/2}$$

The following figure shows the SER obtained in the cases of L = 2, L = 4and L = 8.



Figure 3.11: Symbol Error Probability for L-ary PPM

Vice versa, we can fix the Bit Error Rate and to obtain the power requirements to achieve that BER. The Figure 3.12 gives an example in which we can notice how the performance can be improved by means of coding.



Figure 3.12: Power requirements obtained varying the number of levels L

Under AWGN hypothesis, comparing OOK with L-PPM results in the same performance if L = 2 whereas, for L > 2, L-PPM presents a decreasing energy per bit requirement and, as counterpart, an increasing bandwidth requirement by a factor  $L/\log_2 L$ .

A useful graphic that represents clearly what said, is the following.



Figure 3.13: Comparison between OOK and L-PPM performance

As already said, OOK and 2-PPM get the same power requirement in the obtaining of equal BER. On the other hand, increasing the value of L, leads the L-PPM to a better performance, at least regarding the power requirement. In fact, as evident in the Figure 3.14, if the main limit of the system is the bandwidth, we must do attention about the value of L.



Figure 3.14: Comparison between OOK and L-PPM bandwidth requirements

Further, to show the differences in power and bandwidth requirements for OOK and L-PPM modulations, the above figure evidences that, as it is known, there are 1.5 dB of difference in performance between L-PPM decoded with hard and soft decision. Of course, this loss is paid by a relative simplicity to implement hard decoding.

Finally, we should must notice that in an optical system affected by ambient noise, even starting from L = 2, the L-PPM systems get better performances than those using OOK modulation.



Figure 3.15: Comparison of OOK and L-PPM system when is present ambient noise

# **Chapter 4**

## The Ultra Wide Band Communication System

### Contents

| 4.1 | Introduction                                         | 46 |  |
|-----|------------------------------------------------------|----|--|
| 4.2 | 2 Definition of UWB signal and its generation        |    |  |
|     | 4.2.1 Generation of TH-PPM-UWB signals and their PSD | 49 |  |
|     | 4.2.2 Generation of TH-PAM-UWB signals and their PSD | 53 |  |
|     | 4.2.3 Generation of MB-UWB signals and their PSD     | 55 |  |
| 4.3 | Pulse shaping in UWB systems                         | 56 |  |

## 4.1. Introduction

UWB is a new and appealing technology that, because of its characteristics, in the last years interested an increasing numbers of manufacturing companies, academic researchers and standardization groups.

As we will see in the following, exploiting advanced transmission techniques, it offers potentialities and features that can lead to a revolution, rather than to an evolution, in the telecommunication systems.

Because of the spectral characteristics of the transmitted signals, UWB is a technology that must coexist with the other pre-existent systems. Therefore, it is fundamental to define and to analyse in detail the interferences caused by UWB systems. In the United States the *Federal Communication Commission (FCC)* commissioned measurements campaigns to the *National Telecommunications and Information Administration (NTIA)*. The report provided the information necessaries to the FCC to issue a first document in which it is allowed the intentional emission of UWB signals and are specified the emission masks.



Figure 4.1: FCC indoor and outdoor emission masks

Evidently, it is foreseeable that analogous campaigns will be performed in other countries willing to use UWB communication systems.

To date, two main standardization groups, both IEEE, have worked in order to define two kinds of UWB systems, each correspondent to specific fields of applications:

- IEEE 802.15.3 (3a) Task Group is developing an UWB communication system oriented to transmit high bit rate over short range. This technology is suitable for building Wireless Personal Area Networks (WPANs), for transmitting traffic requiring high bit rate such as multimedia traffic (video, audio, images, etc.) both for substituting cable transmissions (USB, IEEE 1394), and to link wearable devices such mobiles, Hi-Fi headphones, stereos, cameras, etc. As to this, meaningful is the choice, taken just in these months by the Bluetooth Special Interest Group, to exploit the advantages of the Ultra Wide Band technology for future versions of the Bluetooth technology.
- IEEE 802.15.4 (4a) Task Group is blooming instead the complementary technology, namely an UWB system oriented to low transmission rates over medium to long ranges. Transmitting typically around 1 Mbps over tens of meters, 802.15.4 is a suitable technology for non real time data applications (e-mailing, messaging, etc.). More over, because of its characteristics, it is particularly appropriate for ad-hoc sensor networks requiring a no stationary infrastructure as it is needful in case of earthquakes, fires, avalanches, intercommunications in fleets of vehicles (taxicabs, trucks, buses) and so on. For these specific applications, the network must provide special features, representing the main challenges for this technology, such as high-precision ranging and localization capabilities, power constraints and low cost.

In the following sections, the main characteristics and challenges of an UWB communication system will be provided, such as: definition of an UWB signal, its generation and spectral characteristics, propagation and interference models, receiver structures, ranging – positioning techniques.

#### 4.2. Definition of UWB signal and its generation

Before to enter in the details of the generation of UWB signals, an exact definition of what is an UWB signal and when a signal can be considered UWB must be provided.

As it is known, the fractional bandwidth is so defined:



Figure 4.2: Energy spectrum of a modulated signal

namely as the ratio between the energy bandwidth of the signal and the central frequency of its spectrum. Whereas following the statement of the radio community, an UWB signal is characterized to have an instantaneous fractional bandwidth larger than about 0.2, in the report of 2002, FCC gives also the possibility to a signal to be UWB when its bandwidth exceeds 500 MHz. This limit leads to a carrier threshold of 2.5 GHz that allows defining the follow definition of UWB signal: given the threshold of  $f_t = 2.5 GHz$ , below  $f_t$  a signal is UWB if its fractional bandwidth is greater than 0.2, whereas above  $f_t$  it is UWB if its bandwidth exceeds 500 MHz.



The signals have carriers respectively of 0.8 GHz and 1.6 GHz (both under  $f_t$ ). The first one (up), having a fractional bandwidth of 0.25, is an UWB signal, whereas the second (bottom), having a fractional bandwidth of 0.125, is not a UWB signal.

Figure 4.3: Rectangular modulated signals and their spectrum

Nowadays, three main transmission techniques have been developed to be used in UWB systems: TH-PPM-UWB, DS-PAM-UWB and MB-UWB. The first two get impulsive transmission techniques, namely discontinuous transmissions. In the MB-UWB case, a continuous time signal is transmitted using an OFDM modulation. In November 2004, for now unofficially, the DS-PAM-UWB case has been chosen over MB-OFDM by the 802.15.3a Task Group for the physic layer of the correspondent standard, that is to say 802.15.3a. It is foreseeable that the TH-PPM-UWB transmission techniques will be chosen for the 802.15.4a physic layer. In the following subsections we will show the three above quoted cases, remarking our attention on the TH-PPM-UWB and DS-PAM-UWB cases.

#### 4.2.1. Generation of TH-PPM-UWB signals and their PSD

In the TH-PPM-UWB case, a PPM modulation is applied to the signal to transmit. A TH code is used, leading to a medium access by means of the time domain. The following figure shows the transmission block scheme of a TH-PPM-UWB system.



Figure 4.4: Block scheme for a TH-PPM-UWB transmission system

The Code Repetition Coder gets the binary sequence **b**, whose bit rate is  $R_b = 1/T_b$ , as input and introduces in it redundancy. The coder has a coding rate of  $N_s$ , leading to an output bit rate of  $N_s/T_b = N_s \cdot R_b$ .

The transmission coder uses the TH code **c**, whose periodicity is  $N_p$ , for arranging the elements of the sequence **a** in the time axis. More over, a time shift of  $\varepsilon$  is applied if the bit currently coded is "1". Overall, the *j*-th element of the sequence **a** is shifted in time of the quantity  $d_j = c_j T_c + a_j \varepsilon$ , where  $T_c$  is the chip rate and  $\varepsilon$  the *PPM shift*. Since this shift must be within a time interval of length  $T_s$ , called average pulse repetition period, the condition  $c_j T_c + \varepsilon < T_s$  is required. The PPM modulator allows both arranging the *j*-th chip in the temporal instant  $jT_s + d_j$ , and generating dirac impulses in correspondence of each element.

The final block, the pulse shaper, allows shaping the spectrum of the UWB emitted signal. It has an impulse response p(t), whose analysis will be given in the following of this chapter. Because of the discontinuous nature of the generated signal, it must produce a sequence of strictly not overlapping pulses.

For what said, it is clear that the analytical form of a TH-PPM-UWB signal is given by

$$s_{PPM}(t) = \sum_{j=-\infty}^{\infty} p(t - jT_s - d_j) = \sum_{j=-\infty}^{\infty} p(t - jT_s - c_jT_c - a_j\varepsilon).$$

The following figure displays a TH-PPM-UWB signal in the case of two bits transmitted, average transmitted power of -30 dBm, average pulse repetition period  $T_s = 3 ns$ , number of pulses per bit  $N_s = 5$ , chip time  $T_c = 1 ns$ , code  $\mathbf{c} = [2, 0, 1, 2, 2]$ , with cardinality of  $N_h = 3$  and periodicity  $N_p = 5$ , PPM shift  $\varepsilon = 0.5 ns$  and using a pulse shaper whose impulse response p(t) is a second derivative gaussian pulse.



Figure 4.5: Example of a 2PPM-TH-UWB emitted signal

The spectrum of a such signal can be found under the hypothesis that the periodicity  $N_p$  of the code **c** is equal to the number of pulses per bit  $N_s$  leading the signal to be periodic with period  $T_b = N_s T_s = N_p T_s$ .

In such signal, a temporal structure is repeated every  $T_b$  sec; its name is multi-pulse and its analytical expression is given by

$$\nu(t) = \sum_{j=0}^{N_s - 1} p(t - jT_s - c_j T_c).$$

Depending on the bit transmitted, the PPM shift is applied just to this temporal frame. Therefore, we can express the above formula of the modulated signal as

$$s_{PPM}(t) = \sum_{j=-\infty}^{\infty} v(t - jT_b - b_j \varepsilon).$$

In the Figure 4.6 is presented an example in which are sequentially transmitted first a "0" bit, after a "1" bit in case of  $N_s = N_p = 3$ .



**Figure 4.6:** Graphical representation of a 2PPM-TH-UWB signal with  $N_s = N_p = 3$ 

It can be shown that, under the above hypothesis, the PSD of such signal is given by

$$P_{S_{PPM}} = \frac{\left|P_{\nu}(f)\right|}{T_{b}} \left[1 - \left|W(f)\right|^{2} + \frac{\left|W(f)\right|^{2}}{T_{b}} \sum_{n=-\infty}^{\infty} \delta\left(f - \frac{n}{T_{b}}\right)\right],$$

where W(f) is the Fourier transform of the probability density function of the random bits  $b_i$  and  $P_v(f)$  the Fourier transform of v(t).

Over that a continuous part given by W(f) and  $P_v(f)$ , the previous spectrum presents also a discrete part, whose spectral lines have a periodicity of  $1/T_b = 1/N_sT_s = 1/N_pT_s$ . Obviously, increasing  $N_s$  (namely  $N_p$ ) the periodicity of signal tenses to disappear, leading to an approach of the lines. This effect is displayed in the following figure.



**Figure 4.7:** *Effect of increasing*  $N_s = N_p$  on a 2PPM-TH-UWB signal

However, no longer supposing the equality between  $N_s$  and  $N_p$ , it is possible to reduce the discrete part of the spectrum increasing the value of  $N_p$ , maintaining constant the value of  $N_s$ . This technique goes under the name of *PSD whitening*.

#### 4.2.2. Generation of TH-PAM-UWB signals and their PSD

In the DS-PAM-UWB case, a PAM modulation is applied to the signal to modulate and, this time, a DS code is used. The following figure shows the transmission block scheme of a DS-PAM-UWB system.



Figure 4.8: Block scheme for a DS-PAM-UWB transmission system

Once time again the Code Repetition Coder has in input the binary sequence **b**, whose bit rate is  $R_b = 1/T_b$ , and introduces redundancy in it. The coder has still a coding rate of  $N_s$ , and an output bit rate of  $N_s/T_b = N_s \cdot R_b$ .

Before to enter into the transmission coder, the binary sequence **a** is first of all changed in a binary antipodal sequence, associating to a "1" bit a value equal to "+1" and to a "0" bit a "-1". The new sequence so generated is indicated with  $\mathbf{a}^*$ .

The transmission coder uses a DS code **c**, whose periodicity  $N_p$  is typically a multiple of  $N_s$ , for generating a new sequence **d** obtained multiplying directly each element of **a** for the correspondent in **c**, namely  $d_j = a_j c_j$ . Evidently, the output bit rate is the same of that in input, that is to say  $N_s/T_b = 1/T_s$ .

With period  $T_s$ , the PAM modulator inserts into the time axis a sequence of dirac pulses whose amplitude is that of the elements of the coded binary antipodal sequence **d**. Once again, this system block does not change the rate.

Likewise to the TH-PPM-UWB case, the pulse shaper shapes the spectrum of the signal emitted using an impulse response p(t). Given the discontinuous nature of the signal emitted, the sequence of pulses must be again strictly not overlapped.

Finally, the emitted DS-PAM-UWB signal can be analytically expressed as

$$s_{PAM}(t) = \sum_{j=-\infty}^{\infty} d_j p(t-jT_s)$$

whose PSD, in the case of 2PAM modulation, is given by

$$P_{S_{PAM}} = \frac{1}{T_s} \left| P(f) \right|^2 P_c(f)$$

where  $P_c(f)$  is the DFT of the autocorrelation of the sequence  $\{d_j\}$ .

A graphical example of a signal 2PAM-DS-UWB is given in the Figure 4.9. The transmission parameters are: three bits transmitted, average transmitted power of -30 dBm, average pulse repetition period  $T_s = 1 ns$ , number of pulses per bit  $N_s = 10$ , code  $\mathbf{c} = [1, 1, 1, 1, 1, 1, 1, 1, 1, 1]$ , with periodicity  $N_p = 10$  and using a pulse shaper whose impulse response p(t) is a second derivative gaussian pulse.



Figure 4.9: Example of a 2PAM-DS-UWB emitted signal

The spectrum of a 2PAM-DS-UWB is composed both by a continuous and by a discrete part. Greater is the independence of the elements of **d** (increasing  $N_p$  and maintaining constant  $N_s$ ), more similar to P(f) is the spectrum of the emitted 2PAM-DS-UWB signal.

The following figure displays what said above.


Figure 4.10: Effect of increasing  $N_p$ , maintaining constant  $N_s$ , on a 2PAM-DS-UWB signal

#### 4.2.3. Generation of MB-UWB signals and their PSD

Following what stabilized by the FCC, UWB systems can exploit for their transmissions 7.5 GHz of bandwidth, namely the frequency range within 3.1 GHz and 10.6 GHz. Remembering the definition of UWB signal given previously, in that range a signal is UWB if its bandwidth exceeds 500 MHz.

The MB-OFDM case is based on the OFDM modulation. It has been proposed by the IEEE 802.15.TG3; it foresees 128 sub-carriers, equally spaced by 4.1254 MHz and located at the carrier  $f_c$ =3.432 GHz.

The complex envelope of an OFDM symbol is equal to

$$\underline{x}(t) = rect\left(\frac{t}{T}\right)\sum_{m=0}^{N-1} c_m e^{-j2\pi f_m t}$$

to which correspond the following PSD

$$P(f) = \sum_{m=0}^{N-1} \sigma_{c_m}^2 \sum_{m=0}^{N-1} P_{f_m}(f),$$

where  $P_{f_m}(f) = \sin c \left( \frac{\pi (f - f_m)}{\Delta f} \right)$  is the spectrum centred on the m-th sub-carrier.

A graphical representation is given in the next figure.



Figure 4.11: PSD of an MB-OFDM-UWB signal

#### 4.3. Pulse shaping in UWB systems

As told previously, in the final report of the 2002 the FCC stabilized the emission masks to must respect, at least in the United States (Figure 4.1). In particular, for a system designer this implies a quite heavy constrain in the emitted power.

In order to exploit as much as possible the emission mask, several studies have been taken regarding the system that in an UWB transmission chain mostly conditions the shape of the spectrum: the pulse shaper and its impulse response.

The gaussian pulse, because of its easiness to be generated, is the most used waveform. However, despite of this advantage, alone it does not optimize the use of the available transmission power. It is possible to do much better varying its generation parameters such as the time duration of the pulse, its order of differentiation or, even, a combination of them.

For fixed differentiation order, the duration of a gaussian pulse is related to a fundamental parameter called *shape factor*. In fact, for any differentiation order of the gaussian pulse, one can write:

$$p_d(t) = f(t,\alpha) e^{-\frac{2\pi^2}{\alpha^2}}$$

where  $f(t, \alpha)$  is a rational function of t and  $\alpha$ . This means that the shorter is the pulse duration (small values of  $\alpha$ ), the larger is the bandwidth occupation of the transmitted signal.

This effect is shown in the next figure.



Figure 4.12: Effect of changing the shaper factor of the gaussian pulse

On the contrary, if one maintains fixed the duration of the pulse, namely its shape factor, it is possible to obtain higher peak frequency of the spectrum increasing the differentiation order. The peak frequency is in fact related to the differentiation order according with the formula

$$f_{k,\alpha}^{peak} = \frac{\sqrt{k}}{\alpha\sqrt{\pi}}.$$

The following figure provides a graphical representation of this effect for the first fifteen derivatives of a basic gaussian pulse.



Figure 4.13: Effect on the peak frequency of modifying the differentiation order



Figure 4.14: Effect on the PSD of modifying the differentiation order

Given the previous considerations, an immediate generalization can be effectuated considering the advantage coming from changing the shaper factor joined with that deriving by a variation of the differentiation order. Analytically this means to use a linear combination whose generic term is a gaussian pulses with appropriate shape factor and differentiation order. Therefore, the expression of this new impulse response is given by

$$p_c(t) = \sum_{i=1}^N c_i p_i(t)$$

where the coefficients  $c_i$  are chosen with the condition of respecting the FCC mask. Examples of algorithms used for obtaining those coefficients are the *Random Selection* algorithm and the *Least Mean Square Minimization* algorithm.

# **Chapter 5**

## **Wireless Access Control Protocols**

## Contents

| 5.1 | Introduction                                                             | 60 |
|-----|--------------------------------------------------------------------------|----|
| 5.2 | Random access protocols                                                  | 62 |
|     | 5.2.1 Aloha                                                              | 63 |
|     | 5.2.2 CSMA                                                               | 66 |
|     | 5.2.3 In-Band CA: MACA                                                   | 69 |
|     | 5.2.4 Out-Of-Band CA: BTMA                                               | 70 |
| 5.3 | Scheduled protocols and hybrid protocols                                 | 73 |
| 5.4 | Examples of standardized MAC protocols                                   | 74 |
|     | 5.4.1 MAC protocol for 802.11 standard: DFWMAC                           | 74 |
|     | 5.4.2 MAC protocol for IrDA standard: IrLAP                              | 79 |
|     | 5.4.3 UWB systems: MAC protocols for the standards 802.15.3 and 802.15.4 | 83 |
|     | 5.4.4 The (UWB) <sup>2</sup> MAC protocol                                | 85 |

## 5.1. Introduction

In a layered architecture for data network respecting the ISO/OSI stack model, the MAC layer is situated just upper the *Physical layer (PHY)* and constitutes the bottom part of the *Data Link Control (DLC)* layer whose upper sublayer is the *Logical Link Control (LLC)*.



Figure 5.1: ISO/OSI stack model for a data network

Although the theoretical definition of each level of the OSI stack does not require to specify the other levels often, for getting an efficient MAC, it is necessary to know with some detail the characteristics of the physical layer. In fact, the MAC layer holds the task of a fair resource sharing and a suitable definition of resource is related to how the physical layer manages transmission and multiple access techniques. Without entering in technical details, we mention as main multiple access techniques TDMA, FDMA and CDMA.

In this *cross-layer design* conception, the service that the MAC offers to the DLC layer consists to prevent and/or to resolve contentions that can be produced in the multiple access to the physical medium.

It has been shown that a set of parameters that can be used for characterizing a MAC layer independently by the characteristics of the physical layer are:

- Throughput, that is the percentage of the channel capacity used during data transmission
- Delay, namely the average time spent by a packet in a MAC queue
- Degree of fairness, that measures the equality of obtaining the medium access by the nodes of the network

A classification of wireless MAC protocols can be provided relatively to the modality of transmitting the data traffic. In fact, whereas random access protocols bring with themselves the possibility of data packet collisions (just because, for how they are defined, the random access phase interests data packets), scheduled protocols foresee that, after a random access phase in which are transferred control packets that can be subjected to collisions, there is a phase whose characteristic is to assure immunity from collisions on data packets.



Figure 5.2: Wireless MAC protocols

In the following sections we will show in detail the characteristics of wireless protocols, concentrating our attention on the random access protocols.

#### 5.2. Random access protocols

As said in the previous section, random access protocols does not foresee a phase in which is guaranteed resource reservation. For this reason data packet collisions can occur but, as counterpart, these families of protocols are characterized by *simplicity*, in the sense that:

- For transmitting, the terminals do not require specific and detailed information about other terminals (as it is necessary, for example, in a scheduled protocol as *token protocol*)
- The fact that a terminal does not spend (or spends little) time to transmit a data packet assures low delays, in the sense of what said at the end of the previous section

The main drawback derives really from the relative, above quoted, rapidity of transmitting. In fact, when the offered traffic increases, the probability of collision arises as well, leading both to reduce the throughput, and to enlarge the delay, since a terminal must spend time in the retransmission protocol (ARQ). Therefore, in networks with high traffic load, *Collision Avoidance* (*CA*) mechanisms are often adopted in order to mitigate this loss of performance.

Collision Avoidance techniques can be classified in the two big families of *In-Band Collision Avoidance* and *Out-of-Band Collision Avoidance*.

Examples belonging to the first one family are *MACA* (*Medium Access with Collision Avoidance*) and *802.11 DFWMAC* (*Distributed Foundation Wireless MAC*) protocols in which CA mechanisms (exchange of control packets between transmitter and receiver) are used in the data channel.

On the contrary, Out-of-Band Collision Avoidance mechanisms require a dedicated control channel in which to transmit control information which, in these protocols, instead to be organized into control packets, often is given as sinusoidal tones. Examples of Out-of-Band CA mechanisms are *BTMA* (*Busy Tone Multiple Access*) and *DBTMA* (*Dual Busy Tone Multiple Access*). We will enter in detail in them characteristics.

#### 5.2.1. Aloha

The Aloha protocol was introduced in 1970 at the University of Hawaii and, as it is known, is one of the simplest random access protocols never developed. A terminal willing send a packet transmits immediately, without taking into account if its transmission can potentially generate a collision. In order to allow to the receiver getting information about the correctness of its reception, a checksum is added at the end of a packet. In case of collision, the checksum will give negative result, the receiver will discard the corrupted received packet and then it will start the retransmission protocol (ARQ).



Figure 5.3: Examples of possible scenarios for transmitting of packets

By mean the above overview, one can realize that this protocol works well in network characterized by low traffic load but, conversely, its performance is going to reduce when traffic load will increase. The analytic results (found under opportune hypothesis) about the aloha throughout emphasize what said.



 $S = G(n)e^{-2G(n)}$ 

where G(n) is the cumulative arrival rate and *n* the number of terminals waiting for a transmission.

Figure 5.4: Unslotted Aloha and ideal MAC throughputs

A way for obtaining a better throughput is to divide the time axis into time slots leading to the so called *Slotted Aloha* in which packets are transmitted only at the start of each time slot.



Figure 5.5: Example of scenario in the Aloha slotted protocol

It can be shown that in this case the Aloha throughput can be expressed by the following formula

$$S=G(n)e^{-G(n)},$$

that leads to a double maximum throughput and whose graphical representation is provided in the Figure 5.6.



Figure 5.6: Slotted Aloha, unslotted Aloha and ideal MAC throughputs

A fundamental remark that one must do regards the potentiality of increasing the throughput in particular scenarios. In fact, the previous formula about the Aloha throughput has been found under the simplistic hypothesis that when a collision occurred the corrupted packet has to be discarded. Actually, even though corrupted, a packet can be decoded correctly if the useful power is sufficiently greater than the interference, namely if the *Signal to Interference Ratio (SIR)* is large enough. This effect, called *Capture Effect*, leads to increase the actual throughput, as displayed is the following figure.



**Figure 5.7:** Unslotted Aloha, Unslotted Aloha with capture effect and ideal MAC throughputs

Albeit the capture effect can lead to an increased throughput, nevertheless it is not always desirable. In fact, it can bring to an unfairness access, favoring those terminals that are nearer to the receiver, as in centralized network architectures.

The Aloha protocol is suitable in environment whose traffic load is low. In this framework, it can be implemented with facility, leading to a low delay and to a good throughput, specially using its slotted version. In network characterized by an increasing traffic load the performance of the protocol goes down and it is necessary to address our attention to other, more sophisticated, random access protocols.

#### 5.2.2. CSMA

Contrariwise of Aloha, the *CSMA* (*Carrier Sense Multiple Access*) protocol allows maintaining high the throughput even if the traffic offered by the network goes up.

The functioning of the protocol is quite simple: the terminal willing to transmit senses the channel for a time given by w and, if the channel is detected as idle for this time interval, it transmits. Vice versa, if the channel is busy, the terminal can use the following way:

- 0-persistent. The terminal will try to sense again the channel after a random delay
- 1-persistent. The terminal finishes to sense the channel for the time *w* and then it transmits
- *p*-persistent. The terminal adopts the 1-persistent strategy with probability given by *p* and the 0-persistent strategy with probability 1-*p*

The main limit of CSMA lies on the natural finite propagation velocity of the radiation. A terminal, in fact, could start to sense the channel without becoming aware of a transmission that currently it is occurring. This effect is well represented in the following figure.



Figure 5.8: Typical cause of collision for CSMA protocol

Under the same hypothesis through which the Aloha throughput was derived and conjecturing that in case of collision it will be employed the 0-persistent strategy, it can be shown that the CSMA throughput is given by

$$S = \frac{Ge^{-aG}}{G(1+2a) + e^{-aG}}$$

where the propagation time *a* is the largest possible in the network, namely *S* is a lower bound for the system performance.

The following figure displays a graphical comparison of the protocols seen so far.



Figure 5.9: Comparison between the throughputs seen until now

Although better than Aloha, performance of CSMA can fall if the network scenario presents, as unfortunately often happens in wireless environments, two phenomena that considerably decrease the efficiency of the protocol: the *hidden terminal* and the *exposed terminal* issues. Before to enter in the details of protocols that relieves these problems (CA mechanisms), it will be provided a general description of the two, above quoted, phenomena.

Let us consider a transmission between a terminal S, the source of the transmission, and a terminal D, the destination. A terminal H is said hidden terminal when it is into the radio coverage of the destination D but not into that of the source S.



Figure 5.10: Example of scenario relative to the hidden terminal phenomena

Applying the CSMA protocol, if the terminal H wanted to transmit to D as well, it should sense the channel for the time interval *w* and, not able to detect the transmission of S, would interfere with the transmission of S, causing collision. Even though the terminal H had wanted to transmit to another terminal D2, it would have generated a collision in D. This last situation is pictured in the Figure 5.11.



Figure 5.11: An other hidden terminal scenario potentially subjected to collision

An efficient protocol should mitigate this problem making the terminal H aware of being in the radio coverage of the destination D but not into that of S.

As regards the exposed terminal issue, a terminal is called exposed terminal if it is into the radio coverage of the transmitter but it is out of that of the receiver.

Let us consider a similar scenario in which a terminal S1 is the source and D1 is the receiver of their communication as is depicted in Figure 5.12.



Figure 5.12: Example of scenario for the exposed terminal issue

In the above scenario the terminal S2, willing to transmit to D2, senses the channel and finds it busy because of S1->D1 transmission. For this reason S2 postpones its transmission. This phenomena does not lead to collisions but is a source of efficiency loss.

Conversely of the hidden terminal, this issue could be relieve if terminal S2 was aware of being in the radio coverage of S1 (transmitter) but out of the radio coverage of D1 (receiver). The goal of collision avoidance mechanisms is really to make a terminal more aware of its position and role relatively to a transmission.

#### 5.2.3. In-Band CA: MACA

MACA is acronym for Medium Access with Collision Avoidance. It is not based on the carrier sense technique but it employs, before the transmission of a data packet, a change of control packet among the source and the receiver of the communication. This preparatory phase, called *handshaking*, allows preventing collisions between data packets, as soon as possible. The handshaking consists of three phases:

> With reference to Figure 5.13, the source of transmission S sends to D, the receiver, a control packet called *RTS* (Request To Send) piggybacking the ID of S, that of D and the expected duration of the data that S is going to transmit



Figure 5.13: Steps in the scenario considered for the handshaking

The RTS packet allows to all the terminals in the radio coverage of S, as the terminal A1 (exposed terminal), making themselves aware about their inclusion within the radio coverage of S. As A1, each terminal that hears the RTS, will postpone its access to the medium, therefore avoiding a potential collision

- 2. The recipient of the RTS message, the terminal D, will send a *CTS* (Clear To Send) packet to S in order to trigger to the data packet transmission of S. As the RTS, the CTS piggybacks the ID of S, of D and the expected duration of the transmission. Each terminal in the radio coverage of D that will hear the CTS, as A2 (hidden terminal), will postpone its eventual transmission, independently from the listening of the previous RTS. At this point, it is important to notice that, if some terminals as A1 (an exposed terminal) do not hear the CTS, they will can transmit without causing collision in D, just because of its absence in the radio coverage of D. Evidently, we can assert the previous state since we are supposing of working with a symmetrical channel, namely, if a terminal T1 can hear another terminal T2 then T2 can hear T1 and, vice versa, if T1 can not hear T1 then T2 can not as well
- After that S has heard the CTS, it can legitimately transmit its data packet. The collision on data packet is avoided by the fact that RTS and CTS, containing the expected duration of the data packet transmission, lead to a virtual carrier sense

Obviously, collisions can still occur but among RTS packets. This means that, in case of collision, no data packets will be corrupted and the channel will be uselessly busy for a short time, given that RTS packets are usually very short (20 Bytes).

#### 5.2.4. Out-Of-Band CA: BTMA

As said above, Out-Of-Band collision avoidance procedures do not use the data channel but employ a dedicated control channel in which to transmit information for managing the access to the medium. Typically, as we are going to show, these kinds of information are simply sinusoidal tones, therefore not implying an organization of the control information into packets. BTMA employs two channels: a message channel in which to transfer the data packets; a control channel, using a different carrier, employed for transferring the control information and whose denomination is *busy-tone channel*.

The concept on which it is based is quite simple: if a terminal T wants to transmit, it senses the busy-tone channel for a time  $t_d$  and, if it is detected as idle, is allowed transmitting. On the other hand, if the control channel is detected as busy, this means that in the data channel is occurring currently a data transmission implying to postpone the transmission of T.

Obviously, it is necessary a terminal that manages the busy-tone channel. In a network with centralized architecture it can be realized quite simply employing a Base Station. In fact, as soon as the base station senses the message channel as busy, it produces the tone on the busy-tone channel whose semantic is to hold back each other terminal willing to transmit.



Figure 5.14: Example of centralized architecture using BTMA protocol

Analogous address has validity for a network with distributed architecture but characterized by a centralized organization.

Conversely, more complex is the implementation of the protocol if both the architecture and the organization are distributed. In that case, the terminal willing to transmit hears the busy-tone channel for  $t_d$  and if it is detected busy, the terminal puts off its transmission. On the contrary, if the control channel is idle, the terminal turns on its busy-tone channel and transmits data on the message channel. Any other terminal that senses the message channel as busy switches on its busy-tone signal, leading to inhibit the transmissions of those terminals that are within a two-hop range from the transmitter.

Obviously in this way we are relieving the network from the hidden terminal issue but the terminals inhibited are more than those enough for a no collision transmission. In other words, in this way we are preventing collision with the drawback of amplifying the exposed terminal phenomena. This effect is displayed in the following figure.



Figure 5.15: Example of the amplification of the exposed terminal problem

We cite only the fact that the evolution of BTMA, Dual BTMA (DBTMA), employs two control channels for knowing of the state of a terminal, transmitter or receiver, leading to mitigate the exposed terminal effect.

## 5.3. Scheduled protocols and hybrid protocols

Without to enter in their particularity of implementation, we can say that, as common goal, scheduled access protocols allow to a terminal in the network knowing which terminals are currently transmitting, leading to avoid collisions between data packets in a contention less fashion. For a centralized architecture and for a distributed architecture with a centralized organization where it can be defined a controller (Base Station, Access Point), suitable protocols are:

- Polling. The controller "calls" one terminal at the time
- Demand Assignment. The controller assigns a message channel after a request
- Static. A resource (time, frequency, code) is statically assigned to a terminal when it joins to the network

In distributed architectures with distributed organization it can be possible adopt the token protocol.

The hybrid protocols merge the contention less approach of scheduled protocols with that contention based characterizing by random access protocols. A terminal which wants to transmit emits randomly a first data packet that piggybacks a reservation request. If it is received correctly by the destination, then the protocol guaranteed that, thanks to the previous reservation, the remaining packets will be received without collisions.

Examples of hybrid protocols are PRMA (reserves slots in a TDMA frames) and RRA-ISA (reserves slots in a polling sequence).

## 5.4. Examples of standardized MAC protocols

Often, in order to increase the efficiency of a protocol, many of the random access protocols above quoted are combined jointly. This can lead to fill the drawbacks that a protocol could present in its "solitary" implementation. In the following it will be shown with some example that, effectively, the standards used for MAC protocol provide this characteristic.

First of all, we will start showing the MAC of IEEE 802.11 standard (WiFi), namely DFWMAC. Then it will be described the IrDA MAC, that is IrLAP and, finally, a MAC protocol proposed for the UWB systems.

## 5.4.1. MAC protocol for 802.11 standard: DFWMAC

The original definition of the IEEE 802.11 standard included the following characteristics.

|                          | IEEE 802.11 Wireless LAN Standard                              |       |        |       |                            |       |  |
|--------------------------|----------------------------------------------------------------|-------|--------|-------|----------------------------|-------|--|
| Frequency                | 2.40                                                           | ЭНz   | 2.4GHz |       | Infra-red<br>(850mm~950mm) |       |  |
| Spread<br>Spectrum       | DSSS F                                                         |       | FH     | SS    |                            |       |  |
| Baseband<br>Modulation   | DBPSK                                                          | DQPSK | 2GFSK  | 1GFSK | 16-PPM                     | 4-PPM |  |
| Max<br>bandwidth         | 1Mbps                                                          | 2Mbps | 1Mbps  | 2Mbps | 1Mbps                      | 2Mbps |  |
| Access<br>Control        | Access<br>Control<br>Area(open<br>air/office) 100~300m/20~100m |       |        |       | S                          |       |  |
| Area(open<br>air/office) |                                                                |       |        |       | 20~30m/about 5m            |       |  |

Figure 5.16: Main characteristics of the 802.11 wireless LAN standard

Nowadays many successive versions has been developed in order to improve its characteristics:

- IEEE 802.11a. It reaches 54 Mbit/s using an OFDM modulation technique in the 5 GHz band. It holds the same MAC of 802.11
- IEEE 802.11b. It is the most diffused system and reaches 11 Mbit/s using the 2.4 GHz band with DSSS and FHSS modulation

- IEEE 802.11e. In the 5 GHz band as well, it employs an OFDM modulation. In order to manage opportunely real-time applications as audio and video streams, it introduces QoS mechanisms
- IEEE 802.11f. It is introduced an Interaccess Point Protocol by means of that to provide the possibility for the interconnection of access point of different brands
- IEEE 802.11g. It offers the same reachable bit rate of the 802.11a standard, namely 54 Mbit/s, in the same band and with the same modulation of the 802.11b standard (2.4 GHz, DSSS and FHSS). More over, it is assured backward compatibility with 802.11b
- IEEE 802.11h. It uses the 5 GHz band and, exploiting OFDM modulation, manages up to 54 Mbps. It allows a more suitable management of the spectral resources such as power control and dynamic frequency selection
- IEEE 802.11i. In the 5 GHz band, with OFDM modulation and managing at least 54 Mbps, it introduces security mechanisms as encryption and authentication
- IEEE / ETSI 802.11j. The spectral resource are allocated at 5 GHz, employing OFDM and GMSK modulation and leading to, at least, 54 Mbps. It represents the convergence of 802.11a and HiperLAN standards

The 802.11 standard foresees two distinct ways of multiple access:

- *Distributed Coordination Function (DCF)*. It is a distributed modality of access based on the *CSMA/CA* MAC protocol. We will concentrate our attention on it
- *Point Coordination Function (PCF)*. It is an optional centralized modality of access based on a mechanism of reservation and polling. We will not enter in its details

The DCF modality is based on a combination of CSMA and CA protocols (CSMA/CA). A mobile terminal using the DFWMAC can transfer a data packet in two different ways: 2-way and 4-way handshaking, both starting with the carrier sense procedure of CSMA on a slotted time axes.

In the 2-way handshaking a terminal T, that wants to transmit a packet, senses the channel for a time interval denominated *DIFS*. If T detects the channel as idle for a DIFS, then it transmits. Conversely, it waits until the channel become idle for a DIFS. At this time, for minimizing potential collisions with other terminals, any station waiting as T for its transmission, does not transmit immediately but begins the *backoff procedure*. It sets a random time interval and it is activated a countdown timer. The timer is:

- diminished until the channel remains idle
- frozen when the channel is detected as busy, because of another terminal having a lower backoff time
- restarted from the value to which it arrived when it was stopped, when the channel is afresh detected as idle for a DIFS

Finally, the terminal transmits when its backoff timer gets to zero.

Once the destination receives correctly the data packet, it waits for a *SIFS*, whose duration is lower than the DIFS length and sends to the transmitter an *ACK* whose semantic is to make it aware about the result of the communication. If the transmitter does not receive the ACK within a given time, it repeats its transmission following the same procedure described above.



Figure 5.17: Example of a 2-way handshaking in the DFWMAC

As in the 2-way handshaking, in the 4-way handshaking as well, a terminal T willing to transmit to a terminal D, first of all follows the carrier sense procedure as above described. After, it begins the handshaking:

- T transmits the RTS to D
- When D receives the RTS, it replies with a CTS after a SIFS
- The source can transmits its packet, after a SIFS as well
- Eventually, after a correct delivery of the data packet, D sends to S the ACK

As noted in the previous section, the RTS and CTS packets piggyback the information relative to the duration of the communication. This leads to a virtual carrier sense which is exploited by the other stations sensing the channel. In particular these terminals, when hear the RTS/CTS, refresh a *Net Allocation Vector* (*NAV*) containing the information regarding the duration in which the channel will remain busy.

For what said above, the 4-way handshaking is employed when the network scenario is affected by the hidden and exposed terminals issue leading to a better efficiency of the protocol respect to what obtained using the 2-way technique.



Figure 5.18: Example of a 4-way handshaking in the DFWMAC

When a data unit exceeds a given value, the protocol allows fragmenting it into multiple data units. In this case the protocol foresees a special transmission. The terminal that wants to transmit contends the channel by means of the backoff procedure. Obtained

the channel, it transmits sequentially the fragments in the way that, passed a SIFS from the reception of any ACK acknowledgmenting the previously packet, it emits the next packet.

One must notice that, because of the shorter duration of the SISF respect to the DIFS, in this way the remaining packets own a greater access priority. The packets sequentially transmitted piggyback:

- a number of sequence. It is equal for all the packets relative to a sequential transmission but is not the same between different sequential transmission
- a number of fragment. This numeration allows to the receiver reassembling the fragments, discarding possible duplicates

More over, data packets and ACK packets piggyback information relative to the expected duration of the next fragment.

When the transmitter does not receive an ACK of a fragment, it enters in the backoff procedure at the end of which, it restart its transmission beginning from the last packet unacknowledged.

The fragmentation technique can be combined with the 4-way handshaking. The RTS-CTS packets are transmitted only at the start of the sequence. The future fragments with the relative ACK will play the role of RTS and CTS. All the remaining procedure is identical to which above described.

## 5.4.2. MAC protocol for IrDA standard: IrLAP

The original definition of the *IrDA* (*Infrared Data Association*) standard included the following main characteristics.

|                       | IrDA Standard                               |  |  |  |  |
|-----------------------|---------------------------------------------|--|--|--|--|
| Wavelength            | 875 nm (with a tolerance around 30 nm)      |  |  |  |  |
| Baseband Modulation   | OOK (Zero Return with $T_P = 3/16T_{bit}$ ) |  |  |  |  |
| Distance              | Up to 1 mt                                  |  |  |  |  |
| Viewing Angle         | Between 15° and 30°                         |  |  |  |  |
| Rates Supported (bps) | 9600, 19200, 38400, 57600, 115200           |  |  |  |  |
| Access Control        | IrLAP                                       |  |  |  |  |

Table 5.1: Main characteristics for the IrDA LAN standard

To date they have been introduced addictions and improvements to the standard as, for example, the capacity to transmit at available rates up to tens of Mbps. This can be obtained modifying the physical layer *IrPHY* (*SIR*, *FIR*, *VFIR*, etc.). For example, in place of OOK, FIR uses a 4PPM as modulation scheme.



Figure 5.19: Rates available in the IrDA physical layer evolution

The IrDA data protocol stack is displayed in the following figure.



Figure 5.20: The IrDA architecture

The core of the IrDA architecture is constituted by *IrPHY*, *IrLAP* and *IrLMP*. *IrOBEX* is a protocol regarding the definitions for generic object exchange of an IrDAcompliant device. *IrLAN* is an IrDA specification for accessing to a LAN over an infrared medium. It allows a translation of protocol leading to a medium access that is a simplified version of the 802.11 MAC (DFWMAC) previously described. *IrCOMM* allows emulating serial and parallel port communications. Finally, *TinyTP* is the transport protocol used by the standard.

IrLAP is the MAC protocol of the stack. It has three distinct phases of operation: link initialization, nonoperational mode and operational mode.

The following figure displays the logical progression through the two modes above quoted.



Figure 5.21: IrLAP logical flow between nonoperational and operational mode

Let us consider a terminal A willing to connect itself to the network. In the link initialization phase the terminal A chooses a random address of 32 bits.



Figure 5.22: The discovery procedure in IrDA

Obtained its own address, the terminal A needs to know which terminal is within its field of view. Therefore, with reference to Figure 5.22, it broadcasts a discovery XID command frames marking the beginning of each slot. Every terminal that hears the discovery frame will choose randomly a slot in which to respond to A. In the case in Figure 5.22 the terminals labelled with B and C will respond respectively on the second and fourth slot. Finally, A acknowledges the discovery sending a discovery response frame. At the end of the discovery procedure A will know the addresses and other useful information about B and C and, vice versa, B and C will identify the terminal A. We should have to notice that, in the case under examination, for B and C no information is known about each other. In fact, because of the limited field of view, they are mutually hidden.

In the quite improbable case that two terminals chose identical addresses, an address conflict resolution procedure would be foreseen. The terminal that detects an address conflict starts the procedure sending, likewise the discovery procedure, an address resolution XID command to the terminal implicated in the conflict. This time, the communication interests only conflicting terminals. The station selects another address and responds in a slot chosen randomly. It is foreseen the repetition of the procedure in the unlikely case of a relapse in the address conflict.

Only for completeness we cite the sniff procedure, which is a special low-power connection procedure intended to support devices with power-critical modes of operation.

Once the discovery and address resolution processes are completed, the terminal A, willing to connect for example with the terminal B, sends to it a *SNRM* (Set Normal Response Mode) command frame. If B accepts the connection, it replies with a *UA* (Unnumbered Acknowledge) frame. The terminals are ultimately in operational mode and the connection is so established: A is the primary devices and B the secondary.



Figure 5.23: Connection establishment

Data exchange is performed in a master-slave mode, using a polling scheme in which the primary device sends command frames to the secondary device which responds with response frames.

Both terminals implicated in the communication can decided to disconnect. If it is the primary to wish it, it transmits a disconnect command to the secondary, which replies with an UA frame. Conversely, if the secondary desires to disconnect, it sends a request disconnect response to the primary, which responds with a disconnect command. At the end of this phase, both terminals are in disconnect mode and the medium is now available for any device willing to start the discovery, address resolution, or connection procedures.

Finally, reset is a command that, through a mutual agreement of the two stations, causes all counters and timers to be reset.

#### 5.4.3. UWB systems: MAC protocols for the standards 802.15.3 and 802.15.4

Because of the strong power emission constraints imposed by regulatory bodies, UWB is rising as a technology particularly suited for transmissions characterized either by a high bit rate over a short range, or by a low bit rate over a long range, to which respectively correspond the 802.15.3 and 802.15.4 standards.

In 802.11.3 the MAC domain is denominated piconet and it is managed by a *PicoNet Coordinator (PNC)*. When terminals wish to organize themselves into a network, they define a piconet to which can belong up to 256 terminals, each identified univocally by an address of 8 bits. One of those terminals is designed to be the PNC. The choice of the PNC depends on characteristics of the terminal such as maximum power level in transmission and maximum transmission rate. A terminal willing to join to the piconet listens the broadcast messages sent by the PNCs of several piconets and selects one of them. If it has PNC potentialities better than the pre-existent PNC, a special PNC handover procedure is foreseen for changing PNC.

All the operations of terminals belonging at the same piconet must follow a global timing given by a superframe defined by the PNC. The superframe contains the following three periods:

- *Beacon Period*. It is used by the PNC to broadcast information to all terminals within a piconet such as the *CTAs* in which to transmit in the next *CFP*
- *Contention Access Period* (*CAP*). In this period the terminals can demand to the PNC reserved Channel Time Allocations (CTAs) in a CSMA/CA fashion. CAP it also used by terminals for transmitting small amount of data to other terminals
- *Contention Free Period* (*CFP*). It is used for the transmissions of those terminals to which the PNC, using the beacon period, has granted CTAs in a TDMA fashion. It can be used also for controlling traffic during Managements CTAs (*MCTAs*)



Figure 5.24: Superframe used by PNC for the piconet global timing in 802.15.3 MAC

We must notice that, even though the PNC schedules CTAs accepting *Channel Time Request (CTR)* during the CAP, it is not involved in data packet exchange.

Finally, whereas the standard completely defines procedure for intra-piconet operations, it does not do the same for inter-piconet operations.

As regards the low bit rate/medium-to-long range case, the standardization process is quite recently and dates back to the first meeting, in May 2004, of the IEEE 802.15.4a Task Group. The 802.15.4 MAC protocol remembers the 802.15.3 MAC, having anyhow different nomenclatures and functionalities.

Its architecture is distributed with a centralized organization as well. The MAC domain, formed by a group of terminals, is called Personal Area Network (PAN) and it is manages by a coordinator which must be a FFD (Full Function Device). Two different types of devices are defined:

- *Reduced Function Device (RFD).* This kind of device contains a subset of the IEEE 802.15.4 features. The RFD cans only acts as a device in a network. Normally the RFD would be used for battery powered devices, since a device with a pure device capability is very power efficient. Examples of RFDs could be light switches and temperature sensors
- *Full Function Device (FFD)*. This device contains all of the IEEE 802.15.4 features. The FFD can acts in a network as device or coordinator. The FFD is targeted to be used for backbone powered devices. A FFD that takes on the role of coordinator uses significantly more power than a RFD in the device role and is more complex. Examples of FFDs could be light controllers with router capability (light bulbs) and PAN coordinators (main network controllers)

More over, the 802.15.4 MAC foresees two different topologies for a PAN: star topology and peer-to-peer topology. The terminals belonging to a PAN can be of three types: RFD, FFD and PAN Coordinator, which must be however a FFD.

A PAN (both star and peer-to-peer) can operate in either beacon mode or nonbeacon mode. In beacon mode, following a TDMA fashion, the coordinator within the PAN transmits synchronization frames (superframes) to its associated devices. All data transmissions occur, in a CSMA/CA fashion, in the Content Access Period (CAP), subdivided into *Time Slots (TS)*. As in 802.15.3, it is defined a Contention Free Period (CFP), used however for low-latency devices. Conversely by 802.15.3, it is an optional field.

|        | Contention Access Period<br>(CAP) |         |         |         |         |     |         | Contention-Free Period<br>(CFP) |          |
|--------|-----------------------------------|---------|---------|---------|---------|-----|---------|---------------------------------|----------|
| Beacon | TS<br>1                           | TS<br>2 | TS<br>3 | TS<br>4 | TS<br>5 | ••• | TS<br>n | GTS<br>1                        | GTS<br>2 |

Figure 5.25: Superframe used by a PAN Coordinator in 802.15.4 MAC (beacon mode)

In non-beacon mode data transmissions can take place at any time using CSMA/CA. Since in this mode there is not the need to define a slotted time axis, the functionalities of the beacon period are reduced to broadcast the ID of the PAN and to transmit information available to those devices willing to join to the PAN.

## 5.4.4. The (UWB)<sup>2</sup> MAC protocol

The (UWB)<sup>2</sup> protocol is specifically designed for low data rate networks. In the code assignment it uses a hybrid scheme, that is to say are employed in the communication either a common control channel, or a dedicated data channel, respectively identified by a common TH code and a transmitter TH code, which can be obtained directly by means of the MAC ID of the transmitter using appropriated algorithms.

As first step, in the next we are going to analyze the transmission procedure of a terminal T towards a terminal R.

The protocol foresees the following steps:

- 1. The terminal T periodically checks the transmission queue and, in the case it finds MACPDUs to transmit, it extracts the ID of the receiver from the PDU
- 2. T determines the overall number  $N_{PDU}$  of MACPDUs directed to the receiver R
- 3. If other MACPDUs has been sent to R in the last  $T_{ACTIVE}$  seconds, T considers R as an active receiver, and moves to the step 5 of the transmission procedure
- If R is not an Active receiver, T generates a *Link Establish PDU (LE PDU)*, which goal is to produce in the receiver R the relative *Link Confirm PDU* (*LC PDU*)
- The terminal T sends the LE PDU, using the Common TH code, and waits for the Link Confirm PDU of the receiver R
- 6. If the LC PDU is not received within the interval  $T_{LC}$  the terminal T tries again, coming back to the five point of the procedure. The retransmission of the LE PDU can occur maximum for  $N_{LC}$  times, after that the transmission is considered to be failed
- Having received the LC PDU from R, T transmits the DATA PDU using the TH code previously communicated in the LE PDU.
- 8. If the DATA PDU requires it, T waits for the ACK relative to the packet sent
- 9. If the ACK is not received by the terminal T, then it retransmits the same packet using a backoff scheme
- 10. On the contrary, got the ACK, T checks again if other packets directed to R are into the queue, in which case it starts again the procedure in order to transmit the next packet

In the following figures are shown the structures of the LE PDU, the DATA PDU and the flow chart of the transmission procedure.

The structure of the LE PDU is the following:



**Figure 5.26:** *Structure of the LE PDU in (UWB)*<sup>2</sup>

The fields have the following meaning:

- Sync Trailer is used to synchronize the terminals involved in the communication
- Rx Node ID is the MAC ID of receiver R
- Tx Node ID is the MAC ID of transmitter T. It can be associated univocally to the Transmission TH code
- TH-Flag is a flag set to true if the standard TH code associated to Tx Node ID is going to be adopted. The flag is instead set to false if a different TH code will be adopted
- TH-Code is an optional field used when the TH-Flag is set to false, in which case the information on the TH code to be adopted is provided in this field
- FEC/CRC is the field containing the bits for the error correction/revelation

The structure of the DATA PDU is the following:



**Figure 5.27:** *Structure of the DATA PDU in (UWB)*<sup>2</sup>

The fields have the following meaning:

• Sync Trailer is used to synchronize the terminals involved in the communication

- Header, including the fields Tx Node ID, Rx Node ID, *PDU<sub>Number</sub>* (identification number of the PDU) and *N<sub>PDU</sub>* (number of PDU currently in the queue)
- ACK flag communicates to the receiver R to answer with an ACK PDU to the DATA PDU sent
- Payload is the field containing the data information
- FEC/CRC contains the bits necessary for the error correction/revelation.

Finally, the flow chart of the transmission procedure is shown in the Figure 5.28.



**Figure 5.28:** Flow chart of the transmission procedure in  $(UWB)^2$ 

Having seen the procedure to follow by the terminal T, now we are going to look at the reception procedure, namely the steps that the receiver has to follow when it receives a PDU from the terminal T. Considering the case in which no broadcast packets are going to send, the protocol foresees the following points:

- The terminal R, which state is currently Idle, listens the common control channel, looking for its MAC ID. If it is not found, then the reception procedure ends. Vice versa, given that R is listening the common channel and no one broadcasting packet will be send, R has received a LE PDU from the terminal T
- 2. R generates and sends a LC PDU, which goal is to provide the availability to establish the link with T. R changes its state in active receiver and switches the code to the transmission TH code communicated by T in the LE PDU
- 3. If no data packets are received within the time  $T_{DATA}$  then R returns to the idle state and the reception procedure ends
- 4. Vice versa, receiving a DATA PDU, if the ACK flag is set to true, R generates the ACK PDU and sends it to T, reporting in the appropriate field the status of the reception. Moreover, if  $N_{PDU} > 0$  then R remains in the active state waiting for the remaining PDU whereas, if  $N_{PDU} = 0$ , then the whole reception is completed and R turns to the Idle state

In the following the structures of the LC PDU, the ACK PDU and the flow chart of the reception procedure are provided.

The structure of the LE PDU is the following:

| Sync Trailer | Rx Node ID | Tx Node ID | FEC/CRC |  |
|--------------|------------|------------|---------|--|
| x bits       | 64 bits    | 64 bits    | y bits  |  |

**Figure 5.29:** *Structure of the LC PDU in (UWB)*<sup>2</sup>
The fields have the following meaning:

- Sync Trailer is used to synchronize the terminals involved in the communication
- Rx Node ID is the MAC ID of receiver R
- Tx Node ID is the MAC ID of transmitter T. It can be associated univocally to the Transmission TH code
- FEC/CRC is the field containing the bits for the error correction/revelation.

The structure of the ACK PDU is the following:

| Sync Trailer | Rx Node ID | Tx Node ID | PDU <sub>Number</sub> | DATA<br>Status | FEC/CRC |  |
|--------------|------------|------------|-----------------------|----------------|---------|--|
| x bits       | 64 bits    | 64 bits    | 8 bits                | 4 bits         | y bits  |  |

**Figure 5.30:** *Structure of the ACK PDU in (UWB)*<sup>2</sup>

The fields have the following meaning:

- Sync Trailer is used to synchronize the terminals involved in the communication
- Rx Node ID is the MAC ID of receiver R
- Tx Node ID is the MAC ID of transmitter T
- *PDU*<sub>Number</sub> is the number of the DATA PDUs that R expects again from T
- FEC/CRC is the field containing the bits for the error correction/revelation.

Finally, the flow chart of the reception procedure is given in the Figure 5.31.



**Figure 5.31:** *Flow chart of the reception procedure in* (*UWB*)<sup>2</sup>

# **Chapter 6**

# Implementation of (UWB)<sup>2</sup> over an Optical

# System: Hardware's Design

### Contents

| 6.1 | Introduction                       | 94  |
|-----|------------------------------------|-----|
| 6.2 | Optical transmitter                | 95  |
| 6.3 | Optical receiver                   | 102 |
| 6.4 | Optical terminal                   | 105 |
| 6.5 | Optical system                     | 106 |
| 6.6 | Masters, slaves and relative EPLDs | 108 |

## **6.1. Introduction**

In this chapter we are going to expose the hardware architecture used for implementing the (UWB)<sup>2</sup> MAC protocol over optical links.

What we want to develop is an optical system formed by four terminals. At the physical layer each terminal can both transmit, and receive. Hence, at least as regards the physical layer, differences among them do not exist. At the MAC layer, two terminals are masters of the communication, and the remaining two are slaves. This choice was a hardware constraint related to the restricted resources of the EPLDs. The terminals transmit to a given data rates, using an OOK modulation and employing the (UWB)<sup>2</sup> MAC protocol. The presence of the interference between the slaves is ensured through the use in the masters of an array of two LEDs.

First of all, in order to allow in the future improvements and additions, in every step followed in the design of the system, it has been adopted a modular approach. To give an example, an OOK modulation has been chosen; anyhow any other kind of modulation technique can be added, without modifying the remaining architecture of the system.

Following this policy, the first step of the project consisted in the design of the optical part of the system. In particular this required to choose the LEDs to use, the photodiodes, the amplifiers, the comparators, and so on. More over, as we will see in the following of this chapter, its planning has been realized taking into account the specifications of interfacing of the EPLDs that "will contain" the protocol.

Once tested the good functioning of the physical layer, the  $(UWB)^2$  MAC protocol has been implemented using an appropriate EPLD<sup>3</sup>. To this end, the protocol has been developed and simulated, by means of the software *Max+Plus II*. Once verified its functioning in the case of a communication between two terminals, it has been tested working in a scenario characterized by four terminals, still through the software simulation. In order to evaluate the different behaviours of the protocol at different data rates, a set of tests has been performed, each characterized by a distinct data rate. The rates used in the testing belong to the interval [4 Kbps, 256 Kbps]. The simulation effectively emphasizes that as greater is the data rates, as worse is the throughput obtained.

Finally, the physical optical system has been constructed.

<sup>&</sup>lt;sup>3</sup> in terms of logical ports, number of inputs and outputs, needful to implement the protocol

## 6.2. Optical transmitter

The components chosen for the hardware design of the optical transmitter were an IRED L7558, from Hamamatsu and an AND gate, the CD74AC08 from Texas Instruments.

The IRED L7558 admits to manage, as input, signals until 50 MHz, allowing a radiant flux until 250 mW. The typical peak emission wavelength is 850 nm. More detailed characteristics can be found in its datasheet, attached in the annex AII.2.

The AND gate CD74AC08 is employed as circuit of excitation and gets as output the current to pass to the IRED, which finally will transmit the signal. Its datasheet is provided in the annex AII.1.

The circuital scheme of the optical transmitter is shown in the Figure 6.1 and has been designed through the software application Protel 99 SE.



Figure 6.1: Circuital scheme of the optical transmitter

The power supply provides an alimentation of 5 V; the stability of its line is managed by the three capacitors  $C_1 = C_3 = 100 \text{ nF}$ ,  $C_4 = 10 \mu \text{F}$ .

As said before, the physical interface between the original signal to transmit and the LED is constituted by the AND gate CD74AC08. Its output is passed to a circuit of preemphasis, which function consists in the addition of a peak of current to that of polarization coming from the resistor R\_2.

The polarization current, as said previously, proceeds from R\_2. Its value has been calculated taking into account that, willing to use a forward voltage of 1.55 V, it is

necessary to use a forward current of 100 mA, which finally leads to a radiant flux of 30 mW. Hence, for what said, the value of the resistor is calculated as:

$$I_F = \frac{V_{CC} - V_F}{R_2} = \frac{5 - 1.55}{R_2} = 100 \, mA \rightarrow R_2 = 34.5 \,\Omega.$$



FORWARD CURRENT (mA)

**Figure 6.2:** Some input-output characteristics of the LED L7558 useful to design the physical layer of the optical system

As regards the circuit of pre-emphasis, first of all it has been fixed the value of the capacitor, set equal to 15 pF. Secondly, taking into account that this circuit must not limit the rate of the system, it has been chosen a cut frequency equal to ten times that of the maximum working frequency, set to 512 KHz. Therefore, for what said, the value of the resistor R 1 is calculated as:

$$f_{cut} = 10 \cdot f_w = \frac{1}{2\pi \cdot R_1 \cdot C_2} \rightarrow (f_w = 512 \, Mhz, C_2 = 15 \, pF) \rightarrow R_1 = 530 \,\Omega$$



The appearance of a single optical transmitter is displayed in the following figure.

Figure 6.3: Physical appearance of the optical transmitter

Subsequently, both in order to increase the radiant flux at the receiver of the data, and to generate a perceptible and sufficient interference in the other receivers, an array of two LEDs has been designed and employed. To this end, it has been exploited the fact that the AND port has four outputs, two of which have been used.



Figure 6.4: Outputs of the AND Port CD74AC08 used for the LED array

The circuital scheme of the optical transmitter using the array of LEDs is shown in the Figure 6.5.



Figure 6.5: Circuital scheme of the optical transmitter using the array of two LEDs

The look of a single optical transmitter using the above described array is displayed in the following figure.



Figure 6.6: Physical aspect of the optical transmitter using the array of LEDs

As regards the transmitter, is interesting to point out some outputs of some circuits constituting it.

First of all, how seen above, the output of the AND gate CD74AC08 has to be TTL. Effectively, the following figure points out this nature of the signal.



Figure 6.7: Output of the AND gate CD74AC08

Secondly, in the design of the optical transmitter we employed a circuit of preemphasis. The following figure represents the signal obtained at the output of this circuit. How evident, its function is to filter the low frequency of the signal, so that the LED can respond better to it.



Figure 6.8: Output of the circuit of pre-emphasis

Finally, given that the final idea is to build an optical system formed by four terminals, two masters and two slaves of the communication, one LED of each master will be directed toward the photodiode of the relative slave and the other LED, whose output is exactly the same of the first LED (in particular, without phase displacement), will be focused on the photodiode of the slave not interested in the communication, generating in this way the wanted interference.



Figure 6.9: Block scheme of the physical optical system

The previous scheme, once realized via hardware, assumes the following aspect.



Figure 6.10: Hardware implementation of the block scheme represented in the Figure 6.9

## 6.3. Optical receiver

The components employed for the hardware design of the optical receiver were a photodiode S6468-02, from Hamamatsu, an amplifier, the MAX410 from Maxim, and a comparator, the LM360 from National semiconductor.

The S6468-02 is a Si PIN photodiode in which is already present a preamplifier and that can receive signals in input until 35 MHz. More detailed characteristics can be found in its datasheet, attached in the annex AII.3.

The amplifier MAX410, low noise and of 28 MHz of bandwidth, allow getting as output a signal whose amplitude, of 2-3 V, is such that the comparator can work properly. Its datasheet is given in the annex AII.4.

The high speed differential comparator LM360, whose datasheet is presented in the annex AII.5, is necessary to get a TTL signal, namely a signal which value is either 0 V or 5 V. This signal will be passed as input to the relative EPLD.

The circuital scheme of the optical receiver is shown in the Figure 6.11.



Figure 6.11: Circuital scheme of the optical receiver

The values of the resistors (R\_L, R\_1, R\_2, and R\_3) and of the capacitors (C\_B, C\_L, C, C\_1, C\_2, C\_3, and C\_4) can be directly got from the datasheets of the photodiode, of the amplifier and of the comparator.

The aspect of the optical receiver, without EPLD, is displayed in the following figure.



Figure 6.12: Appearance of the optical receiver

How done for the transmitter, now we are going to show some important output in the reception chain of the receiver.

First of all, after the acquisition of the optical signal by the photodiode and after to have removed the DC component through the capacitor C, the input to the amplifier is the following.



Figure 6.13: Input to the amplifier



The output of the amplifier, once set properly the trimmer<sup>4</sup>, is the following.

Figure 6.14: Output of the amplifier

How wanted, its output is greater than 1 V that is the minimum threshold at which the comparator can work.

The previous signal represents the input to the comparator. Anew, once adjusted the value of the trimmer, the output of the comparator is that displayed in the following figure. How manifest, its output is a TTL signal.



Figure 6.15: *Output of the comparator* 

<sup>&</sup>lt;sup>4</sup> in particular, without the amplifier goes in the non linear region

## 6.4. Optical terminal

In  $(UWB)^2$  the preliminary handshake between the master and the slave presupposes implicitly the dual capacity of transmitting and of listening the channel. This means in particular that, at the physical layer, the generic terminal has to possess jointly the hardware necessary for receiving and emitting signals.

For what said, without taking into account for now the hardware relative to the EPLD, each optical terminal used in the simulation will be constituted by the cohesion of the hardware characteristics presented in the section 6.2 and 6.3. The relative schematic obtained is shown in the Figure 6.16. The relative PCBs are presented in the Annex I.



Figure 6.16: Circuital scheme of the optical terminal

The physical aspect of the terminal is provided in the Figure 6.17.



Figure 6.17: Physical aspect of the optical terminal

# 6.5. Optical system

As said above, at the physical layer each terminal is formed by the same hardware characteristics. In particular, the physical transmitters are constituted by LEDs that are intrinsically directives. Hence, as shown above in the Figure 6.9, in order to get the reciprocal interference necessary to test the protocol, an opportune positioning of the emitters is needed. Let us denote the role of each terminal as follows.

| TERMINAL | ROLE      |
|----------|-----------|
| T1       | Master #1 |
| T2       | Master #2 |
| Т3       | Slave #1  |
| T4       | Slave #2  |

**Table 6.1:** Roles of the terminals involved in the simulations

The mutual dislocation employed is such that T3 and T4 are in visibility respectively with T1 and with T2; symmetrically, the terminals T1 and T2 are in visibility both with T3 and with T4. Effectively this is what represented in the Figure 6.9.

Finally, the following figure depicts the physical aspect of the optical system. Furthermore, the complete PCB's specifications are provided in the Annex I.



Figure 6.18: Physical aspect of the optical system

### 6.6. Masters, slaves and relative EPLDs

As stated in the section 6.3, the differential comparator LM360 is necessary to get a TTL signal that after will be passed to the EPLD. In fact, this is the nature of the signals that must be passed to the inputs of the EPLDs.

Even though the EPLD employed for the implementation of  $(UWB)^2$ , the Altera EPM9320ALC84-10, presents advanced features and a large amount of available resources, we had to simplify the logic of the protocol. To this end, we followed the next guidelines:

- to save and to economize the device's resources so that the protocol can fit to the EPLD
- to reduce the size of some field in order to: both to respect what above affirmed, and to manage in a simpler way the results of the simulations
- to remove the logical functionalities of some field that represents an option of implementation. In particular our choice was not to remove completely these fields from the packets, but rather to keep a single unused bit so that the VHDL code can be modified simply.

As remark, we can state that effectively, the changes introduced in the protocol implementation do not affect its original nature and its basic logic.

The changes and choices common to every packet defined by the protocol are the following:

- the fields "Tx Node ID" and "Rx Node ID" are reduced from 64 to 8 bits
- the "FEC/CRC" fields are not used. In any case, as said before, the fields have been kept and they get the length of y = 1 bit

The only modification interesting the LE packet is:

• the length of the "TH-Code" field has been chosen equal to 1 bit, rather than 16 bits. In fact, the PPM modulation is not used, and then no PPM code is needed The changes and choices associated to the DATA packet are:

- as length of the DATA field, it has been chosen the value M = 256 bits. As we are going to show, this value determines directly the data rate chosen for the simulations
- the fields "*PDU<sub>Number</sub>*" and "*N<sub>PDU</sub>*" get both a length of 1 bit, instead of 8 bits. This choice is motivated by the fact that we realized a pseudo-casual generator whose function is to generate pseudo-aleatorily a request to send a single data packet, no more, and only when the previous transmission is finished. This means to keep a queue containing maximum one packet. The Pseudo Random Number Generator (PRNG) adopted is shown in the annex AI.18 and it has been implemented through a shift register having 13 taps. This allows obtaining a number generated following a uniform distribution and whose value belongs to the interval [0, 8191]. This number indicated the clock cycles that the master will have to wait before to send its DATA packet. Given the distribution employed, chosen the clock frequency ( $f_{clk} = 512 KHz$ ) and the numbers of data bits (M = 256) and known the expected value of the uniform distribution ( $m_n^{(1)} = 4096$ ), the data rate is obtained as:

$$R_{data} = \frac{M}{m_n^{(1)} \cdot T_{clk}} = \frac{256}{4096 \cdot \frac{1}{512000}} = 32 \, Kbps \, .$$

As regards the ACK packet, we did the following modifications:

- the " $PDU_{Number}$ " field is constituted by 1 bit, rather than 8 bits
- the "DATA Status" field gets 1 bit, not 4 bits. In fact, in our implementation, this field keeps the only semantic of acknowledge positively or negatively the DATA packet

For the remaining fields, it has been chosen the original length and no further changes were made.

Moreover, and this time only because of "fitting reasons" into the EPLD, it was necessary to implement separately the logic of the master of the communication from that of the slave. This means that, whereas at the physical layer each terminal can transmit and receive packets, at the MAC layer a terminal is considered either a master or a slave of the communication. The corresponding roles were presented already in the Table 6.1.

Among the different fields defined by the protocol, some of those assumes a fixed value. How it is possible to verify directly through the codes presented in the Annex III, in our implementation we chose the following:

| N <sub>2</sub> 4, ID        | <i>Master</i> #1:     | Master #2:                                                           | Slave #1: | Slave #2: |  |  |  |  |  |  |  |  |  |
|-----------------------------|-----------------------|----------------------------------------------------------------------|-----------|-----------|--|--|--|--|--|--|--|--|--|
| Node ID                     | 35                    | 2B                                                                   | СА        | C1        |  |  |  |  |  |  |  |  |  |
| LE packet "Sync<br>Trail"   |                       | A2                                                                   |           |           |  |  |  |  |  |  |  |  |  |
| LC packet "Sync<br>Trail"   |                       | 8E                                                                   |           |           |  |  |  |  |  |  |  |  |  |
| DATA packet<br>"Sync Trail" |                       | 96                                                                   |           |           |  |  |  |  |  |  |  |  |  |
| ACK packet<br>"Sync Trail"  |                       | ED                                                                   |           |           |  |  |  |  |  |  |  |  |  |
| Payload                     | 96D49<br>96D49        | 96D496D496D496D4CACACACACACACACA<br>96D496D496D496D4CACACACACACACACA |           |           |  |  |  |  |  |  |  |  |  |
| * all the values are exp    | pressed in hexadecima | 1                                                                    |           |           |  |  |  |  |  |  |  |  |  |

**Table 6.2:** Values chosen for some fixed fields defined by the  $(UWB)^2$  protocol

As said before, the EPLD chosen for the implementation of  $(UWB)^2$  was the EPM9320ALC84-10. It is an EEPROM belonging to the Altera MAX 9000 family, the third generation of the Altera MAX architecture. It is fabricated with an advanced CMOS technology and between 84 pins, allows using totally 60 user pins. Actually, in our implementation, does not matter the total number of user pins, but the total resources of which the EPLD disposes. Regarding this aspect, the following table provides the main features of the EPLDs belonging to the family EPM9320.

| Feature                   | EPM9320<br>EPM9320A |
|---------------------------|---------------------|
| Usable gates              | 6,000               |
| Flipflops                 | 484                 |
| Macrocells                | 320                 |
| Logic array blocks (LABs) | 20                  |
| Maximum user I/O pins     | 168                 |

 Table 6.3: Main features of the EPLDs belonging to the family MAX 9320

A graphical representation of how the physical pins, both of the masters and of the slaves, will be connected electronically is provided in the following figures.

|                |     | R      |    | R  | R  |    |    | R  | R  | R  | R    |       |      | R   | R  | R  | R  |    | R  | R  | R  | R  |    |          |
|----------------|-----|--------|----|----|----|----|----|----|----|----|------|-------|------|-----|----|----|----|----|----|----|----|----|----|----------|
|                |     | Ε      | D  | Ε  | Ε  |    |    | Ε  | Ε  | Ε  | Ε    |       |      | Ε   | Ε  | Ε  | Ε  |    | Ε  | Ε  | Ε  | Е  |    |          |
|                |     | S      | A  | S  | S  |    |    | S  | S  | S  | S    |       |      | S   | S  | S  | S  |    | S  | S  | S  | S  |    |          |
|                |     | Ε      | T  | Е  | Е  | R  |    | Ε  | Е  | Е  | Ε    |       |      | Е   | Ε  | Ε  | Е  | U  | Е  | Е  | Е  | Е  |    |          |
|                |     | R      | A  | R  | R  | Е  |    | R  | R  | R  | R    |       |      | R   | R  | R  | R  | C  | R  | R  | R  | R  |    |          |
|                |     | U      | _  | V  | U  | S  | G  | V  | U  | U  | V    | C     | G    | U   | V  | U  | U  | C  | U  | V  | U  | U  |    |          |
|                |     | Ε      | R  | Ε  | Е  | Е  | Ν  | Ε  | Е  | Е  | Ε    | L     | Ν    | Ε   | Ε  | Е  | Ε  | Ι  | Е  | Ε  | Е  | Е  |    |          |
|                |     | D      | Х  | D  | D  | Т  | D  | D  | D  | D  | D    | К     | D    | D   | D  | D  | D  | 0  | D  | D  | D  | D  |    |          |
|                |     |        |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    |    | -  |          |
|                |     | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1     | 84   | 83  | 82 | 81 | 80 | 79 | 78 | 77 | 76 | 75 | 1  |          |
| KE2EKAED       | ! ] | 2      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 74 | 1  | REPERAED |
| GNU            | ! ! | 3      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 73 | 4  | KEZEKAED |
| VCCINI         | 11  | 4      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 72 | ÷  | GNU      |
|                | 11  | ,      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 71 | 1  | OCCINI   |
| IA_PHUKEI      | 11  | 0      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 70 | 4  | GNU      |
| KESERVED       |     | (<br>0 |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 60 | 4  | RESERVED |
| DESEDIIEN      | 11  | 0<br>0 |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 67 | ÷  | CND      |
| PACKET CORRECT | 1 2 | 7<br>0 |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 66 | ÷  | RESERVED |
| IICCINT        | 12  | 1      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 65 | ÷  | RESERVED |
| RESERVED       | 12  | 2      |    |    |    |    |    |    | F  | РМ | 9321 | GAL 1 | :84- | -10 |    |    |    |    |    |    |    | 64 | ÷  | UCCINT   |
| DATA TX        | 12  | 3      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 63 | ÷  | RESERVED |
| GND            | 12  | 4      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 62 | ÷  | RESERVED |
| GND            | 1 2 | 5      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 61 | ÷. | GND      |
| RESERVED       | 1 2 | 6      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 60 | i. | VCCIO    |
| RESERVED       | i 2 | 7      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 59 | i. | RESERVED |
| VCCINT         | i 2 | 8      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 58 | i. | RESERVED |
| N.C.           | i 2 | 9      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 57 | i. | VCCINT   |
| #TDO           | j 3 | 0      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 56 | i  | ^VPP     |
| RESERVED       | 3   | 1      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 55 | Ì. | #TMS     |
| RESERVED       | 3   | 2      |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    | 54 | Ì. | RESERVED |
|                | I_  | 33     | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42   | 43    | 44   | 45  | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 1  |          |
|                | -   |        |    |    |    |    |    |    |    |    |      |       |      |     |    |    |    |    |    |    |    |    |    |          |
|                |     | R      | R  | R  | R  | U  | R  | R  | R  | R  | #    | #     | R    | R   | R  | R  | G  | R  | R  | R  | R  | R  |    |          |
|                |     | Ε      | Ε  | Е  | Е  | C  | Ε  | Ε  | Е  | Ε  | т    | Т     | Ε    | Ε   | Ε  | Ε  | Ν  | Е  | Ε  | Ε  | Ε  | Е  |    |          |
|                |     | S      | S  | S  | S  | C  | S  | S  | S  | S  | D    | C     | S    | S   | S  | S  | D  | S  | S  | S  | S  | S  |    |          |
|                |     | E      | E  | E  | E  | I  | E  | E  | E  | Ε  | I    | к     | Ε    | E   | E  | E  |    | E  | E  | E  | E  | E  |    |          |
|                |     | R      | R  | R  | R  | 0  | R  | R  | R  | R  |      |       | R    | R   | R  | R  |    | R  | R  | R  | R  | R  |    |          |
|                |     | U      | U  | U  | U  |    | U  | U  | U  | U  |      |       | U    | U   | U  | U  |    | U  | U  | U  | U  | U  |    |          |
|                |     | E      | E  | E  | E  |    | E  | E  | E  | E  |      |       | E    | E   | E  | E  |    | E  | E  | E  | E  | E  |    |          |
|                |     | D      | D  | D  | D  |    | D  | D  | D  | D  |      |       | D    | D   | D  | D  |    | D  | D  | D  | D  | D  |    |          |

Figure 6.19: Graphical representation of the connections of the pins for the masters

|          |    | R      |          | R  | R   | R  |        | R  | R   | R    | R           |              |      | R          | R   | R  | R           |     | R  | R          | R  | R    |            |
|----------|----|--------|----------|----|-----|----|--------|----|-----|------|-------------|--------------|------|------------|-----|----|-------------|-----|----|------------|----|------|------------|
|          |    | E      | D        | Ε  | Ε   | Ε  |        | Ε  | Ε   | Е    | Ε           |              |      | Е          | Ε   | Ε  | Ε           |     | Ε  | Ε          | Ε  | E    |            |
|          |    | S      | A        | S  | S   | S  |        | S  | S   | S    | S           |              |      | S          | S   | S  | S           |     | S  | S          | S  | S    |            |
|          |    | E      | т        | Е  | Ε   | Ε  |        | Ε  | Ε   | Е    | Ε           |              |      | Е          | Ε   | Ε  | Ε           | V   | Ε  | Е          | Ε  | E    |            |
|          |    | B      | A        | R  | R   | R  |        | R  | R   | R    | R           |              |      | R          | R   | R  | R           | C   | R  | R          | R  | R    |            |
|          |    | U      | -        | V  | V   | V  | G      | V  | V   | V    | V           | C            | G    | V          | V   | V  | V           | C   | Ų  | V          | V  | U    |            |
|          |    | E      | R        | Е  | Е   | Е  | Ν      | Е  | Е   | Е    | Е           | L            | Ν    | Е          | Ε   | Е  | Е           | I   | Е  | Е          | Ε  | Е    |            |
|          |    | D      | Х        | D  | D   | D  | D      | D  | D   | D    | D           | К            | D    | D          | D   | D  | D           | 0   | D  | D          | D  | D    |            |
|          |    |        |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    |      | 2          |
|          | 1  | 11     | 10       | 9  | 8   | 7  | 6      | 5  | 4   | 3    | 2           | 1            | 84   | 83         | 82  | 81 | 80          | 79  | 78 | 77         | 76 | 75   | I.         |
| RESERVED | I  | 12     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 74   | RESERVED   |
| RESET    | ļ  | 13     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 73   | RESERVED   |
| VCCINT   | ļ  | 14     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 72   | GND        |
| VCCIU    | Į. | 15     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | /1   | UCCINI     |
| RESERVED | !  | 16     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 70   | GND        |
| RESERVED | ļ. | 17     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 69   | I RESERVED |
| GND      | ļ. | 18     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 68   | I RESERVED |
| RESERVED | ļ. | 19     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 67   | GND        |
| CUMPARE  | !  | 20     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 00   | I RESERVED |
| VUUINI   | !  | 21     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 65   | I RESERVED |
| RESERVED | ļ. | 22     |          |    |     |    |        |    | t   | :PMS | 7321        | JAL          | :84- | -10        |     |    |             |     |    |            |    | 64   | UCCINI     |
| DATA_IX  | ļ. | 23     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 63   | I RESERVED |
| GND      | ļ. | 24     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 62   | I RESERVED |
| GND      | ļ. | 25     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 61   | GND        |
| RESERVED | ļ. | 26     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 60   |            |
| REPERAED | ł. | 27     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 59   | I REPERAED |
| VCCINI   | !  | 28     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 58   | I REPERAED |
| N.U.     | !  | 29     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 57   | UCCINI     |
|          | ļ. | 30     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 50   |            |
| RESERVED | ł  | 31     |          |    |     |    |        |    |     |      |             |              |      |            |     |    |             |     |    |            |    | 55   |            |
| RESERVED | !  | 32     | <b>.</b> | ٥r | 0.Z | 07 |        |    | 1.0 | 6.4  | <b>1.</b> 0 | <b>I</b> . 0 |      | ь <b>г</b> | h.Z |    | <b>I</b> .0 | Ŀ.0 | га | <b>F</b> 4 | га | 54   | I KEZERAED |
|          | 1_ | 33     | 34       | 35 | 30  | 37 | 38     | 39 | 40  | 41   | 42          | 43           | 44   | 45         | 40  | 47 | 48          | 49  | 50 | 51         | 52 | 53 _ | .1         |
|          |    |        | P        | P  | P   |    | P      | P  | P   | P    | #           | #            | P    | P          | P   | P  | c           | P   | P  | p          | P  | p    |            |
|          |    | F      | F        | F  | F   | č  | F      | F  | F   | F    | т           | т            | F    | F          | F   | F  | N           | F   | F  | F          | F  | F    |            |
|          |    | 5      | 5        | 5  | 5   | c  | 5      | 5  | 5   | 5    | 'n          | ċ            | 5    | 5          | 5   | 5  | n           | 5   | 5  | 5          | 5  | 5    |            |
|          |    | F      | F        | F  | F   | ī  | F      | F  | F   | F    | ī           | ĸ            | F    | F          | F   | F  |             | F   | F  | F          | F  | F    |            |
|          |    | R      | P        | R  | R   | ĥ  | P      | R  | R   | R    | •           |              | R    | R          | R   | P  |             | P   | P  | R          | R  | R    |            |
|          |    | л<br>П | 1        |    |     | 0  | п<br>П |    |     |      |             |              |      |            |     | 1  |             | 1   | 1  |            |    |      |            |
|          |    | F      | F        | F  | F   |    | F      | F  | F   | F    |             |              | F    | F          | F   | F  |             | F   | F  | F          | F  | F    |            |
|          |    | D      | D        | D  | D   |    | D      | D  | D   | D    |             |              | D    | D          | D   | D  |             | D   | D  | D          | D  | D    |            |
|          |    |        |          | -  | -   |    | -      | -  | -   | -    |             |              | -    | -          | -   | -  |             | -   |    | -          |    | -    |            |

Figure 6.20: Graphical representation of the connections of the pins for the slaves

How it is possible to see directly in the two above figures, the user pins utilized for the masters and for the slaves are respectively those presented in the following tables.

| PIN NUMBER | LABEL I/O PORT |
|------------|----------------|
| 1          | CLK            |
| 7          | RESET          |
| 10         | DATA_RX        |
| 16         | TX_PACKET      |
| 20         | PACKET_CORRECT |
| 23         | DATA_TX        |

**Table 6.4:** User pins employed in to the EPLDs of the masters

| PIN NUMBER | LABEL I/O PORT |
|------------|----------------|
| 1          | CLK            |
| 10         | DATA_RX        |
| 13         | RESET          |
| 23         | DATA_TX        |

**Table 6.5:** User pins employed in to the EPLDs of the slaves

Both the EPLD of the masters and that of the slaves gets the CLK, common to the four terminals and whose frequency is  $f_{clk} = 512 \, KHz$ , in the pin number 1. For the clock it was employed the 5.0V TTL Clock Oscillator F1100E from FASTFOX, whose technical specifications are provided in the annex AII.6.

Similarly, both the masters and the slaves receive the pin number 10 and that number 23 respectively as input and output of the data. Thanks to the differential comparator LM360, the input DATA\_RX is a TTL signal.

The masters and the slaves get them reset respectively in the pin number 7 and in that number 13. The optical system presents two reset buttons: the first one is assigned to the pair master #1 – slave #1, the second to that master #2 – slave #2.

Moreover the masters present two outputs: the first one is TX\_PACKET, located at the pin number 16; the second, PACKET\_CORRECT, located at the pin 20. The output TX\_PACKET emits a rectangular waveform every time that a packet is transmitted. It will be used to measure the number of packets generated. The output PACKET\_CORRECT emits a rectangular waveform when a packet is received correctly by the slave, that is to

say when the ACK field contains a bit equal to "1". It will be used to count the number of packets received correctly.

The remaining pins can be divided in two families: those listed in the annex AII.7, namely the dedicated device pins, and those not used because not required by our implementation. As regards the first family, we can remember that the dedicated device pins are necessary to connect the GND, the alimentation and the pins that allow the insystem programmability (ISP) by means of the JTAG – interface (Joint Test Action Group).

The next figures represent the schematics of the EPLDs related to the two terminals belonging to the pair of terminals number 1, namely the master #1 and the slave #1. They were realized using PROTEL 99 SE and clarify what above exposed.



Figure 6.21: Schematic of the EPLD related to the master #1



Figure 6.22: Schematic of the EPLD related to the slave #1

Finally, all the schematics and all the PCBs designed are shown in the Annex I, the component's specifications are provided in the Annex II and the VHDL codes are presented in the Annex III.

Lastly, we wish to point out that the main board with the EPLDs has been only designed because of the very high cost of its physically realization (more than 1600  $\in$ ) resulting mainly by the absence in the stock of the EPLD chose for implementing the protocol, the EPM9320ALC84-10, whose price, a bit higher than 100  $\in$ , would have still allowed building the whole system. This lack leaded to chose, at least as potential change, the EPLD EPM9320ALC84-15 that, even if worse, has a price exceeding 300  $\in$ .

# Chapter 7

# Implementation of (UWB)<sup>2</sup> over an Optical

# System: Results

Contents

| 7.1 | Introduction                            | 118 |
|-----|-----------------------------------------|-----|
| 7.2 | (UWB)2: software implementation         | 118 |
| 7.3 | Optical System: hardware implementation | 134 |

### 7.1. Introduction

In this chapter we are going to expose the results obtained through the simulations of the (UWB)<sup>2</sup> protocol.

First of all, we will present the results achieved by means of the Max+Plus simulator. Regarding this point, several simulations have been realized. The aim of each simulation was to test the protocol working at different data rates, obtaining consequently both the total number of data packets transmitted by the masters, and the total number of packets correctly received by the slaves. In this way we could estimate the throughput of the net as:

$$Throughput = \frac{N_{CR}}{N_T} = \frac{\sum_{i=1}^{2} N_{CR}^i}{\sum_{i=1}^{2} N_T^i}$$

where  $N_{CR}$  is the total number of data packets correctly received by the slaves (namely  $N_{CR}^1 + N_{CR}^2$ ) and  $N_T$  the total number of data packets transmitted by the masters (that is to say  $N_T^1 + N_T^2$ ). Evidently, the above throughput is dependent from the data rate employed.

# 7.2. (UWB)<sup>2</sup>: software implementation

As said previously, the  $(UWB)^2$  protocol has been tested working at different low data rates. Those chosen for the simulations are: [256 Kbps, 128 Kbps, 64 Kbps, 32 Kbps, 16 Kbps, 8 Kbps, 4 Kbps]. At the physical layer the changing of the data rate has been achieved modifying in the masters architecture the length of the shift register used for implementing the PRNG. In particular, given that the PRNG generates pseudo-casually a number following a uniform distribution, we can state that for each PRNG employed, whose length is *N*, the data rate can be calculated as:

$$R_{data} = \frac{M}{m_n^{(1)} \cdot T_{clk}} = \frac{256}{\frac{2^N}{2} \cdot \frac{1}{512000}} bps = \frac{2^{18}}{2^N} \cdot 10^3 \, bps = 2^{18-N} \, Kbps$$

where *N* assumes the values [10, 11, 12, 13, 14, 15, 16]. To give a graphical example, the shift register with 13 taps is represented in the annex AI.18.

A remark to do now is that in our nomenclature we are distinguishing between data rate and bit rate. The data rate is what we have calculated using the above formula, that is to say the amount of information that a terminal wants to transmit in the time. With bit rate we are meaning the rate at which the above information is transferred into the channel, namely the clock rate that has been fixed to 512 KHz.

The throughputs obtained executing the simulations are presented in the Table 7.1.

As foreseeable, the throughput increases when the data rate decreases. This result can be explained thinking that when the data rate reduces, less packets are transmitted in a given interval time, and therefore the probability of collision between two packets diminishes as well, leading to an upper value of the throughput.

The table contains the Simulation Time Interval (STI) as well, namely the total duration time in which the system has been simulated. Given that a lower data rate means a smaller amount of DATA packets transmitted, it was necessary to increase the STI in order to obtain a sufficient number of exchanges of packets.

To end, further it has been calculated what we have called "partial throughput", namely the ratio:

Throughput = 
$$\frac{N_{CR}^{(i)}}{N_T^{(i)}}$$
,

where  $N_{CR}^{(i)}$  is the number of data packets correctly received by the slave number *i* and  $N_T^{(i)}$  is the total number of data packets transmitted by the master number *i*. This kind of measure has been performed only to ascertain that really the protocol assures a good degree of fairness in the medium access. Effectively examining the values in the table, it provides equality of obtaining the medium access.

The Figure 7.1 shows in a graphic the values of throughputs obtained vs. the data rates employed.

| DATA<br>DATA<br>PACKETS<br>CORRECTLY<br>CORRECTLY<br>RECEIVED IN<br>THE NET<br>DURING THE<br>STI | 404   | 393   | 576   | 762  | 609   | 518   | 062           |                          |
|--------------------------------------------------------------------------------------------------|-------|-------|-------|------|-------|-------|---------------|--------------------------|
| DATA<br>PACKETS<br>CORRECTLY<br>CORRECTLY<br>RECEIVED BY<br>THE SLAVE #2<br>DURING THE<br>STI    | 155   | 199   | 291   | 395  | 309   | 250   | 396           |                          |
| DATA<br>PACKETS<br>CORRECTLY<br>CORRECTLY<br>RECEIVED BY<br>THE SLAVE #1<br>DURING THE<br>STI    | 249   | 194   | 285   | 367  | 300   | 268   | 394           |                          |
| DATA<br>PACKETS<br>TRANSMITTED<br>IN THE NET<br>DURING THE<br>STI                                | 1682  | 755   | 839   | 888  | 661   | 536   | 792           |                          |
| DATA<br>DATA<br>PACKETS<br>TRANSMITTED<br>BY THE<br>MASTER #2<br>DURING THE<br>STI               | 770   | 381   | 423   | 458  | 335   | 259   | 397           | otocol                   |
| DATA<br>PACKETS<br>TRANSMITTED<br>BY THE<br>MASTER #1<br>DURING THE<br>STI                       | 912   | 374   | 416   | 430  | 326   | 277   | 395           | he (UWB) <sup>2</sup> pi |
| SIMULATION<br>TIME<br>INTERVAL<br>(STI)                                                          | 1 sec | 1 sec | 2 sec | 4sec | 6 sec | 9 sec | 20 sec        | mulation of th           |
| PARTIAL<br>THROUGHPUT<br>MASTER #2-<br>SLAVE #2                                                  | 0.2   | 0.52  | 0.688 | 0.86 | 0.92  | 0.97  | 0.997         | ve software si           |
| PARTIAL<br>THROUGHPUT<br>MASTER #L-<br>SLAVE #I                                                  | 0.273 | 0.52  | 0.685 | 0.85 | 0.92  | 76.0  | 0.997         | btained by th            |
| NET<br>THROUGHPUT                                                                                | 0.24  | 0.52  | 0.686 | 0.86 | 0.92  | 0.97  | <i>1</i> 66.0 | hroughputs o             |
| DATA RATE<br>(Kbps)                                                                              | 256   | 128   | 64    | 32   | 16    | 8     | 4             | Table 7.1: $T$           |



Figure 7.1: Throughputs Obtained Simulating the UWB<sup>2</sup> Protocol

Additionally, thanks to the graphical representation of the simulations provided by the Max+Plus simulator, it is really interesting to analyze the different situations that can occur during the development of the communication. Referring to the case in which the masters are transmitting with a data rate of 32 Kbps, in the following of this paragraph we are going to show some of those.

First of all, we are going to provide the graphical representation of the packets defined by the (UWB)<sup>2</sup> protocol: the LE packet, the LC packet, the DATA packet and the ACK packet.

Following this order, the next figures represent these packets, both for the first and for the second pair of terminals. These pictures allow getting a clearer visualization of each field contained in the above quoted packets. More over, we remember that their structures were provided respectively in the Figure 5.26, Figure 5.29, Figure 5.27 and Figure 5.30.



**Figure 7.2:** *LE and LC packets relative to both the pairs of terminals and obtained through the Max+Plus simulator* 



**Figure 7.3:** *DATA and ACK packets relative to both the pairs of terminals* 

Now, let us consider the whole communication of a data packet between, for example, the second pair of terminals: the master #2 and the slave #2. As known, in absence of errors the whole communication chain is constituted by the following packets: LE packet, LC packet, DATA packet and ACK packet<sup>5</sup>, in the chronological order of writing. The Figure 7.4 provides a graphical example of the above quoted exchange of packets. The master #1 does not transmit any packet during this time, whereas the master #2 sends a LE packet to the slave #2 in order to establish a connection. Subsequently, the LE packet is received both by the slave #1 and by the slave #2. Decoding the packet, the slave #1 becomes aware, through the Rx Node ID field, that the communication is not directed to him and then it follows to hear the channel. Vice versa, the slave #2 recognizes its ID and replies to it with a LC packet. Received and decoded this packet, the master #2 sends the DATA packet. Once more, the slave #1 receives the DATA packet too, passing over it as before. On the contrary, the slave #2 decodes the packet and, by means of the comparison of the DATA field received with that stored in its memory, becomes aware if errors are occurred. If so, it increases of one unity the variable "ERRORS 2", otherwise the variable increased is that measuring the total number of packets correctly received and decoded, namely "PACKET CORRECT2[0..9]". In the case that we are analyzing no error is occurred. Hence, the slave #2 replies with an ACK packet, acknowledging positively the DATA packet.

A further comment to do regards the presence of the counter "PACKET\_TX2". This variable, necessary for calculating the final throughput, is increased every time that the master #2 wants to send a DATA packet to the slave #2, that is to say when it transmits a LE packet.

As final observation, we point out that effectively what said until now is applicable symmetrically to the couple of terminals master #1 - slave#1.

The Figure 7.5 depicts again another situation in which no error occurs. The first couple of terminals realizes its communication with success and immediately after, the second pair performs its communication, without this last transmission interferes with the previous. The masters increase their "PACKET\_TX" variables just before to transmit the LE packet and they augment them "PACKET\_CORRECT" variables of one unity when the DATA packets are received correctly by the correspondent slaves (ACK bit set to "1").

<sup>&</sup>lt;sup>5</sup> The reader should remember that we chose to use the ACK packet by default



**Figure 7.4:** Example of exchange of the packets defined by the  $(UWB)^2$  protocol for the couple of terminal master #2 - slave #2


During the communication, many kinds of interferences can be detected, in the sense that the interfering packets can fall in distinct parts of the useful packets. The Figure 7.6 represents a situation in which the LE packet emitted by the master #2 interferes with the DATA field of the DATA packet sent by the master #1. After the LE – LC exchange between the first pair of terminals, the master #1 sends the DATA packet. While occurs this transmission, the master #2 sends its LE packet to the slave #2 and this generates a collision in the DATA packet, in particular just in the DATA field. After few bits, the slave #1 detects the errors and increases the errors counter, namely the variable "ERRORS\_1". Obviously, the relative ACK packet, sent by the slave #1, will contain an ACK bit equal to "0". Furthermore, the whole LE packet transmitted by the master #2 has been affected by the collision as well, meaning with this that the slave #2 will not be able to decode correctly the LE packet and therefore it will not send the LC packet to the master #2.





In the previous example the collision occurred in way that the slave #2 still could able to decode the header of the DATA packet. This means that it knew that a DATA packet was received, but affected by errors. Vice versa, the Figure 7.7 shows a situation in which the collision interests jointly the header of the DATA packet sent by the master #1 and that of the LE packet transmitted by the master #2. This means that not only the slave #2 will not be able to decode correctly the LE packet (and thus to establish the link), but additionally that the slave #1 will not be able to realize to have received a DATA packet and then it will not acknowledge the DATA packet, neither positively nor negatively.

Immediately after the end of the DATA packet the master #2 tries to establish the link for sending a DATA packet to the slave #2 and, because of the absence of interference, the whole communication gets a positive outcome.



A very interesting situation is that pictured in figure 7.8. Both the masters want to transmit a DATA packet but the first to send a LE packet is that number 2. Obviously, this packet is not affected by interference. Subsequently and almost simultaneously, the master #1 sends its LE packet to the slave #1 and the slave #2 replies with a LC packet to the master #2. Once again, these packets do not interfere between themselves. In fact, with reference to the Figure 6.9, in the case in analysis any collision can occur neither at the receiver of the slave #1 (that can hear packets of the type LE and DATA coming from any master), nor at the receiver of the master #2 (that can hear packets of the type LC and ACK coming from any slave). This means that both the slave #1 and the master #2 will succeed in decoding the packets to them addressed.

After, and still almost simultaneously, the slave #1 replies to the master #1 with a LC packet and the master #2 starts to transmit its DATA packet. Anew and for the same reasons above exposed, no collision occurs between this LC packet and the first part of the DATA packet sent by the master #2.

Hence, for what said until now and with reference to the figure 7.8, the part do not affected by collision is that contained in the blue box.

Approximately after the instant 706.3 ms the collision between the DATA packets takes place, but with different effects for the slaves. While the initial part of the DATA packet transmitted by master #2 and decoded by the slave #2 is sufficient to understand the nature of the current packet (namely that it is a DATA packet coming from the master #2 and directed to the slave #2), the whole header of the DATA packet sent by the master #1 is affected by the collision, not allowing to recognize therefore the DATA packet. What said leads to two consequences: the slave #2 detects with errors the DATA packet addressed to itself and then acknowledges it with an ACK packet with the ACK bit set to "0"; the slave #1 does not recognize the DATA packet directed to itself and therefore does not send the ACK packet.

Lastly, the Figure 7.9 depicts a set of sequential exchanges of packets, some affected by collisions, others not.





#### 7.3. Optical System: hardware implementation

As seen in the Chapter 6, the optical system is constituted by four terminals, divided in two groups: master #1 - slave #1 and master #2 - slave #2 and each communication of a couple of terminals interferes with the other. To check the functioning of the system we chose to use a function generator for each pair of terminals. The following figures show the operative context in which the system was checked.



Figure 7.10: Operative context of work in the laboratory



Figure 7.11: A visual particularity of the Figure 7.10



Figure 7.12: An other visual particularity of the Figure 7.10

In the following of this paragraph we are going to display some pictures representing the four signals implicated in the communication between the terminals. The pictures was taken out through the digital oscilloscope DS06104A of Agilent Technologies. Additionally, we decided to switch off the second LED of the terminal #1 with the purpose to not generate interference in the terminal #4, in way to take this terminal as reference for the others terminals<sup>6</sup>.

To start, the following figure represents a situation of absence of interference. How it is clear, every terminal gets an output of kind TTL, that is to say a signal whose value is 0V or +5V. Moreover, the working frequency is, as wanted, of 512 KHz.



Figure 7.13: Signals obtained at the output of the terminals in absence of interference

A second situation is that pictured in the Figure 7.14. This time the terminals #1 and that number 3 are affected by interference. As evident comparing the waveform in green (terminal 2) with that purple (terminal 4, of reference), the transmission of the terminal #3 does not affect the reception of the terminal #2.

<sup>&</sup>lt;sup>6</sup> for the numerical reference of the terminals, see the Figure 6.18



Figure 7.14: A first situation in which the terminals begin to be affected by interference

The Figure 7.15 shows an other situation in which the interference begins to be quite strong, at least for the terminals #1 and 3. Once again the terminal #2 is not affected by interference. Moreover we want to point out that this time the effects of the interference is strongest; for example the time duration of the high level (+5V) of the yellow signal is extended and the waveform of the terminal #3 is almost completely damage.

To end, the Figure 7.16 and Figure 7.17 depict two situations in which the interference is begun very strong, affecting all the communications of the terminal number 1, 2, 3. The terminal #4 continues to be of reference, maintaining as output a TTL signal with a repetition period of 512 KHz.



Figure 7.15: A second situation in which the interference begins to be noticeable



Figure 7.16: A third situation in which the interference affects strongly each terminal



Figure 7.17: A fourth situation in which the interference affects strongly each terminal

# **Chapter 8**

## **Bibliography and Web Pages**

Contents

| 8.1 | Bibliography | 142 |
|-----|--------------|-----|
| 8.2 | Web Pages    | 145 |

#### 8.1. Bibliography

- [1] S. Barbarossa, "Multi-antenna systems", 2004.
- [2] M. Cavagnaro, Lectures of "Environmental Impact of Electromagnetic Fields", University of Rome "La Sapienza", April – June 2004.
- [3] M.G. Di Benedetto, Lectures of "Wireless Access", University of Rome "La Sapienza", October – December 2004.
- [4] M.G. Di Benedetto, Lectures of "Optical Transmission", University of Rome "La Sapienza", April – June 2004.
- [5] C. Mencuccini, V. Silvestrini, "Physics II", Liguori, 1998.
- [6] A.V. Oppenheim and R. W. Schafer, "Discrete-Time Signal Processing", Prentice-Hall, 1989.
- [7] G. Columpsi, M. Leonardi, A. Ricci, "UMTS, Techniques and Architecture for Multimedia Mobile Communication Network", Hoepli, 2003.
- [8] Thomas L. Floyd, "Fundamentos de Sistemas Digitales", 7<sup>a</sup> edición, Prentice-Hall, 2000.
- [9] M.G. Di Benedetto and G. Giancola, "Understanding Ultra Wide Band Radio Fundamentals", Prentice-Hall, 2004.
- [10] Altera, "Max+Plus II getting Started", 1997.
- [11] National Semiconductors, "National Operational Amplifiers Databook", 1995.
- [12] "Introductory Tutorial, Exploring Protel 99 SE".

- [13] Manuel Torres, "Diseño e ingenieria electrónica asistida sobre PROTEL", Ra-Ma, 2000.
- [14] C-MAC Frequency Products, "Crystal Product Data Book 2000".
- [15] Freescale Semiconductor, "802.15.4 MAC PHY Software, User's Guide", 2005.
- [16] Santiago T. Pérez Suárez, "Sistema de comunicación fhss síncrono para ccoo no guiadas", Universidad de Las Palmas de Gran Canaria, 2002.
- [17] Luca De Nardis, "Location-Aware, Power-Efficient MAC and Routing Strategies for UWB Wireless Communications", University of Rome "La Sapienza", 2004.
- [18] A. E. García Braun, J. A. Rabadán Borges, M. Á. Bacallado Marrero y R. Pérez Jiménez, "Sistema de comunicación óptica no guiada basado en tecnología IrDA y técnicas DSSS", July 2005.
- [19] I. Millar, M. Beale, B. J. Donoghue, K. W. Lindstrom, S. Williams, "The IrDA Standards for High-Speed Infrared Communications", The Hewlett Packard Journal, 1998.
- [20] Andrea J. Goldsmith, Stephen B. Wicker, "Design Challenges for Energy-Constrained Ad Hoc Wireless Networks", IEEE Wireless Communication, August 2002.
- [21] V. Bharghavan et Al., "MACAW: A Media Access Protocol for Wireless LANs" Proc. ACM SIGCOMM '94, pp. 212-225, Aug. 1994.
- [22] K. K. Wong, Tim O'Farrell, "Spread Spectrum Techniques for Indoor Wireless IR Communications", IEEE Wireless Communication, pp. 54-63, April 2003.

[23] Maria-Gabriella Di Benedetto, Luca De Nardis, Matthias Junk and Guerino Giancola, : "(UWB)<sup>2</sup>: Uncoordinated, Wireless, Baseborn Medium Access for UWB Communication Networks", 2005.

### 8.2. Web Pages

#### General information

| [URL I]   | http://www.irda.org                          | IrDA            |
|-----------|----------------------------------------------|-----------------|
| [URL II]  | http://www.sss-mag.com                       | Spread Spectrum |
| [URL III] | http://hyperphysics.phy-astr.gsu.edu/hbase/h | frame.html      |
| [URL IV]  | http://datasheetarchive.com/                 | Datasheets      |
| [URL V]   | http://www.uwbinsider.com/                   | UWB             |

### **Official Organisms**

| [URL VI]   | http://www.acit-canarias.org               | IEEE            |
|------------|--------------------------------------------|-----------------|
| [URL VII]  | http://www.fcc.gov/                        | FCC             |
| [URL VIII] | http://www.ntia.doc.gov/                   | NTIA            |
| [URL IX]   | http://www.etsit.ulpgc.es                  | Escuela Técnica |
|            | Superior de Ingenieros de Telecomunicación | (ULPGC)         |

#### **Component's Searchers**

| [URL X]   | www.chipcenter.com | ChipCenter |
|-----------|--------------------|------------|
| [URL XI]  | www.techonline.com | TechOnline |
| [URL XII] | www.icmaster.com   | IC Master  |

#### Manufacturer

| [URL XIII] | http://www.altera.com   | Altera         |
|------------|-------------------------|----------------|
| [URL XIV]  | http://www.analog.com   | Analog Devices |
| [URL XV]   | http://www.hamamatsu.es | Hamamatsu      |
| [URL XVI]  | https://maxim-ic.com    | Maxim          |

#### Component's Supplier

| [URL XVII]  | http://www.lopacan.com | Lopacan |
|-------------|------------------------|---------|
| [URL XVIII] | http://www.amidata.es  | RS      |
| [URL XIX]   | http://www.farnell.com | Farnell |

## **Annex I. Schematics and PCBs**

#### Contents

.

| AI.1  | Schematic of the optical transmitter 149                             |
|-------|----------------------------------------------------------------------|
| AI.2  | Schematic of the optical receiver 151                                |
| AI.3  | Schematic of the optical terminal 153                                |
| AI.4  | Schematic of the EPLD relative to the master number one              |
| AI.5  | Schematic of the EPLD relative to the master number two 157          |
| AI.6  | Schematic of the EPLD relative to the to the slave number one        |
| AI.7  | Schematic of the EPLD relative to the to the slave number two        |
| AI.8  | Schematic of the EPLDs of the optical system                         |
| AI.9  | PCB of the optical transmitter 165                                   |
| AI.10 | PCB of the optical receiver                                          |
| AI.11 | PCB of the optical terminal                                          |
| AI.12 | PCB of the optical system 177                                        |
| AI.13 | PCBs of the EPLDs of the optical system 183                          |
| AI.14 | Schematic of the drive logic of the master number 1 and number 2 189 |
| AI.15 | Schematic of the drive logic of the slave number 1 and number 2 191  |
| AI.16 | Schematic of the 4 taps shift register                               |
| AI.17 | Schematic of the 16 taps shift register 195                          |
| AI.18 | Schematic of the Pseudo Random Number Generator 197                  |
| AI.19 | Schematic of the optical system used in the software simulation      |



## AI.1. Schematic of the optical transmitter



## AI.2. Schematic of the optical receiver



## AI.3. Schematic of the optical terminal



AI.4. Schematic of the EPLD relative to the master number one



AI.5. Schematic of the EPLD relative to the master number two



AI.6. Schematic of the EPLD relative to the slave number one



#### AI.7. Schematic of the EPLD relative to the slave number two


# AI.8. Schematic of the EPLDs of the optical system

### AI.9. PCB of the optical transmitter





### AI.10. PCB of the optical receiver





### AI.11. PCB of the optical terminal











179



#### AI.13. PCBs of the EPLDs of the optical system









AI.14. Schematic of the drive logic of the master number 1 and number 2



AI.15. Schematic of the drive logic of the slave number 1 and number 2







## AI.17. Schematic of the 16 taps shift register



#### AI.18. Schematic of the Pseudo Random Number Generator




# **Annex II. Components's Specifications**

## Contents

| AII.1        | Technical specifications of the quad 2-input AND gate CD74AC08  | 202 |
|--------------|-----------------------------------------------------------------|-----|
| AII.2        | Technical specifications of the Infrared LED L7558 series       | 203 |
| AII.3        | Technical specifications of the Si PIN photodiode S6468 series  | 205 |
| AII.4        | Technical specifications of the Amplifier MAX410                | 207 |
| AII.5        | Technical specifications of the Differential Comparator LM360   | 222 |
| AII.6        | Technical specification of the 5.0V TTL Clock Oscillator F1100E | 230 |
| <b>AII.7</b> | Altera MAX 9000 programmable logic device family data sheet     | 231 |
| <b>AII.8</b> | Altera device package information for EPM9320ALC84-10           | 239 |

## AII.1. Technical specifications of the quad 2-input AND gate CD74AC08



Data sheet acquired from Harris Semiconductor SCHS226

September 1998

:

### Features

- Buffered Inputs
- Typical Propagation Delay
- 4.3ns at  $V_{CC}$  = 5V,  $T_A$  = 25°C,  $C_L$  = 50pF
- Exceeds 2kV ESD Protection MIL-STD-883, Method 3015
- SCR-Latchup-Resistant CMOS Process and Circuit Design
- Speed of Bipolar FAST™/AS/S with Significantly Reduced Power Consumption
- Balanced Propagation Delays
- AC Types Feature 1.5V to 5.5V Operation and Balanced Noise Immunity at 30% of the Supply
- ±24mA Output Drive Current
  - Fanout to 15 FAST™ ICs
  - Drives 50  $\Omega$  Transmission Lines

### Pinout





### **Quad 2-Input AND Gate**

### Description

The CD74AC08 and CD74ACT08 are quad 2-input AND gates that utilize the Harris Advanced CMOS Logic technology.

### **Ordering Information**

| PART<br>NUMBER | TEMP.<br>RANGE ( <sup>o</sup> C) | PACKAGE    | PKG.<br>NO. |
|----------------|----------------------------------|------------|-------------|
| CD74AC08E      | -55 to 125                       | 14 Ld PDIP | E14.3       |
| CD74ACT08E     | -55 to 125                       | 14 Ld PDIP | E14.3       |
| CD74AC08M      | -55 to 125                       | 14 Ld SOIC | M14.15      |
| CD74ACT08M     | -55 to 125                       | 14 Ld SOIC | M14.15      |

### NOTES

- When ordering, use the entire part number. Add the suffix 96 to obtain the variant in the tape and reel.
- Wafer and die for this part number is available which meets all electrical specifications. Please contact your local sales office or Harris customer service for ordering information.

### Functional Diagram



### TRUTH TABLE

| INP | OUTPUTS |   |  |
|-----|---------|---|--|
| nA  | nA nB   |   |  |
| L   | L       | L |  |
| Н   | L       | L |  |
| L   | н       | L |  |
| н   | н       | н |  |
|     |         |   |  |

CAUTION: These devices are sensitive to electrostatic discharge. Users should follow proper IC Handling Procedures. FAST™ is a Trademark of Fairchild Semiconductor. Copyright © Harris Corporation 1998

File Number 1950.1

# LED Infrared LED LADSEADSABCEDIS High-speed, high-power infrared LED for spatial light transmission LADSEADSA Section States arise infrared LEDs were developed for spatial light transmission of high-density information such as image data signals, and operate at the speeds of SMHz. LYSS delivers high output of HamW and is used in combination with a light projection lens that matches the application. LYSSs-01 is sealed in a metal package capped with a glass lens that ensures narrow directivity of ±7 (full angle at half maximum). Metal stem package gives LYSSs and LYSSS haves the proved developed devices. Entere Applections Mign adiant output prover: Ligh adiant output prover: LYSSS (14 mWTyp) (IF=50 mA): Lystem transmission LYSSS (14 mWTyp) (IF=50 mA): Lystem transmission

# AII.2. Technical specifications of the Infrared LED L7558 series

| Parameter             | Symbol | Condition                             | Value         | Unit |
|-----------------------|--------|---------------------------------------|---------------|------|
| Forward current       | IF     |                                       | 100           | mA   |
| Reverse voltage       | VR     |                                       | 5             | V    |
| Pulse forward current | IFP    | Pulse width =10 µs<br>Duty ratio =1 % | 1.0           | А    |
| Operating temperature | Topr   |                                       | -30 to +85    | °C   |
| Storage temperature   | Tstg   | S                                     | -40 to +100 * | °C   |
| Storage temperature   | Taty   |                                       | -40 10 + 100  | _    |

\* Guaranteed to resist temperature cycle test of up to 5 cycles.

### Electrical and optical characteristics (Ta=25 °C)

High reliability

|                          | Symbol | 0                   | L7558 |      |      | L7558-01 |      |      | 1000               |
|--------------------------|--------|---------------------|-------|------|------|----------|------|------|--------------------|
| Parameter                |        | Condition           | Min.  | Typ. | Max. | Min.     | Typ. | Max. | Unit               |
| Peak emission wavelength | λp     | IF=50 mA            | 820   | 850  | 880  | 820      | 850  | 880  | nm                 |
| Spectral half width      | Δλ     | IF=50 mA            | -     | 50   | -    | -        | 50   |      | nm                 |
| Forward voltage          | VF     | IF=50 mA            | -     | 1.45 | 1.60 | -        | 1.45 | 1.60 | v                  |
| Pulse forward voltage    | VFP    | IF=1 A              | -     | 3.4  | 4.3  |          | 3.4  | 4.3  | V                  |
| Reverse current          | IR     | V <sub>R</sub> =5 V |       | -    | 10   | -        | -    | 10   | μA                 |
| Radiant flux             | фе     | IF=50 mA            | 11    | 14   | -    | 5.5      | 7.0  | -    | mW                 |
| Radiant illuminance      | PE     | IF=50 mA            | -     | 1.5  | -    | -        | 4.0  |      | mW/cm <sup>2</sup> |
| Cut-off frequency        | fc     | IF=50 mA ± 1mAp-p   | 35    | 50   | -    | 35       | 50   | -    | MHz                |

STATE

### HAMAMATSU



## Infrared LED L7558 series

Information furnished by HAMAWATSU is ballaved to be railable. However, no responsibility is assumed for possible inaccuracies or ornissions. Specifications are subject to change without notice. No patent rights are granted to any of the circuits described herein. @2001 Hamamatsu Photonics K.K. 5U AT

HAMAMATSU PHOTONICS K.K., Solid State Dhilsion Specificatione are subject to charge without notice. No patent rights are granted to any of the circuits described herein. 402011 Hamamats HAMAMATSU PHOTONICS K.K., Solid State Dhilsion 1126-1 Ichino-cho, Hamamatsu City, 435-8558 Japan, Telephone: (81) 053-434-3311, Fax: (81) 053-434-5184, http://www.hamamatsu.com U.S.A: Hamamatsu Corporation: 360 Foothal Road, PO.Bixx 5010, Bridgewater, N.J. 08807-0010, U.S.A., Telephone: (1) 008-231-0060, Fax: (1) 008-231-1218 Germany: Hamamatsu Photonics Deutonian Grabit. Arzbrogenist: 10, D-82211 Hermoning am Ammense, Germany, Talephone: (40) 06152-3750, Pax: (40) 06152-3558 France Hamamatsu Photonics Deutonian Grabit. B, Rue do Bailia Trapu, Fare du Mouti de Baisy, DifeBC Massy Cedex, Fance, Talephone: (40) 06152-375, Pax: 341) 60 537 1 00 United Kingdom: Hamamatsu Photonics UK Umited: El Howard Court, 10 Town Road, Weiwyn Gardian (1), Hertforthrina. AZ 16W, United Kingdom, Telephone: (41) 1707-324888, Rex: (44) 1707-324888, Re

Cat. No. KLED1009E02 Apr. 2001 DN

# AII.3. Technical specifications of the Si PIN photodiode S6468 series



- Cut-off frequency (Vcc=5 V) S6468 : 15 MHz S6468-02: 35 MHz
   Low noise (f=1 MHz)
- Low holse (t=1 MHz) S8468 : 25 nVrms/Hz<sup>1/2</sup> S8468-02: 28 nVrms/Hz<sup>1/2</sup>
- 3 pin TO-18 package
- Active area: \$0.8 mm

- Video signal transmission
- Optical disk pick-up

### Electrical and optical characteristics [Ta=25 °C, Vcc=5 V, RL=500 Ω, CL=13 pF] <sup>\*1</sup>

| D                                                 | Combell.  | 0                                     | Condition S6468 |             |              | S6468-02  |             |              | 11-8                |
|---------------------------------------------------|-----------|---------------------------------------|-----------------|-------------|--------------|-----------|-------------|--------------|---------------------|
| Parameter                                         | Symbol    | Condition                             | Min.            | Тур.        | Max.         | Min.      | Тур.        | Max.         | Unit                |
| Spectral response range                           | λ         |                                       |                 | 320 to 1060 | 1            | 1         | 320 to 1000 | )            | nm                  |
| Peak sensitivity wavelength                       | λρ        |                                       | -               | 900         | -            | -         | 800         | -            | nm                  |
| 8.80 (P.C.S.)                                     | 2 · ··· 3 | λ=660 nm                              |                 | 13.5        | <u>ି</u> - ୍ | 1 A 1     | 8.5         | 0.70         | 8                   |
| Photo sensitivity                                 | S         | ),=780 nm                             | -               | 15.5        | -            | -         | 11          | -            | mV/µW               |
|                                                   |           | λ=830 nm                              |                 | 16.5        | 3 - J        | 1 . J     | 11          | 1000         |                     |
| Trans-impedance                                   | RT        |                                       | -               | 30          | -            | -         | 20          | -            | kΩ                  |
| Power supply current                              | loc       | RL=00                                 | 5 <u>2</u> 8    | 2.20        | 3            | 8 - 9 - 8 | 14 3        | 3            | mA                  |
| Output bias voltage *2                            | Vo        | RL=∞<br>Pin=0 µW                      | 0.55            | 0.65        | 0.8          | 0.65      | 0.8         | 0.9          | v                   |
| Temperature coefficient of<br>output bias voltage | 1928      |                                       | 14              | -2          | 27           | 2         | -2          | 823          | mV/<br>℃            |
| Cut-off frequency                                 | fc        | Pin=10 µW 3                           | 12              | 15          |              | 28        | 35          | -            | MHz                 |
| Maximum output voltage<br>amplitude               | -         | Nonlinear<br>distortion:<br>10 % Max. | 0.5             | -           | -            | 0.5       | -           | (14)<br>(14) | Vp-p                |
| Output impedance                                  | Zo        | f=5 Hz                                | -               | 30          | -            | -         | 30          | · - ·        | Ω                   |
| Output noise voltage                              | Vn        | Pin=0 µW<br>f=1 MHz                   | -               | 25          | -            | -         | 28          | -            | nV/Hz <sup>10</sup> |
| Overshoot                                         |           | Pin=10 µW 3                           | -               | -           | 10           | -         | -           | 10           | %                   |

### Absolute maximum ratings

| Parameter               | Symbol | Min. | Max. | Unit |
|-------------------------|--------|------|------|------|
| Power supply voltage "4 | Voc    | -0.5 | 7    | V    |
| Power dissipation       | Р      | -    | 300  | mW   |
| Operating temperature   | Topr   | -20  | 70   | °C   |
| Storage temperature     | Tstg   | -40  | 100  | °C   |

| Recommended | operating | conditions |
|-------------|-----------|------------|
|             |           |            |

| Parameter             | Symbol | Min. | Тур. | Max. | Unit |
|-----------------------|--------|------|------|------|------|
| Power supply voltage  | Vcc    | 4.75 | 5    | 5.25 | v    |
| Load resistance       | RL     | 500  | -    | 2    | Ω    |
| Load capacitance      | CL     | -    | -    | 13   | pF   |
| Operating temperature | Topr   | 0    | -    | 60   | °C   |

\*1: For definitions of RL and CL, refer to the basic connection.

\*2: Output voltage Vout =Vo-(Pin × S) Pin: incident radiant flux (µW)

\*3: Peak value

\*4: A bypass capacitor (0.01 μF to 0.1 μF ceramic) is connected between the Vcc lead and the GND lead. The lead length should be less than 20 mm.



### HAMAMATSU



### Si PIN photodiode with preamp S6468 series

against electro static discharge, the device, operation operation static discharge which accumulate on the operator or the operator's clothes, use a wrist strap or similar • To protect the device from electro static discharge which accumulate on the operator or the operator's clothes, use a wrist strap or similar

To protect the device from electro static discharge which accumulate on the operator or the operator's clothes, use a wrist strap or similar tools to ground the operator's body via a high impedance resistor (1 M $\Omega$ ). • A semiconductive sheet (1 M $\Omega$  to 100 M $\Omega$ ) should be laid on both the work table and the floor in the work area. • When soldering, use an electrically grounded soldering iron with an isolation resistance of more than 10 M $\Omega$ . • For containers and packing, use of a conductive material or aluminum foil is effective. When using an antistatic material, use one with a resistance of 0.1 M $\Omega$ /cm<sup>2</sup> to 1 G $\Omega$ /cm<sup>2</sup>.

Wiring

NL and CL are total resistive load and capacitive load viewed from the V signal terminal. When connecting a cable or circuit to the latter stage of the basic connection diagram, the cable or circuit resistance and capacitance should also be taken into account. They should be used in accordance with the recommended operating conditions: RL≥500 Ω and CL ≤ 13 pF.
 A bypass capacitor (Ct=0.01 µF to 0.1 µF ceramic) is connected between the Voc lead and the GND lead.

- The lead length should be less than 20 mm.

If electric current or voltage is applied in reverse polarity to an electronic device such as a preamplifier, this can degrade device performance or destroy the device. Always check the wiring and dimensional cutline to avoid misconnection.

HAMAATSU Information furnished by HAMAMATSU is believed to be reliable. However, no responsibility is assumed for possible inacouracies or omissions. Specifications are subject to change without notice. No pattert rights are granted to any of the circuits described herein. 62003 Hamamatsu Photonics K.K. HAMAMATSU PHOTONICS K.K., Solid State Division

HAMAMAN SU PHOTONICS K.K., Solid State Division 1126-1 Ichino-cho, Hamamatsu City, 435-8555 Japan, Telephone: (31) 053-434-3311, Fax: (31) 053-434-5184, http://www.hamamatsu.com U.S.: Hamamatsu Corporation: 300 Foothi Road, PO.Box 6010, Bridgewater, N.J. 08807-0010, U.S.A., Telephone: (1) 908-291-0980, Fax: (1) 908-291-1218 Germany: Hamamatsu Photonics Destachiand GmbH. Azbergenst: 10, D-82211 Hensching am Ammersee Germany: Telephone: (40) 08153-3750, Fax: (40) 08152-2658 France: Hamamatsu Photonics Destachiand GmbH. Azbergenst: 10, D-82211 Hensching am Ammersee Germany: Telephone: (40) 90152-3750, Fax: (40) 08152-3058, France: Hensmatsu Photonics UK Limited 2 Howard Court, 10 Tenet: Road, Welvyn Garden CV, Hettfordshire AJ.2 16W, United Kingdom: Telephone: (44) 1707-294888, Fax: (44) 1707-325777 North Europe: Hamamatsu Photonics India M.B. Smidewatgen 12, 581-714 18 John, Sweder, Telephone: (30) 02-935-81-733, Fax: (50) 02-935-81-741

Cat. No. KPIN1026E05 Aug. 2003 DN

# AII.4. Technical specifications of the Amplifier MAX410

19-4194; Rev 4; 6/03

# **MIXI/M** Single/Dual/Quad, 28MHz, Low-Noise, Low-Voltage, Precision Op Amps

♦ Voltage Noise: 2.4nV/√Hz (max) at 1kHz

Low Supply Voltage Operation: ±2.4V to ±5V

250µV (max) Offset Voltage (MAX410/MAX412)

Available in an Ultra-Small TDFN Package

2.5mA Supply Current Per Amplifier

♦ 28MHz Unity-Gain Bandwidth

♦ 115dB (min) Voltage Gain

♦ 4.5V/µs Slew Rate

### **General Description**

The MAX410/MAX412/MAX414 single/dual/quad op amps set a new standard for noise performance in high-speed, low-voltage systems. Input voltage-noise density is guaranteed to be less than  $2.4nV/\sqrt{Hz}$  at 1kHz. A unique design not only combines low noise with ±5V operation, but also consumes 2.5mA supply current per amplifier. Low-voltage operation is guaranteed with an output voltage swing of  $7.3V_{P-P}$  into  $2k\Omega$ from ±5V supplies. The MAX410/MAX412/MAX414 also operate from supply voltages between ±2.4V and ±5V for greater supply flexibility.

Unity-gain stability, 28MHz bandwidth, and 4.5V/ $\!\mu s$ slew rate ensure low-noise performance in a wide variety of wideband and measurement applications. The MAX410/MAX412/MAX414 are available in DIP and SO packages in the industry-standard single/dual/quad op amp pin configurations. The single comes in an ultrasmall TDFN package (3mm x 3mm).

### **Applications**

Low-Noise Frequency Synthesizers Infrared Detectors **High-Quality Audio Amplifiers** Ultra Low-Noise Instrumentation Amplifiers Bridge Signal Conditioning



| PART       | TEMP RANGE     | PIN-PACKAGE   |
|------------|----------------|---------------|
| MAX410CPA  | 0°C to +70°C   | 8 Plastic DIP |
| MAX410BCPA | 0°C to +70°C   | 8 Plastic DIP |
| MAX410CSA  | 0°C to +70°C   | 8 SO          |
| MAX410BCSA | 0°C to +70°C   | 8 SO          |
| MAX410EPA  | -40°C to +85°C | 8 Plastic DIP |
| MAX410BEPA | -40°C to +85°C | 8 Plastic DIP |
| MAX410ESA  | -40°C to +85°C | 8 SO          |
| MAX410BESA | -40°C to +85°C | 8 SO          |
| MAX410ETA  | -40°C to +85°C | 8 TDFN-EP*    |

Ordering Information continued at end of data sheet.

\*EP-Exposed paddle. Top Mark-AGQ.

### **Pin Configurations**

**Ordering Information** 



### MAXIM

Maxim Integrated Products 1

For pricing, delivery, and ordering information, please contact Maxim/Dallas Direct! at 1-888-629-4642, or visit Maxim's website at www.maxim-ic.com.

# MAX410/MAX412/MAX414

**Features** 

### **ABSOLUTE MAXIMUM RATINGS**

| Supply Voltage                                        | 12V        |
|-------------------------------------------------------|------------|
| Differential Input Current (Note 1)                   | ±20mA      |
| Input Voltage Range                                   | V+ to V-   |
| Common-Mode Input Voltage(V+ + 0.3V) to               | (V0.3V)    |
| Short-Circuit Current Duration                        | Continuous |
| Continuous Power Dissipation (T <sub>A</sub> = +70°C) |            |
| MAX410/MAX412                                         |            |
| 8-Pin Plastic DIP (derate 9.09mW/°C above +70°C       | )727mW     |

| MAX414                                                  |  |
|---------------------------------------------------------|--|
| 14-Pin Plastic DIP (derate 10.00mW/9C above +70°C)800mW |  |
| 14 Pin SO (derate 8.33mW/ $\ell$ C above 170°C) 667mW   |  |
| Operating Temperature Depage:                           |  |
|                                                         |  |

MIXIM

Note 1: The amplifier inputs are connected by internal back-to-back clamp diodes. In order to minimize noise in the input stage, currentlimiting resistors are not used. If differential input voltages exceeding ±1.0V are applied, limit input current to 20mA.

Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of the specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

### **ELECTRICAL CHARACTERISTICS**

(V+ = 5V, V- = -5V, TA = +25°C, unless otherwise noted.)

| PARAMETER                     | SYMBOL          | CONDI                                      | TIONS           | MIN          | ТҮР           | MAX  | UNITS   |
|-------------------------------|-----------------|--------------------------------------------|-----------------|--------------|---------------|------|---------|
| Level Offered Meller          |                 | MAX410, MAX410B, M                         | AX412, MAX412B  |              | ±120          | ±250 | (       |
| Input Offset Voltage          | VOS             | MAX414, MAX414B                            |                 |              | ±150          | ±320 | μν      |
| Input Bias Current            | IB              |                                            |                 |              | ±80           | ±150 | nA      |
| Input Offset Current          | los             |                                            |                 |              | ±40           | ±80  | nA      |
| Differential Input Resistance | RIN(Diff)       |                                            |                 |              | 20            |      | kΩ      |
| Common-Mode Input Resistance  | RIN(CM)         |                                            |                 |              | 40            |      | MΩ      |
| Input Capacitance             | CIN             |                                            |                 |              | 4             |      | рF      |
|                               |                 | MAX410, MAX412,                            | 10Hz            |              | 7             |      |         |
| Innet Nation Maltaine Density |                 | MAX414                                     | 1000Hz (Note 2) |              | 1.5           | 2.4  |         |
| Input Noise-Voltage Density   | en              | MAX410B, MAX412B,<br>MAX414B               | 1000Hz (Note 2) |              | 2.4           | 4.0  | nvviiiz |
|                               |                 | $f_0 = 10Hz$                               | •               |              | 2.6           |      | A (1)   |
| Input Noise-Current Density   | In              | fo = 1000Hz                                |                 |              | 1.2           |      | PAγHz   |
| Common-Mode Input Voltage     | Vсм             |                                            |                 | ±3.5         | +3.7/<br>-3.8 |      | V       |
| Common-Mode Rejection Ratio   | CMRR            | $V_{CM} = \pm 3.5 V$                       |                 | 115          | 130           |      | dB      |
| Power-Supply Rejection Ratio  | PSRR            | $V_{S} = \pm 2.4 V \text{ to } \pm 5.25 V$ |                 | 96           | 103           |      | dB      |
| Lange Signal Option           | A               | $R_L = 2k\Omega, V_O = \pm 3.6V$           |                 | 115          | 122           |      | JD      |
| Large-Signal Gain             | AVOL            | $R_{L} = 600\Omega, V_{O} = \pm 3.5V$      |                 | 110          | 120           |      | aB      |
| Output Voltage Swing          | Vout            | $R_L = 2k\Omega$                           |                 | +3.6<br>-3.7 | +3.7/<br>-3.8 |      | V       |
| Short-Circuit Output Current  | I <sub>SC</sub> |                                            |                 |              | 35            |      | mA      |
| Slew Rate                     | SR              | 10kΩ    20pF load                          |                 |              | 4.5           |      | V/µs    |
| Unity-Gain Bandwidth          | GBW             | 10k $\Omega$    20pF load                  |                 |              | 28            |      | MHz     |
| Settling Time                 | ts              | To 0.1%                                    |                 |              | 1.3           |      | μs      |
| Channel Separation            | CS              | $f_{O} = 1 kHz$                            |                 |              | 135           |      | dB      |

### **ELECTRICAL CHARACTERISTICS (continued)**

(V+ = 5V, V- = -5V,  $T_A = +25^{\circ}C$ , unless otherwise noted.)

| PARAMETER                      | SYMBOL | CONDITIONS    | MIN  | TYP | MAX   | UNITS |
|--------------------------------|--------|---------------|------|-----|-------|-------|
| Operating Supply-Voltage Range | Vs     |               | ±2.4 |     | ±5.25 | V     |
| Supply Current                 | IS     | Per amplifier |      | 2.5 | 2.7   | mA    |

### **ELECTRICAL CHARACTERISTICS**

(V+ = 5V, V- = -5V, T<sub>A</sub> = 0°C to +70°C, unless otherwise noted.)

| PARAMETER                    | SYMBOL                   | CONDITIONS                                 | MIN  | TYP           | MAX  | UNITS |
|------------------------------|--------------------------|--------------------------------------------|------|---------------|------|-------|
| Input Offset Voltage         | Vos                      |                                            |      | ±150          | ±350 | μV    |
| Offset Voltage Tempco        | $\Delta V_{OS}/\Delta T$ | Over operating temperature range           |      | ±1            |      | µV/°C |
| Input Bias Current           | IB                       |                                            |      | ±100          | ±200 | nA    |
| Input Offset Current         | los                      |                                            |      | ±80           | ±150 | nA    |
| Common-Mode Input Voltage    | Vсм                      |                                            | ±3.5 | +3.7/<br>-3.8 |      | V     |
| Common-Mode Rejection Ratio  | CMRR                     | $V_{CM} = \pm 3.5 V$                       | 105  | 121           |      | dB    |
| Power-Supply Rejection Ratio | PSRR                     | $V_{S} = \pm 2.4 V \text{ to } \pm 5.25 V$ | 90   | 97            |      | dB    |
| Lange Circuit Opin           | A                        | $R_L = 2k\Omega, V_O = \pm 3.6V$           | 110  | 120           |      | - ID  |
| Large-Signal Gain            | AVOL                     | $R_{L} = 600\Omega, V_{O} = \pm 3.5V$      | 90   | 119           |      | ав    |
| Output Voltage Swing         | Vout                     | $R_{L} = 2k\Omega$                         | ±3.5 | +3.7/<br>-3.6 |      | V     |
| Supply Current               | Is                       | Per amplifier                              |      |               | 3.3  | mA    |

### **ELECTRICAL CHARACTERISTICS**

(V+ = 5V, V- = -5V,  $T_{\mbox{A}}$  = -40°C to +85°C, unless otherwise noted.) (Note 3)

| PARAMETER                    | SYMBOL                   | CONDITIONS                                   | MIN  | ТҮР           | MAX  | UNITS |
|------------------------------|--------------------------|----------------------------------------------|------|---------------|------|-------|
| Input Offact Voltage         | Maa                      | MAX410, MAX410B, MAX412, MAX412B             |      | ±200          | ±400 |       |
| Input Onset voltage          | ¥ OS                     | MAX414, MAX414B                              |      | ±200          | ±450 | μv    |
| Offset Voltage Tempco        | $\Delta V_{OS}/\Delta T$ | Over operating temperature range             |      | ± 1           |      | µV/⁰C |
| Input Bias Current           | IB                       |                                              |      | ±130          | ±350 | nA    |
| Input Offset Current         | los                      |                                              |      | ±100          | ±200 | nA    |
| Common-Mode Input Voltage    | Vсм                      |                                              | ±3.5 | +3.7/<br>-3.6 |      | V     |
| Common-Mode Rejection Ratio  | CMRR                     | $V_{CM} = \pm 3.5 V$                         | 105  | 120           |      | dB    |
| Power-Supply Rejection Ratio | PSRR                     | $V_{S} = \pm 2.4 V$ to $\pm 5.25 V$          | 90   | 94            |      | dB    |
| Lorga Signal Cain            | Aug                      | $R_L = 2k\Omega, V_O = \pm 3.6V$             | 110  | 118           |      | dD    |
| Large-Signal Gain            | AVOL                     | $R_L = 600\Omega$ , $V_O = +3.4V$ to $-3.5V$ | 90   | 114           |      | uв    |
| Output Voltage Swing         | Vout                     | $R_{L} = 2k\Omega$                           | ±3.5 | +3.7/<br>-3.6 |      | V     |
| Supply Current               | Is                       | Per amplifier                                |      |               | 3.3  | mA    |

Note 2: Guaranteed by design. Note 3: All TDFN devices are 100% tested at  $T_A = +25$ °C. Limits over temperature for thin TDFNs are guaranteed by design.



MAX410/MAX412/MAX414







MAX410/MAX412/MAX414



### Applications Information

The MAX410/MAX412/MAX414 provide low voltagenoise performance. Obtaining low voltage noise from a bipolar op amp requires high collector currents in the input stage, since voltage noise is inversely proportional to the square root of the input stage collector current. However, op amp current noise is proportional to the square root of the input stage collector current, and the input bias current is proportional to the input stage collector current. Therefore, to obtain optimum low-noise performance, DC accuracy, and AC stability, minimize the value of the feedback and source resistance.

### **Total Noise Density vs. Source Resistance**

The standard expression for the total input-referred noise of an op amp at a given frequency is:

$$e_t = \sqrt{e_n^2 + (R_p + R_n)^2 i_n^2 + 4kT (R_p + R_n)}$$

where:

$$R_n$$
 = Inverting input effective series resistance

Rp = Noninverting input effective series resistance

 $\mathbf{e}_{\mathrm{B}}$  = Input voltage-noise density at the frequency of interest

 $i_{\ensuremath{\mathsf{n}}}$  = Input current-noise density at the frequency of interest

T = Ambient temperature in Kelvin (K)

k = 1.28 x 10<sup>-23</sup> J/K (Boltzman's constant)

In Figure 1,  $R_{\rm p}$  = R3 and  $R_{\rm n}$  = R1 II R2. In a real application, the output resistance of the source driving the input must be included with  $R_{\rm p}$  and  $R_{\rm n}$ . The following example demonstrates how to calculate the total output-noise density at a frequency of 1kHz for the MAX412 circuit in Figure 1.

Gain = 1000

 $4kT \text{ at } +25^{\circ}C = 1.64 \times 10^{-20}$ 

 $R_p = 100\Omega$ 

 $R_{\Pi} = 100\Omega \text{ II } 100 \text{k}\Omega = 99.9 \text{ W}$ 

 $e_n = 1.5 \text{nV}/\sqrt{\text{Hz}}$  at 1kHz

in = 
$$1.2pA\sqrt{Hz}$$
 at 1kHz

et =  $[(1.5 \times 10^{-9})^2 + (100 + 99.9)^2 (1.2 \times 10^{-12})^2 + (1.64 \times 10^{-20}) (100 + 99.9)]^{1/2} = 2.36$ nV//Hz at 1kHz

Output noise density =  $(100)e_{t} = 2.36\mu V/\sqrt{Hz}$  at 1kHz.

In general, the amplifier's voltage noise dominates with equivalent source resistances less than  $200\Omega$ . As the equivalent source resistance increases, resistor noise

M IXI M

becomes the dominant term, eventually making the voltage noise contribution from the MAX410/MAX412/ MAX414 negligible. As the source resistance is further increased, current noise becomes dominant. For example, when the equivalent source resistance is greater than  $3\Omega \alpha t$  1kHz, the current noise component is larger than the resistor noise. The graph of Total Noise Density vs. Matched Source Resistance in the *Typical Operating Characteristics* shows this phenomenon. Optimal MAX410/MAX412/MAX414 noise performance and minimal total noise achieved with an equivalent source resistance of less than  $10 \Omega c$ .

### **Voltage Noise Testing**

MAX410/MAX412/MAX414

RMS voltage-noise density is measured with the circuit shown in Figure 2, using the Quan Tech model 5173 noise analyzer, or equivalent. The voltage-noise density at 1kHz is sample tested on production units. When measuring op-amp voltage noise, only low-value, metal film resistors are used in the test fixture.

The 0.1Hz to 10Hz peak-to-peak noise of the MAX410/MAX412/MAX414 is measured using the test



Figure 1. Total Noise vs. Source Resistance Example



Figure 2. Voltage-Noise Density Test Circuit



Figure 3. 0.1Hz to 10Hz Voltage Noise Test Circuit



Figure 4. 0.1Hz to 10Hz Voltage Noise Test Circuit, Frequency Response

circuit shown in Figure 3. Figure 4 shows the frequency response of the circuit. The test time for the 0.1Hz to 10Hz noise measurement should be limited to 10 seconds, which has the effect of adding a second zero to the test circuit, providing increased attenuation for frequencies below 0.1Hz.

### **Current Noise Testing**

The current-noise density can be calculated, once the value of the input-referred noise is determined, by using the standard expression given below:

$$i_{n} = \frac{\sqrt{e_{no}^{2} - \left[ (A_{VCL})^{2} (4kT) (R_{n} + R_{p}) \right]}}{(R_{n} + R_{p}) (A_{VCL})} A / \sqrt{Hz}$$

where:

 $R_n$  = Inverting input effective series resistance

Rp= Noninverting input effective series resistance

 $e_{\rm NO}$  = Output voltage-noise density at the frequency of interest (V/NHz)

 $i_{\Pi}$  = Input current-noise density at the frequency of interest (A/\Hz)

AvcL = Closed-loop gain

T = Ambient temperature in Kelvin (K)

k = 1.38 x 10<sup>-23</sup> J/K (Boltzman's constant)

 $\mathsf{R}_\mathsf{p}$  and  $\mathsf{R}_\mathsf{n}$  include the resistances of the input driving source(s), if any.

If the Quan Tech model 5173 is used, then the A<sub>VCL</sub> terms in the numerator and denominator of the equation given above should be eliminated because the Quan





Figure 5. Current-Noise Test Circuit

Tech measures input-referred noise. For the circuit in Figure 5, assuming  $R_p$  is approximately equal to  $R_n$  and the measurement is taken with the Quan Tech model 5173, the equation simplifies to:

$$i_{n} = \frac{\sqrt{e_{no}^{2} - \left[ (1.64 \times 10^{-20})(20 \times 10^{3}) \right]}}{(20 \times 10^{3})} \text{ A}/\sqrt{\text{Hz}}$$

### **Input Protection**

To protect amplifier inputs from excessive differential input voltages, most modern op amps contain input protection diodes and current-limiting resistors. These resistors increase the amplifier's input-referred noise. They have not been included in the MAX410/MAX412/MAX414, to optimize noise performance. The MAX410/MAX412/MAX414 do contain back-to-back input protection diodes which will protect the amplifier for differential input voltages of  $\pm 0.1V$ . If the amplifier must be protected from higher differential input voltages, add external current-limiting resistors in series with the op amp inputs to limit the potential input current to less than 20mA.

### **Capacitive-Load Driving**

Driving large capacitive loads increases the likelihood of oscillation in amplifier circuits. This is especially true for circuits with high loop gains, like voltage followers. The output impedance of the amplifier and a capacitive load form an RC network that adds a pole to the loop response. If the pole frequency is low enough, as when driving a large capacitive load, the circuit phase margin is degraded.

In voltage follower circuits, the MAX410/MAX412/ MAX414 remain stable while driving capacitive loads as great as 3900pF (see Figures 6a and 6b).





Figure 6a. Voltage Follower Circuit with 3900pF Load



Figure 6b. Driving 3900pF Load as Shown in Figure 6a

When driving capacitive loads greater than 3900pF, add an output isolation resistor to the voltage follower circuit, as shown in Figure 7a. This resistor isolates the load capacitance from the amplifier output and restores the phase margin. Figure 7b is a photograph of the response of a MAX410/MAX412/MAX414 driving a 0.015 $\mu$ F load with a 10 $\Omega$  isolation resistor

The capacitive-load driving performance of the MAX410/MAX412/MAX414 is plotted for closed-loop gains of -1V/V and -10V/V in the % Overshoot vs. Capacitive Load graph in the *Typical Operating Characteristics*.

Feedback around the isolation resistor RI increases the accuracy at the capacitively loaded output (see Figure 8). The MAX410/MAX412/MAX414 are stable with a  $0.01\mu$ F load for the values of RI and CF shown. In general, for decreased closed-loop gain, increase RI or CF. To drive larger capacitive loads, increase the value of CF.

9

MAX410/MAX412/MAX414



Figure 7a. Capacitive-Load Driving Circuit



Figure 7b. Driving a 0.015 $\mu$ F Load with a 10 $\Omega$  Isolation Resistor

### **TDFN Exposed Paddle Connection**

On TDFN packages, there is an exposed paddle that does not carry any current but should be connected to V- (not the GND plane) for rated power dissipation.

**Total Supply Voltage Considerations** Although the MAX410/MAX412/MAX414 are specified with  $\pm 5V$  power supplies, they are also capable of single-supply operation with voltages as low as 4.8V. The minimum input voltage range for normal amplifier operation is between V- + 1.5V and V+ - 1.5V. The minimum room-temperature output voltage range (with 2k $\!\Omega$  load)



Figure 8. Capacitive-Load Driving Circuit with Loop-Enclosed Isolation Resistor



Figure 9. MAX410 Offset Null Circuit

is between V+ - 1.4V and V- + 1.3V for total supply voltages between 4.8V and 10V. The output voltage range, referenced to the supply voltages, decreases slightly over temperature, as indicated in the ±5V Electrical Characteristics tables. Operating characteristics at total supply, voltages of less than 10V are guaranteed by design and PSRR tests.

### MAX410 Offset Voltage Null

The offset null circuit of Figure 9 provides approximately ±450µV of offset adjustment range, sufficient for zeroing offset over the full operating temperature range,



| _Ordering  | Information    | n (continued   |
|------------|----------------|----------------|
| PART       | TEMP RANGE     | PIN-PACKAGE    |
| MAX412CPA  | 0°C to +70°C   | 8 Plastic DIP  |
| MAX412BCPA | 0°C to +70°C   | 8 Plastic DIP  |
| MAX412CSA  | 0°C to +70°C   | 8 SO           |
| MAX412BCSA | 0°C to +70°C   | 8 SO           |
| MAX412EPA  | -40°C to +85°C | 8 Plastic DIP  |
| MAX412BEPA | -40°C to +85°C | 8 Plastic DIP  |
| MAX412ESA  | -40°C to +85°C | 8 SO           |
| MAX412BESA | -40°C to +85°C | 8 SO           |
| MAX414CPD  | 0°C to +70°C   | 14 Plastic DIP |
| MAX414BCPD | 0°C to +70°C   | 14 Plastic DIP |
| MAX414CSD  | 0°C to +70°C   | 14 SO          |
| MAX414BCSD | 0°C to +70°C   | 14 SO          |
| MAX414EPD  | -40°C to +85°C | 14 Plastic DIP |
| MAX414BEPD | -40°C to +85°C | 14 Plastic DIP |
| MAX414ESD  | -40°C to +85°C | 14 SO          |
| MAX414BESD | -40°C to +85°C | 14 SO          |



# MAX410/MAX412/MAX414

### **Chip Information**

MAX410 TRANSISTOR COUNT: 132 MAX412 TRANSISTOR COUNT: 262 MAX414 TRANSISTOR COUNT: 2 × 262 (hybrid) PROCESS: Bipolar

**MIXIW** 

217

**Package Information** 

(The package drawing(s) in this data sheet may not reflect the most current specifications. For the latest package outline information, go to www.maxim-ic.com/packages.)





ΜΙΧΙΜ

### Package Information (continued)

(The package drawing(s) in this data sheet may not reflect the most current specifications. For the latest package outline information, go to www.maxim-ic.com/packages.)



# MAX410/MAX412/MAX414

### **MIXIW**





(The package drawing(s) in this data sheet may not reflect the most current specifications. For the latest package outline information, go to <a href="http://www.maxim-ic.com/packages">www.maxim-ic.com/packages</a>.)



M/IXI/M

### Package Information (continued)

21-0137

D

(The package drawing(s) in this data sheet may not reflect the most current specifications. For the latest package outline information, go to www.maxim-ic.com/packages.)

| COMMC                                                   |                              |                                           | 1                                         |                                       |                                                              |                                          |                                                   |   |
|---------------------------------------------------------|------------------------------|-------------------------------------------|-------------------------------------------|---------------------------------------|--------------------------------------------------------------|------------------------------------------|---------------------------------------------------|---|
| EVMDOL                                                  |                              | MAY                                       | -                                         |                                       |                                                              |                                          |                                                   |   |
|                                                         | 0.70                         | 0.80                                      | -                                         |                                       |                                                              |                                          |                                                   |   |
|                                                         | 2.90                         | 3.10                                      | 1                                         |                                       |                                                              |                                          |                                                   |   |
| F                                                       | 2.00                         | 3.10                                      | -                                         |                                       |                                                              |                                          |                                                   |   |
| Δ1                                                      | 0.00                         | 0.05                                      | -                                         |                                       |                                                              |                                          |                                                   |   |
| 1                                                       | 0.00                         | 0.40                                      | -                                         |                                       |                                                              |                                          |                                                   |   |
| k                                                       | 0.20                         | 25 MIN                                    |                                           |                                       |                                                              |                                          |                                                   |   |
| A2                                                      | 0.2                          | 20 REF                                    | 1                                         |                                       |                                                              |                                          |                                                   |   |
| PACKAGE VAR                                             | IATIONS                      |                                           |                                           |                                       |                                                              |                                          |                                                   | 1 |
| PACKAGE VAR<br>PKG. CODE                                | IATIONS<br>N                 | D2                                        | E2                                        | e                                     | JEDEC SPEC                                                   | b                                        | [(N/2)-1] x e                                     | ] |
| PACKAGE VAR<br>PKG. CODE<br>T633-1                      | IATIONS<br>N<br>6            | D2<br>1.50-0.10                           | E2<br>2.30-0.10                           | e<br>0.95 BSC                         | JEDEC SPEC<br>M0229 / WEEA                                   | b<br>0.40-0.05                           | [(N/2)-1] x e<br>1.90 REF                         | ] |
| PACKAGE VAR<br>PKG. CODE<br>T633-1<br>T833-1            | IATIONS<br>N<br>6<br>8       | D2<br>1.50-0.10<br>1.50-0.10              | E2<br>2.30-0.10<br>2.30-0.10              | e<br>0.95 BSC<br>0.65 BSC             | JEDEC SPEC<br>MO229 / WEEA<br>MO229 / WEEC                   | b<br>0.40–0.05<br>0.30–0.05              | [(N/2)-1] x e<br>1.90 REF<br>1.95 REF             | 1 |
| PACKAGE VAR<br>PKG. CODE<br>T633-1<br>T833-1<br>T1033-1 | IATIONS<br>N<br>6<br>8<br>10 | D2<br>1.50-0.10<br>1.50-0.10<br>1.50-0.10 | E2<br>2.30-0.10<br>2.30-0.10<br>2.30-0.10 | е<br>0.95 BSC<br>0.65 BSC<br>0.50 BSC | JEDEC SPEC<br>MO229 / WEEA<br>MO229 / WEEC<br>MO229 / WEED-3 | b<br>0.40-0.05<br>0.30-0.05<br>0.25-0.05 | [(N/2)-1] x e<br>1.90 REF<br>1.95 REF<br>2.00 REF |   |

Maxim cannot assume responsibility for use of any circuitry other than circuitry entirely embodied in a Maxim product. No circuit patent licenses are implied. Maxim reserves the right to change the circuitry and specifications without notice at any time.

Maxim Integrated Products, 120 San Gabriel Drive, Sunnyvale, CA 94086 408-737-7600 \_\_\_\_\_\_ 15

© 2003 Maxim Integrated Products Printed USA MAXIM is a registered trademark of Maxim Integrated Products.

# AII.5. Technical specifications of the Differential Comparator LM360



© 2004 National Semiconductor Corporation DS005707

### Absolute Maximum Ratings (Notes 6, 8) If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/ Distributors for availability and specifications.

| Positive Supply Voltage     | +8V                        |
|-----------------------------|----------------------------|
| Negative Supply Voltage     | –8V                        |
| Peak Output Current         | 20 mA                      |
| Differential Input Voltage  | ±5V                        |
| Input Voltage               | $V^+ \geq V_{IN} \geq V^-$ |
| ESD Tolerance (Note 9)      | 1600V                      |
| Operating Temperature Range |                            |
| LM160                       | -55°C to +125°C            |
| LM360                       | 0°C to +70°C               |

| Storage Temperature Range             | –65°C to +150°C     |
|---------------------------------------|---------------------|
| Lead Temperature                      |                     |
| (Soldering, 10 sec.)                  | 260°C               |
| Soldering Information                 |                     |
| Dual-In-Line Package                  |                     |
| Soldering (10 seconds)                | 260°C               |
| Small Outline Package                 |                     |
| Vapor Phase (60 seconds)              | 215°C               |
| Infrared (15 seconds)                 | 220°C               |
| See AN-450 "Surface Mounting Method   | ds and Their Effect |
| on Product Reliability" for other met | hods of soldering   |

surface mount devices.

# Electrical Characteristics

| ('MIN - 'A - 'MAX/                                              |                                                |      |      |      |       |
|-----------------------------------------------------------------|------------------------------------------------|------|------|------|-------|
| Parameter                                                       | Conditions                                     | Min  | Тур  | Max  | Units |
| Operating Conditions                                            |                                                |      |      |      |       |
| Supply Voltage V <sub>CC</sub> <sup>+</sup>                     |                                                | 4.5  | 5    | 6.5  | V     |
| Supply Voltage V $_{\rm CC}^-$                                  |                                                | -4.5 | -5   | -6.5 | V     |
| Input Offset Voltage                                            | $R_S \le 200\Omega$                            |      | 2    | 5    | mV    |
| Input Offset Current                                            |                                                |      | 0.5  | 3    | μA    |
| Input Bias Current                                              |                                                |      | 5    | 20   | μA    |
| Output Resistance (Either Output)                               | $V_{OUT} = V_{OH}$                             |      | 100  |      | Ω     |
| Response Time                                                   | $T_A = 25^{\circ}C, V_S = \pm 5V$ (Notes 2, 7) |      | 13   | 25   | ns    |
|                                                                 | $T_A = 25^{\circ}C, V_S = \pm 5V$ (Notes 3, 7) |      | 12   | 20   | ns    |
|                                                                 | $T_A = 25^{\circ}C, V_S = \pm 5V$ (Notes 4, 7) |      | 14   |      | ns    |
| Response Time Difference between Outputs                        |                                                |      |      |      |       |
| $(t_{pd} \text{ of } +V_{IN1}) - (t_{pd} \text{ of } -V_{IN2})$ | T <sub>A</sub> = 25°C (Notes 2, 7)             |      | 2    |      | ns    |
| $(t_{pd} \text{ of } +V_{IN2}) - (t_{pd} \text{ of } -V_{IN1})$ | T <sub>A</sub> = 25°C (Notes 2, 7)             |      | 2    |      | ns    |
| $(t_{pd} \text{ of } +V_{IN1}) - (t_{pd} \text{ of } +V_{IN2})$ | T <sub>A</sub> = 25°C (Notes 2, 7)             |      | 2    |      | ns    |
| $(t_{pd} \text{ of } -V_{IN1}) - (t_{pd} \text{ of } -V_{IN2})$ | T <sub>A</sub> = 25°C (Notes 2, 7)             |      | 2    |      | ns    |
| Input Resistance                                                | f = 1 MHz                                      |      | 17   |      | kΩ    |
| Input Capacitance                                               | f = 1 MHz                                      |      | 3    |      | pF    |
| Average Temperature Coefficient of                              | $R_S = 50\Omega$                               |      | 8    |      | µV/°C |
| Input Offset Voltage                                            |                                                |      |      |      |       |
| Average Temperature Coefficient of                              |                                                |      | 7    |      | nA/°C |
| Input Offset Current                                            |                                                |      |      |      |       |
| Common Mode Input Voltage Range                                 | $V_S = \pm 6.5 V$                              | ±4   | ±4.5 |      | V     |
| Differential Input Voltage Range                                |                                                | ±5   |      |      | V     |
| Output High Voltage (Either Output)                             | $I_{OUT} = -320 \ \mu A, V_S = \pm 4.5 V$      | 2.4  | 3    |      | V     |
| Output Low Voltage (Either Output)                              | I <sub>SINK</sub> = 6.4 mA                     |      | 0.25 | 0.4  | V     |
| Positive Supply Current                                         | $V_{\rm S} = \pm 6.5 V$                        |      | 18   | 32   | mA    |
| Negative Supply Current                                         | $V_{\rm S} = \pm 6.5 V$                        |      | -9   | -16  | mA    |

Note 2: Response time measured from the 50% point of a 30 mVp-p 10 MHz sinusoidal input to the 50% point of the output.

Note 3: Response time measured from the 50% point of a 2 Vp-p 10 MHz sinusoidal input to the 50% point of the output.









www.national.com





# AII.6. Technical specification of the 5.0V TTL Clock Oscillator F1100E

### 5.0V TTL CLOCK OSCILLATOR F1100E F1100E FEATURES 5.0V Operation TTL Output 14-Pin DIP FASTFOX MODEL NUMBER SELECTION Frequency Stability<sup>1</sup> Operating Frequency Model Number Range (MHz) 1.000 ~ 100.000 Temperature (°C) F1100E ±100PPM (STD) ±100PPM $0 \sim +70$ 1.000 1.000 ~ 100.000 F1100ER 40~+85 F1145E F1145ER ±50PPM 0~+70 1.000 ~ 100.000 70.000 ±50PPM 1.000 ~ -40 ~ +85 F1144E ±25PPM 0 ~ +701.000 ~ 100.000 20.8 Max F1144ER ±25PPM -40~+85 $1.000 \sim 70.000$ #14 #B ELECTRICAL CHARACTERISTICS 13.2 Max PARAMETERS MAX (unless otherwise noted) \$7 Frequency Range (Fo) 1.000 ~ 100.000 MHz Comer Denates Pin 1 -55°C~+125°C Storage Temperature Range (TSTG) Supply Voltage (VDD) $5.0V \pm 10\%$ Input Current (IDD) 1.000 ~ 8.000 MHz 15mA 8.000+~24.000 MHz 30mA 5.08 Max 24.000+ ~ 70.000 MHz 70m A 70.000+ ~ 100.000 MHz 80mA 6.35 1 Output Symmetry (1.4V Level) 1.000 ~ 8.000 MHz 45% ~ 55% 8.000+~ 100.000 MHz 40%~ 60% Rise Time (0.5V ~ 2.4V) (TR) 1.000 ~ 25.000 MHz 10 nS Ø0.45±0.08 25.000+~70.000 MHz 5 nS Trouisted Stand offs 70.000+ ~ 100.000 MHz $4 \, \mathrm{nS}$ Fall Time (2.4V ~ 0.5V) (Tr) 00 æ ł. 1.000 ~ 25.000 MHz 10 nS 7.62±0.127 25.000+ ~ 70.000 MHz 5 nS 0 0 ÷. 70.000+ ~ 100.000 MHz 4 nS Output Voltage 13.24±0.127 1.000 ~ 25.000 MHz (Vol) 0.4V 25.000+~ 100.000 MHz 0.5V 1.000 ~ 100.000 MHz 2.4V Min (VOH) Output Current (Iot.) 20mA Min **Pin Connections** (IOH) -1.0mA Min #1 N.C. #8 Output #7 GND (Case) #14 +5Vdc Output Load 10TTL (Ts)Start-up Time All dimensions are in millimeters. 1.000 ~ 3.500 MHz 20mS 3.500+ ~ 4.000 MHz 35mS 4 000+ ~ 6 000 MHz 30mS 6.000+~ 20.000 MHz 20mS 20.000+~ 100.000 MHz 15mS

Inclusive of 25°C tolerance, operating temperature range, input voltage change, load change, aging, shock, and vibration.

See page 30 for mechanical specifications, test circuits, and output waveform. All specifications subject to change without notice. Rov. 02/10/03

FOXElectronics 5570 Enterprise Parkway Fort Myers, Florida 33905 USA +001(239)693-0099 FAX +001(239)693-1554 http://www.foxonline.com 57 e 2003 Fox Electronics

# AII.7. Altera MAX 9000 programmable logic device family data sheet



Altera Corporation

A-DS-M9000-05.01

### MAX 9000 Programmable Logic Device Family Data Sheet

...and More

Features

Programmable macrocell flipflops with individual clear, preset, Clock, and clock enable controls Programmable security bit for protection of proprietary designs Software design support and automatic place-and-route provided by Altera's MAX+PLUS® II development system on 486- and Pentium-based PCs, and Sun SPARCstation, HP 9000 Series 700/800, and IBM RISC System/6000 workstations Additional design entry and simulation support provided by  $\ensuremath{\mathrm{EDIF}}$ 2 0 0 and 3 0 0 netlist files, library of parameterized modules (LPM), Verilog HDL, VHDL, and other interfaces to popular EDA tools from manufacturers such as Cadence, Exemplar Logic, Mentor Graphics, OrCAD, Synopsys, Synplicity, and VeriBest Programming support with Altera's Master Programming Unit (MPU), BitBlaster<sup>™</sup> serial download cable, and ByteBlaster<sup>™</sup> parallel port download cable, as well as programming hardware from third-party manufacturers Offered in a variety of package options with 84 to 356 pins (see Table 2) Table 2. MAX 9000 Package Options & I/O Counts Notes (1), (2) 84-Pin 208-Pin 240-Pin 280-Pin 304-Pin 356-Pin Device RQFP RQFP RQFP PLCC PGA BGA EPM9320 60 *(3)* 132 168 168 EPM9320A 60 *(3)* 132 168 EPM9400 59 *(3)* 139 159 EPM9480 146 175

EPM9560A *Notes:* 

EPM9480A

EPM9560

 MAX 9000 device package types include plastic J-lead chip carrier (PLCC), power quad flat pack (RQFP), ceramic pin-grid array (PGA), and ball-grid array (BGA)

175

191

191

216

216

216

216

146

153

153

- (2) Contact Altera Customer Marketing at (408) 544-7104 for up-to-date information on package availability. All information on EPM9320A, EPM9480A, and EPM9560A devices is preliminary.
   (2) Disferse a complete thermal analysis before committing a design to this device
- (3) Perform a complete thermal analysis before committing a design to this device package. See *Application Note 74 (Evaluating Power for Altera Devices)* in the *1998 Data Book*:

Altera Corporation

### MAX 9000 Programmable Logic Device Family Data Sheet

### General Description

The MAX 9000 family of in-system-programmable, high-density, high-performance EPLDs is based on Altera's third-generation MAX architecture. Fabricated on an advanced CMOS technology, the EEPROM-based MAX 9000 family provides 6,000 to 12,000 usable gates, pin-to-pin delays as fast as 7.5 ns, and counter speeds of up to 178 MHz. The -7 and -10 speed grades of the MAX 9000 family are compliant with the *PCI Local Bus Specification, Revision 2.1.* Table 3 shows the speed grades available for MAX 9000 devices.

| Table 3. MAX 9000 Speed Grade Availability |             |              |              |              |  |  |  |
|--------------------------------------------|-------------|--------------|--------------|--------------|--|--|--|
| Device                                     | Speed Grade |              |              |              |  |  |  |
|                                            | -7 Note (1) | -10          | -15          | -20          |  |  |  |
| EPM9320                                    |             |              | $\checkmark$ | $\checkmark$ |  |  |  |
| EPM9320A                                   | ✓ (2)       | <b>√</b> (2) | ✓ (2)        |              |  |  |  |
| EPM9400                                    |             |              | $\checkmark$ | $\checkmark$ |  |  |  |
| EPM9480                                    |             |              | $\checkmark$ | $\checkmark$ |  |  |  |
| EPM9480A                                   |             | <b>√</b> (2) | ✓ (2)        |              |  |  |  |
| EPM9560                                    |             |              | $\checkmark$ | $\checkmark$ |  |  |  |
| EPM9560A                                   |             | ✓(2)         | ✓ (2)        |              |  |  |  |

Notes:
(1) The -7 speed grade is under development.
(2) This information is preliminary. Contact Altera for up-to-date information on speed grade availability.

Table 4 shows the performance of MAX 9000 devices for typical functions.

| Table 4. MAX 9000 Performance         Note (1) |                 |             |            |           |         |     |  |  |  |
|------------------------------------------------|-----------------|-------------|------------|-----------|---------|-----|--|--|--|
| Application                                    | Macrocells Used |             | Units      |           |         |     |  |  |  |
|                                                |                 | -7 (2), (3) | -10 (2)    | -15       | -20     |     |  |  |  |
| 16-bit loadable counter                        | 16              | 178         | 144        | 118       | 100     | MHz |  |  |  |
| 16-bit up/down counter                         | 16              | 178         | 144        | 118       | 100     | MHz |  |  |  |
| 16-bit prescaled counter                       | 16              | 178         | 144        | 118       | 100     | MHz |  |  |  |
| 16-bit address decode                          | 1               | 4.4 (7.5)   | 5.6 (10)   | 7.9 (15)  | 10 (20) | ns  |  |  |  |
| 16-to-1 multiplexer                            | 1               | 5.8 (9.3)   | 7.7 (12.1) | 10.9 (18) | 16 (26) | ns  |  |  |  |

Notes:

Notes:
 Internal logic array block (LAB) performance is shown. Numbers in parentheses show external delays from row input pin to row I/O pin.
 This information is preliminary.
 The -7 speed grade is under development.

Altera Corporation

### MAX 9000 Programmable Logic Device Family Data Sheet

The MAX 9000 architecture supports high-density integration of systemlevel logic functions. It easily integrates multiple programmable logic devices ranging from PALs, GALs, and 22V10s to field-programmable gate array (FPGA) devices and EPLDs. With speed, density, and I/O resources comparable to commonly used masked gate arrays, MAX 9000 EPLDs are also ideal for gate-array prototyping.

All MAX 9000 device packages provide four dedicated inputs for global control signals with large fan-outs. Each I/O pin has an associated I/O cell register with a clock enable control on the periphery of the device. As outputs, these registers provide fast clock-to-output times; as inputs, they offer quick setup times.

MAX 9000 EPLDs provide 5.0-V in-system programmability (ISP). This feature allows the devices to be programmed and reprogrammed on the printed circuit board (PCB) for quick and efficient iterations during design development and debug cycles. MAX 9000 devices are guaranteed for 100 program and erase cycles.

MAX 9000 EPLDs contain from 320 to 560 macrocells that are combined into groups of 16 macrocells, called logic array blocks (LABs). Each macrocell has a programmable-AND/ fixed-OR array and a configurable register with independently programmable clock, clock enable, clear, and preset functions. For increased flexibility, each macrocell offers a dualoutput structure that allows the register and the product terms to be used independently. This feature allows register-rich and combinatorialintensive designs to be implemented efficiently. The dual-output structure of the MAX 9000 macrocell also improves logic utilization, thus increasing the effective capacity of the devices. To build complex logic functions, each macrocell can be supplemented with both shareable expander product terms and high-speed parallel expander product terms to provide up to 32 product terms per macrocell.

The MAX 9000 family provides programmable speed/power optimization. Speed-critical portions of a design can run at high speed/full power, while the remaining portions run at reduced speed/low power. This speed/power optimization feature enables the user to configure one or more macrocells to operate at 50% or less power while adding only a nominal timing delay. MAX 9000 devices also provide an option that reduces the slew rate of the output buffers, minimizing noise transients when non-speed-critical signals are switching. MAX 9000 devices offer the MultiVolt feature, which allows output drivers to be set for either 3.3-V or 5.0-V operation in mixedvoltage systems.

Altera Corporation


Altera Corporation

#### MAX 9000 Programmable Logic Device Family Data Sheet

Device Pin-Outs Tables 10, 11, 12, and 13 show the pin names and numbers for the dedicated pins for each EPM9320, EPM9320A, EPM9400, EPM9480, EPM9480A, EPM9560, and EPM9560A device package.

| Pin Name                | 84-Pin PLCC,<br>Note (1)         | 208-Pin RQFP                                                                                                                                         | 280-Pin PGA,<br>Note (2)                                                                                                                                                  | 356-Pin BGA                                                                                                                                                                                                            |
|-------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIN1 (GCLK1)            | 1                                | 182                                                                                                                                                  | V10                                                                                                                                                                       | AD13                                                                                                                                                                                                                   |
| DIN2 (GCLK2)            | 84                               | 183                                                                                                                                                  | U10                                                                                                                                                                       | AF14                                                                                                                                                                                                                   |
| DIN3 (GCLR)             | 13                               | 153                                                                                                                                                  | V17                                                                                                                                                                       | AD1                                                                                                                                                                                                                    |
| DIN4 (GOE)              | 72                               | 4                                                                                                                                                    | W2                                                                                                                                                                        | AC24                                                                                                                                                                                                                   |
| TCK                     | 43                               | 78                                                                                                                                                   | A9                                                                                                                                                                        | A18                                                                                                                                                                                                                    |
| TMS                     | 55                               | 49                                                                                                                                                   | D6                                                                                                                                                                        | E23                                                                                                                                                                                                                    |
| TDI                     | 42                               | 79                                                                                                                                                   | C11                                                                                                                                                                       | A13                                                                                                                                                                                                                    |
| TDO                     | 30                               | 108                                                                                                                                                  | A18                                                                                                                                                                       | D3                                                                                                                                                                                                                     |
| GND                     | 6, 18, 24, 25,<br>48, 61, 67, 70 | 14, 20, 24, 31, 35,<br>41, 42, 43, 44, 46,<br>47, 66, 85, 102,<br>110, 113, 114, 115,<br>116, 118, 121, 122,<br>132, 133, 143, 152,<br>170, 189, 206 | D4, D5, D16, E4, E5, E6,<br>E15, E16, F5, F15, G5,<br>G15, H5, H15, J5, J15, K5,<br>K15, L5, L15, M5, M15, N5,<br>N15, P4, P5, P15, P16, R4,<br>R5, R15, R16, T4, T5, T16 | A9, A22, A25, A26, B25,<br>B26, D2, E1, E26, F2, G1,<br>G25, G26, H2, J1, J25, I26,<br>K2, L26, M26, N1, N25,<br>P26, R2, T1, U2, U26, V1,<br>V25, W25, Y26, AA2, AB1,<br>AB26, AC26, AE1, AF1,<br>AF2, AF4, AF7, AF20 |
| VCCINT<br>(5.0 V only)  | 14, 21, 28, 57,<br>64, 71        | 10, 19, 30, 45, 112,<br>128, 139, 148                                                                                                                | D15, E8, E10, E12, E14,<br>R7, R9, R11, R13, R14,<br>T14                                                                                                                  | D26, F1, H1, K26, N26, P1,<br>U1, W26, AE26, AF25,<br>AF26                                                                                                                                                             |
| VCCIO<br>(3.3 or 5.0 V) | 15, 37, 60, 79                   | 5, 25, 36, 55, 72,<br>91, 111, 127, 138,<br>159, 176, 195                                                                                            | D14, E7, E9, E11, E13, R6,<br>R8, R10, R12, T13, T15                                                                                                                      | A1, A2, A21, B1, B10, B24,<br>D1, H26, K1, M25, R1, V26,<br>AA1, AC25, AF5, AF8,<br>AF19                                                                                                                               |

Altera Corporation

| Pin Name                         | 84-Pin PLCC,<br>Note (1) | 208-Pin RQFP                                                                                              | 280-Pin PGA,<br>Note (2)                                                                                                                                                                                                                                | 356-Pin BGA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------|--------------------------|-----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| No Connect<br>(N.C.)             | 29                       | 6, 7, 8, 9, 11, 12,<br>13, 15, 16, 17, 18,<br>109, 140, 141, 142,<br>144, 145, 146, 147,<br>149, 150, 151 | B6, K19, L2, L4, L18, L19,<br>M1, M2, M3, M4, M16, M17,<br>M18, M19, N1, N2, N3, N4,<br>N16, N17, N18, N19, P1,<br>P2, P3, P17, P18, P19, R1,<br>R2, R3, R17, R18, R19, T11,<br>T2, T3, T17, T18, T19, U1,<br>U2, U3, U17, U18, U19, V1,<br>V2, V19, W1 | B4, B5, B6, B7, B8, B9,<br>B11, B12, B13, B14, B15,<br>B16, B18, B19, B20, B21,<br>B22, B23, C4, C23, D4,<br>D23, E4, E22, F4, F23, G4<br>H4, H23, J23, K4, L4, L23,<br>N4, P4, P23, R3, R26, T2,<br>T3, T4, T5, T22, T23, T24,<br>T25, T26, U3, U4, U5, U22<br>U23, U24, U25, V2, V3, V4<br>V5, V22, V23, V24, W1,<br>W2, W3, W4, W5, W22,<br>W23, W24, Y1, Y2, Y3, Y4<br>Y5, Y22, Y23, Y24, Y25,<br>AA3, AA4, AA5, AA22,<br>AA23, AA24, AA25, AA26,<br>AB2, AB3, AB4, AB5,<br>AB23, AB24, AB25, AC1,<br>AC2, AC23, AD4, AD23,<br>AE4, AE5, AE6, AE7, AE9<br>AE11, AE12, AE14, AE15,<br>AE20, AE24, AE25, AC20,<br>AE16, AE18, AE19, AE20,<br>AE21, AE22, AE23 |
| VPP, Note (3)                    | 56                       | 48                                                                                                        | C4                                                                                                                                                                                                                                                      | E25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Total User I/O<br>Pins, Note (4) | 56                       | 128                                                                                                       | 164                                                                                                                                                                                                                                                     | 164                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

#### MAX 9000 Programmable Logic Device Family Data Sheet

Notes:
(1) Perform a complete thermal analysis before committing a design to this device package. See Application Note 74 (Evaluating Power for Altern Devices) in the 1999 Data Book.
(2) This package is no offered for EPM9320A devices.
(3) During in-system programming, each device's VPP pin must be connected to the 5.0-V power supply. During normal device operation, the VPP pin is pulled up internally and can be connected to the 5.0-V supply or left unconnected.
(4) Pins that are not listed are user I/O pins.

Altera Corporation

| Revision<br>History | The information contained in the <i>MAX 9000 Programmable Logic Device Family Data Sheet</i> version 5.01 supersedes information published in the <i>MAX 9000 Programmable Logic Device Family Data Sheet</i> version 5.0, which can be found in the <b>1998 Data Book</b> .                                                                                                                                                                                              |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | The <i>MAX 9000 Programmable Logic Device Family Data Sheet</i> version 5.01 contains the following changes:                                                                                                                                                                                                                                                                                                                                                              |
|                     | <ul> <li>Note (1) in Table 4 has been reworded for clarification.</li> <li>A sentence has been added to the dedicated inputs paragraph referring readers to Figure 2 for more information.</li> <li>An erroneous reference to UESCODE in the IEEE 1149.1 (JTAG) Boundary Scan Support section has been removed.</li> <li>The graph slope in Figure 15 has been corrected.</li> <li>Minor textual, illustration, and style changes were made to the data sheet.</li> </ul> |

Altera Corporation

## AII.8. Altera device package information for EPM9320ALC84-10

Altera Device Package Information

#### 84-Pin Plastic J-Lead Chip Carrier (PLCC)

All dimensions and tolerances conform to ASME Y14.5M – 1994. Controlling dimension is in inches. Pin 1 is generally indicated by an indentation in the plastic body, in Pin 1's proximity, on package surface.

| Package Information        |                                                |  |
|----------------------------|------------------------------------------------|--|
| Description                | Specification                                  |  |
| Ordering Code Reference    | L                                              |  |
| Package Acronym            | PLCC                                           |  |
| Leadframe Material         | Copper                                         |  |
| Lead Finish (Plating)      | Regular: 85Sn:15Pb (Typ.)<br>Pb-free: Matte Sn |  |
| JEDEC Outline Reference    | MS-018 Variation: AF                           |  |
| Maximum Lead Coplanarity   | 0.004 inches (0.10mm)                          |  |
| Weight                     | 6.8 g                                          |  |
| Moisture Sensitivity Level | Printed on moisture barrier bag                |  |

| Package Outline Dimension Table |           |       |       |  |
|---------------------------------|-----------|-------|-------|--|
| Cumhal                          | Inches    |       |       |  |
| Symbol                          | Min.      | Nom.  | Max.  |  |
| А                               | 0.165     | 0.172 | 0.180 |  |
| A1                              | 0.020     | -     | -     |  |
| A2                              | 0.150 TYP |       |       |  |
| D                               | 1.185     | 1.190 | 1.195 |  |
| D1                              | 1.150     | 1.154 | 1.158 |  |
| D2                              | 1.082     | 1.110 | 1.138 |  |
| E                               | 1.185     | 1.190 | 1.195 |  |
| E1                              | 1.150     | 1.154 | 1.158 |  |
| E2                              | 1.082     | 1.110 | 1.138 |  |
| b                               | 0.013     | -     | 0.021 |  |
| С                               | 0.008 TYP |       |       |  |
| е                               | 0.050 TYP |       |       |  |

Altera Corporation

DS-84PLCC05-1.0



Altera Corporation

101 Innovation Drive San Jose, CA 95134 (408) 544-7000 http://www.altera.com Copyright © 2005 Altera Corporation. All rights reserved. Altera, The Programmable Solutions Company, the stylized Altera logo, specific device designations, and all other words and logos that are identified as trademarks and/or service marks are, unless noted otherwise, the trademarks and service marks of Altera Copyrights. All other products or service names are the property of their respective holders. Altera products are protected under numerous US. and foreign patents and pending applications, maskwork rights, and copyrights. Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of bolain the latest to in writing by Altera Corporation. Sterier eadvised to obtain the latest placing orders for products or services.



# Annex III. VHDL code

### Contents

| AIII.1         | Masters: VHDL code of the block "Recognize Header"            | 244 |
|----------------|---------------------------------------------------------------|-----|
| AIII.2         | Masters: VHDL code of the block "Buffer"                      | 247 |
| AIII.3         | Masters: VHDL code of the block "Parallel Serial Converter"   | 250 |
| AIII.4         | Masters: VHDL code of the block "Multiplexer"                 | 253 |
| AIII.5         | Masters: VHDL code of the block "Compare Header"              | 254 |
| AIII.6         | Masters: VHDL code of the block "Vector to Integer Converter" | 255 |
| AIII.7         | Slaves: VHDL code of the block "Recognize Header "            | 256 |
| AIII.8         | Slaves: VHDL code of the block "Buffer"                       | 259 |
| AIII.9         | Slaves: VHDL code of the block "Parallel Serial Converter"    | 261 |
| <b>AIII.10</b> | Slaves: VHDL code of the block "Multiplexer"                  | 263 |
| AIII.11        | Slaves: VHDL code of the block "Compare Header"               | 264 |
| <b>AIII.12</b> | Slaves: VHDL code of the block "Compare Payload"              | 265 |

## AIII.1. Masters: VHDL code of the block "Recognize Header"

-- RECOGNIZE HEADER BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all;

#### ENTITY RECOGNIZE\_HEADER\_TX IS

| PORT |                |      |                            |
|------|----------------|------|----------------------------|
| (    |                |      |                            |
|      | END_TX         | :IN  | STD_LOGIC_VECTOR (0 TO 1); |
|      | RESET_TX_1     | :IN  | STD_LOGIC;                 |
|      | COMPARE        | :IN  | STD LOGIC VECTOR (0 TO 1); |
|      | CLK            | :IN  | STD LOGIC;                 |
|      | TX PACKET      | :IN  | STD LOGIC;                 |
|      | LISTEN         | :OUT | STD LOGIC;                 |
|      | WAIT TX        | :OUT | STD LOGIC;                 |
|      | STATE          | :OUT | STD LOGIC VECTOR (0 TO 2); |
|      | RESET TX 2     | :OUT | STD LOGIC;                 |
|      | READ PN NUMBER | :OUT | STD LOGIC;                 |
|      | SEL            | :OUT | STD LOGIC VECTOR (0 TO 1)  |
| );   |                |      | ( )                        |

#### END RECOGNIZE\_HEADER\_TX;

#### ARCHITECTURE A OF RECOGNIZE\_HEADER\_TX IS

| SIGNAL count                 | :INTEGER RANGE 20 DOWNTO 0; |
|------------------------------|-----------------------------|
| SIGNAL recog_sync            | $:STD\_LOGIC := '0';$       |
| SIGNAL recog_id_rx           | $:STD\_LOGIC := '0';$       |
| SIGNAL sel signal            | :STD LOGIC VECTOR (0 TO 1); |
| SIGNAL listen_signal         | :STD_LOGIC;                 |
| SIGNAL state_signal          | :STD_LOGIC_VECTOR (0 TO 2); |
| SIGNAL state_signal_aux      | :STD_LOGIC_VECTOR (0 TO 2); |
| SIGNAL reset_tx_2_signal     | :STD_LOGIC;                 |
| SIGNAL timeout_signal        | :INTEGER RANGE 19 TO 0;     |
| SIGNAL waiting_flag          | :STD_LOGIC;                 |
| SIGNAL waiting_time          | :INTEGER RANGE 0 TO 333;    |
| SIGNAL read_pn_number_signal | :STD_LOGIC;                 |
| SIGNAL flag_tx               | :STD_LOGIC;                 |

#### BEGIN

PROCESS (END\_TX, RESET\_TX\_1, COMPARE, CLK, TX\_PACKET) BEGIN

#### wait until CLK'event AND CLK = '1';

```
IF (TX_PACKET = '1') THEN

flag_tx <= '1';

listen_signal <= '0';

sel_signal <= "00";

state_signal_aux <= "000";

state_signal <= "000";

recog_sync <= '0';

recog_id_rx <= '0';

count <= 0;

END IF;
```

IF (read\_pn\_number\_signal = '1') THEN read\_pn\_number\_signal <= '0'; END IF;

```
IF (reset_tx_2_signal = '1') THEN
                             reset tx 2 signal \leq 0';
                             flag_tx <= '0':
                             read_pn_number_signal <= '1';</pre>
                   END IF;
                   IF (waiting flag = '1') THEN
                             waiting time <= waiting time - 1;
                             IF (waiting_time = 0) THEN
                                       waiting flag \leq 0';
                                       reset tx 2 signal \leq 1';
                             END IF;
                   END IF;
                   IF (RESET_TX_1 = '1') THEN
                             reset_tx_2_signal <= '1';
                   END IF;
                   IF state_signal_aux /= "000" THEN
                             state_signal_aux <= "000";</pre>
                   END IF;
                   IF (flag tx = '1' AND waiting flag = '0') THEN
                             CASE state_signal IS
                                       WHEN "000" =>
                                                IF END TX = "01" THEN
                                                          state_signal_aux <= "001";</pre>
                                                          state signal <= "001";
                                                          listen signal <= '1';
                                                          timeout signal \leq 19;
                                                END IF;
                                       WHEN "001" =>
                                                IF (timeout_signal = 0) THEN
                                                          reset_tx_2_signal <= '1';
                                                ELSIF (recog sync = '0') THEN
                                                          timeout signal <= timeout signal - 1;
                                                END IF;
                                                IF (COMPARE = "01" AND recog sync = '0') THEN
                                                          count \leq 0;
                                                          recog_sync <= '1';
                                                          sel signal \leq "10";
                                                ELSIF (COMPARE = "01" AND recog sync = '1') THEN
                                                          count \le count + 1;
                                                          recog id rx \leq 1';
                                                          listen_signal <= '0';
                                                          state_signal_aux <= "010";</pre>
                                                          state signal <= "001";
                                                ELSIF recog \overline{\text{sync}} = '1' THEN
                                                          \operatorname{count} \ll \operatorname{count} + 1;
                                                END IF;
                                                IF (count = 7 AND recog id rx = '0' AND COMPARE /= "11" AND
COMPARE /= "01") THEN
                                                          reset_tx_2_signal <= '1';
                                                END IF;
                                                IF (COMPARE = "11") THEN
                                                          waiting_flag <= '1';
                                                          waiting time <= 333;
                                                END IF;
                                                IF END_TX = "10" THEN
                                                          sel signal \leq "01";
                                                          state signal aux <= "011";
                                                          state signal <= "011";
                                                          listen signal <= '1';
                                                          recog sync \leq 0';
```

```
recog_id_rx <= '0';
                       \operatorname{count} \leq 0;
                       timeout signal <= 19;
           END IF;
WHEN "011" =>
           IF (timeout_signal = 0) THEN
           reset_tx_2_signal <= '1';
ELSIF (recog_sync = '0') THEN
                       timeout_signal <= timeout_signal - 1;</pre>
           END IF:
           IF (COMPARE = "01" AND recog sync = '0') THEN
                      \operatorname{count} \leq 0;
                       recog sync <= '1';
                       sel_signal <= "10";
           ELSIF (COMPARE = "01" AND recog_sync = '1') THEN
                       \operatorname{count} \ll \operatorname{count} + 1;
                       recog id rx \leq 1';
                       listen_signal <= '0';
                       state_signal_aux <= "111";</pre>
                       state signal <= "011";
           ELSIF recog_sync = '1' THEN
                       \operatorname{count} \leq \operatorname{count} + 1;
           END IF;
           IF (count = 8 AND recog_id_rx = '0') THEN
                       reset_tx_2_signal <= '1';
           ELSIF (count = 20) THEN
recog_sync <= '0';
                       recog_id_rx \ll 0';
                       \operatorname{count} \leq 0;
           END IF;
```

WHEN OTHERS => NULL;

END CASE; END IF;

END PROCESS;

RESET\_TX\_2 <= reset\_tx\_2\_signal; SEL <= sel\_signal; LISTEN <= listen\_signal; STATE <= state\_signal\_aux; WAIT\_TX <= waiting\_flag; READ\_PN\_NUMBER <= read\_pn\_number\_signal;

## AIII.2. Masters: VHDL code of the block "Buffer"

-- BUFFER BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all;

ENTITY BUFFER\_TX IS

PORT (

| RESET TX 2     | :IN  | STD LOGIC;                 |
|----------------|------|----------------------------|
| DATA, CLK      | :IN  | STD_LOGIC;                 |
| TX_PACKET      | :IN  | STD_LOGIC;                 |
| WAIT_TX        | :IN  | STD_LOGIC;                 |
| STATE          | :IN  | STD_LOGIC_VECTOR (0 TO 2); |
| START_TX       | :OUT | STD_LOGIC;                 |
| RESET_TX_1     | :OUT | STD_LOGIC;                 |
| CORRECT        | :OUT | INTEGER RANGE 0 TO 1023;   |
| PACKET_CORRECT | :OUT | STD_LOGIC                  |
|                |      |                            |

```
);
```

END BUFFER\_TX;

ARCHITECTURE A OF BUFFER\_TX IS

|         | SIGNAL count_1            | :INTEGER RANG    | E 8 DOWNTO 0;             |
|---------|---------------------------|------------------|---------------------------|
|         | SIGNAL count 2            | :INTEGER RANG    | E 10 DOWNTO 0;            |
|         | SIGNAL flag_buffer        | :BOOLEAN := fals | se;                       |
|         | SIGNAL mem_ind            | :INTEGER RANG    | E 7 DOWNTO $0 := 0;$      |
|         | SIGNAL start_tx_signal    | :STD_LOGIC := '0 | )';                       |
|         | SIGNAL state_signal       | :STD_LOGIC_VE    | CTOR (0 TO 2);            |
|         | SIGNAL id_tx_signal       | :STD_LOGIC_VE    | CTOR (0 TO 7);            |
|         | SIGNAL ack_signal         | :STD_LOGIC;      |                           |
|         | SIGNAL set                |                  |                           |
| :STD_LC | DGIC;                     |                  |                           |
|         | SIGNAL reset_tx_signal    | :STD_LOGIC;      |                           |
|         | SIGNAL count_packet_corre | ect_signal       | :INTEGER RANGE 0 TO 1023; |
|         | SIGNAL packet_correct_sig | nal              | :STD_LOGIC;               |
|         |                           |                  |                           |

#### BEGIN

PROCESS (RESET\_TX\_2, DATA, CLK, TX\_PACKET, WAIT\_TX, STATE) BEGIN

wait until CLK'event AND CLK = '1';

```
IF (reset_tx_signal = '1') THEN

reset_tx_signal <= '0';

END IF;

IF (packet_correct_signal = '1') THEN

packet_correct_signal <= '0';

END IF;

CASE STATE IS

WHEN "000" =>

IF (set = '0' AND TX_PACKET = '1' AND WAIT_TX = '0') THEN

start_tx_signal <= '1';

ELSE

start_tx_signal <= '0';

END IF;

WHEN "010" | "111" =>
```

```
state signal <= STATE;
                                       count 1 \leq 0;
                                       \operatorname{count}^{-}2 \leq 0;
                                       flag buffer <= true;
                                       mem ind \leq 0;
                                       reset_tx_signal <= '0';
                                       id tx signal \leq (OTHERS => '0');
                             WHEN OTHERS =>
                                       state_signal <= STATE;</pre>
                   END CASE;
                   IF (RESET TX 2 = '1') THEN
                             set <= '0';
                   END IF;
                   CASE state_signal IS
                             WHEN "010" =>
                                       IF flag buffer THEN
                                                CASE count_1 IS
                                                           WHEN 0 to 7 \Rightarrow
                                                                    id tx signal(mem ind) <= DATA;
                                                                    mem ind \leq mem ind +1;
                                                           WHEN 8 \Rightarrow
                                                                    flag buffer <= false;
                                                                    IF (id_tx_signal /= X"35") THEN
                                                                              reset_tx_signal <= '1';
                                                                    ELSE
                                                                              start tx signal <= '1';
                                                                    END IF:
                                                           WHEN OTHERS =>
                                                                    NULL;
                                                 END CASE;
                                                 count 1 \leq \text{count } 1 + 1;
                                       END IF;
                             WHEN "111" =>
                                       IF flag_buffer THEN
                                                 CASE count 2 IS
                                                           WHEN 0 to 7 \Rightarrow
                                                                    id_tx_signal(mem_ind) <= DATA;
                                                                    mem ind \leq mem_{ind} + 1;
                                                           WHEN 8 =>
                                                                    NULL;
                                                           WHEN 9 \Rightarrow
                                                                    ack_signal <= DATA;
                                                           WHEN 10 =>
                                                                    flag buffer <= false;
                                                                    IF ((id tx signal \neq X"35") OR (ack signal = '0')
)THEN
                                                                              reset_tx_signal <= '1';
                                                                    ELSIF ack signal = '1' THEN
                                                                              reset tx signal <= '1';
                                                                              count_packet_correct_signal <=</pre>
count_packet_correct_signal + 1;
                                                                              packet_correct_signal <= '1';</pre>
                                                                    END IF;
                                                           WHEN OTHERS =>
                                                                    NULL;
                                                 END CASE;
                                                 \operatorname{count}_2 \leq \operatorname{count}_2 + 1;
                                       END IF;
                                       WHEN OTHERS =>
                                                NULL;
                   END CASE;
```

#### END PROCESS;

START\_TX <= start\_tx\_signal; RESET\_TX\_1 <= reset\_tx\_signal; CORRECT <= count\_packet\_correct\_signal; PACKET\_CORRECT <= packet\_correct\_signal;

## AIII.3. Masters: VHDL code of the block "Parallel Serial Converter"

-- PARALLEL SERIAL CONVERTER BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all;

#### ENTITY PARALLEL\_SERIAL\_CONVERTER\_TX IS

| PORT |            |      |                            |
|------|------------|------|----------------------------|
| (    |            |      |                            |
|      | RESET_TX_2 | :IN  | STD_LOGIC;                 |
|      | STATE      | :IN  | STD_LOGIC_VECTOR (0 TO 2); |
|      | START_TX   | :IN  | STD_LOGIC;                 |
|      | CLK        | :IN  | STD_LOGIC;                 |
|      | DATA_TX    | :OUT | STD_LOGIC;                 |
|      | END_TX     | :OUT | STD_LOGIC_VECTOR (0 TO 1)  |
| ):   |            |      |                            |

);

#### END PARALLEL SERIAL CONVERTER TX;

#### ARCHITECTURE A OF PARALLEL\_SERIAL\_CONVERTER\_TX IS

| SIGNAL count_1           | :INTEGER RANGE 27 DOWNTO 0;             |
|--------------------------|-----------------------------------------|
| SIGNAL count_2           | :INTEGER RANGE 284 DOWNTO 0;            |
| SIGNAL mem_ind_1         | :INTEGER RANGE 0 TO 7;                  |
| SIGNAL mem_ind_2         | :INTEGER RANGE 0 TO 15;                 |
| SIGNAL flag_tx           | :BOOLEAN := false;                      |
| SIGNAL end_tx_signal     | :STD_LOGIC_VECTOR (0 TO 1);             |
| SIGNAL state_signal      | :STD_LOGIC_VECTOR (0 TO 2);             |
|                          |                                         |
| CONSTANT id_tx           | :STD_LOGIC_VECTOR (0 TO 7) := X"35";    |
| CONSTANT id_rx           | :STD_LOGIC_VECTOR (0 TO 7) := X"CA";    |
| CONSTANT sync_trail_le   | :STD_LOGIC_VECTOR (0 TO 7) := X"A2";    |
| CONSTANT sync_trail_data | :STD_LOGIC_VECTOR (0 TO 7) := X"96";    |
| CONSTANT payload_a       | :STD_LOGIC_VECTOR (0 TO 15) := X"96D4"; |
| CONSTANT payload_b       | :STD_LOGIC_VECTOR (0 TO 7) := X"CA";    |
| CONSTANT th_flag         | :STD_LOGIC := '0';                      |
| CONSTANT th_code         | :STD_LOGIC := '0';                      |
| CONSTANT fec_crc_le      | :STD_LOGIC := '0';                      |
| CONSTANT PDU_number      | :STD_LOGIC := '0';                      |
| CONSTANT N_pdu           | :STD_LOGIC := '0';                      |
| CONSTANT ack             | :STD_LOGIC := '0';                      |
| CONSTANT fec_crc_data    | :STD_LOGIC := '0';                      |
|                          |                                         |

BEGIN

PROCESS (RESET\_TX\_2, STATE, START\_TX, CLK) BEGIN

wait until CLK'event AND CLK = '1';

```
IF START TX = '1' THEN
          flag tx \leq true;
          count_1 <= 0;
          \operatorname{count}^{-}2 \leq 0;
          mem ind 1 \leq 7;
          mem_ind_2 <= 15;
END IF;
IF STATE /= "000" THEN
          IF STATE = "111" THEN
                   state_signal <= "000";</pre>
          ELSE
                    state_signal <= STATE;</pre>
```

```
END IF;
                          END IF;
                          IF (RESET TX 2 = 1) THEN
                                    state_signal <= "000";
                          END IF:
                          IF (end tx signal = "01" OR end tx signal = "10") THEN
                                   end_tx_signal <= "00";
                          END IF;
                          CASE state signal IS
                                    WHEN "000" =>
                                            IF flag_tx THEN
                                                     CASE count_1 IS
                                                              WHEN 0 to 7 \Rightarrow
                                                                       DATA TX \leq sync trail le(mem ind 1);
                                                              WHEN 8 to 15 =>
                                                                       DATA_TX <= id_rx(mem_ind_1);
                                                              WHEN 16 to 23 =>
                                                                       DATA_TX <= id_tx(mem_ind_1);
                                                              WHEN 24 =>
                                                                       DATA TX \leq th flag;
                                                              WHEN 25 =>
                                                                       DATA_TX <= th_code;
                                                              WHEN 26 =>
                                                                       DATA TX <= fec crc le;
                                                              WHEN 27 =>
                                                                       DATA TX \leq 0';
                                                                       end_tx_signal <= "01";
                                                                       flag tx <= false;
                                                              WHEN OTHERS =>
                                                                       NULL;
                                                     END CASE;
                                                     count 1 \leq \text{count } 1 + 1;
                                                     mem ind 1 \le \text{mem} ind 1 - 1;
                                            END IF;
                                    WHEN "010" =>
                                            IF flag_tx THEN
                                                     CASE count 2 IS
                                                              WHEN 0 to 7 \Rightarrow
                                                                       DATA TX <=
sync_trail_data(mem_ind_1);
                                                                       mem_ind_1 \le mem_ind_1 - 1;
                                                              WHEN 8 to 15 =>
                                                                       DATA TX \leq id rx(mem ind 1);
                                                                       mem ind 1 \le \text{mem} ind \overline{1} - 1;
                                                              WHEN 16 to 2\overline{3} = \overline{)}
                                                                       DATA_TX <= id_tx(mem_ind_1);
                                                                       mem_ind_1 \le mem_ind_1 - 1;
                                                              WHEN 24 =>
                                                                       DATA_TX <= PDU_number;
                                                              WHEN 25 =>
                                                                       DATA_TX <= N_pdu;
                                                              WHEN 26 =>
                                                                       DATA_TX <= ack;
                                                              WHEN 27 TO 90 =>
                                                                       DATA_TX <= payload_a(mem_ind_2);
                                                                       mem_ind_2 <= mem_ind_2 - 1;
                                                              WHEN 91 TO 154 =>
                                                                       DATA TX <= payload b(mem ind 1);
                                                                       mem ind 1 \le \text{mem} ind 1 - 1;
                                                              WHEN 155 TO 21\overline{8} =>
                                                                       DATA TX \leq payload a(mem ind 2);
```

```
mem_ind_2 <= mem_ind_2 - 1;
WHEN 219 TO 282 =>
DATA_TX <= payload_b(mem_ind_1);
mem_ind_1 <= mem_ind_1 - 1;
WHEN 283 =>
DATA_TX <= fec_crc_data;
WHEN 284 =>
end_tx_signal <= "10";
flag_tx <= false;
WHEN OTHERS =>
NULL;
END CASE;
count_2 <= count_2 + 1;
END IF;
WHEN OTHERS =>
NULL;
```

END CASE;

END PROCESS;

END\_TX <= end\_tx\_signal;

## AIII.4. Masters: VHDL code of the block "Multiplexer"

-- MULTIPLEXER BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all;

ENTITY MULTIPLEXER\_TX IS

PORT (

| SEL    | :IN  | STD_LOGIC_VECTOR (0 TO 1);    |
|--------|------|-------------------------------|
| OUTPUT | :OUT | STD LOGIC VECTOR (7 DOWNTO 0) |
| 001101 | .001 | STD_EOGIC_VECTOR (/ DOWNTO 0) |

END MULTIPLEXER\_TX;

);

ARCHITECTURE A OF MULTIPLEXER\_TX IS

| :STD_LOGIC_VECTOR (0 TO 7) := X"8E"; |
|--------------------------------------|
| :STD_LOGIC_VECTOR (0 TO 7) := X"ED"; |
| :STD_LOGIC_VECTOR (0 TO 7) := X"CA"; |
|                                      |

BEGIN

PROCESS (SEL) BEGIN

```
CASE SEL IS
WHEN "00" =>
OUTPUT <= sync_trail_lc;
WHEN "01" =>
OUTPUT <= sync_trail_ack;
WHEN "10" =>
OUTPUT <= id_rx;
WHEN OTHERS =>
NULL;
END CASE;
```

END PROCESS;

## AIII.5. Masters: VHDL code of the block "Compare Header"

-- COMPARE HEADER BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all;

ENTITY COMPARE\_HEADER\_TX IS

PORT (

| DATA_A  | :IN  | STD_LOGIC_VECTOR (0 TO 7); |
|---------|------|----------------------------|
| DATA_B  | :IN  | STD_LOGIC_VECTOR (0 TO 7); |
| CLEARN  | :IN  | STD_LOGIC;                 |
| COMPARE | :OUT | STD_LOGIC VECTOR (0 TO 1)  |
| COMPARE | :OUT | STD_LOGIC_VECTOR (0 TO 1)  |

);

END COMPARE HEADER TX;

ARCHITECTURE A OF COMPARE\_HEADER\_TX IS

BEGIN

```
PROCESS (DATA_A, DATA_B, CLEARN)
BEGIN
IF(CLEARN = '1') THEN
IF (DATA_A = DATA_B) THEN
COMPARE <= "01";
ELSIF (DATA_B = X"CA" AND DATA_A = X"C1") THEN
COMPARE <= "11";
ELSE
COMPARE <= "00";
END IF;
ELSE
COMPARE <= "00";
END IF;
```

END PROCESS;

## AIII.6. Masters: VHDL code of the block "Vector to Integer Converter"

-- CONVERTER VECTOR BIT TO INTEGER BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all; USE ieee.std\_logic\_arith.all; use ieee.std\_logic\_unsigned.all;

#### ENTITY CONV\_VECTOR\_TO\_INTEGER\_TX IS

PORT

(

);

| PN_NUMBER_BIT   | :IN  | STD_LOGIC_VECTOR (0 TO 15); |
|-----------------|------|-----------------------------|
| CLK             | :IN  | STD_LOGIC;                  |
| PRESETN         | :IN  | STD_LOGIC;                  |
| READ_PN_NUMBER  | :IN  | STD_LOGIC;                  |
| TX_PACKET       | :OUT | STD_LOGIC;                  |
| COUNT_PACKET_TX | :OUT | INTEGER RANGE 0 TO 1023     |
|                 |      |                             |

#### END CONV\_VECTOR\_TO\_INTEGER\_TX;

ARCHITECTURE A OF CONV\_VECTOR\_TO\_INTEGER\_TX IS

SIGNAL pn\_number\_integer\_signal SIGNAL tx\_packet\_signal SIGNAL tx\_signal SIGNAL count\_packet\_tx\_signal :INTEGER RANGE 0 TO 65535; :STD\_LOGIC; :STD\_LOGIC; :INTEGER RANGE 0 TO 1023;

#### BEGIN

```
PROCESS (PN NUMBER BIT, READ PN NUMBER, PRESETN, CLK)
BEGIN
wait until CLK'event AND CLK = '1';
IF (tx_packet_signal = '1') THEN
        tx packet signal <= '0';
        count packet tx signal <= count packet tx signal + 1;
END IF;
IF (READ PN NUMBER = '1' OR PRESETN = '0') THEN
        pn number integer signal <= CONV INTEGER(PN NUMBER BIT);
        tx\_signal <= '1';
END IF:
IF (pn_number_integer_signal > 0 AND tx_signal = '1') THEN
        pn number integer signal <= pn number integer signal - 1;
ELSIF (pn number_integer_signal = 0 AND tx_signal = '1') THEN
        tx_packet_signal <= '1';</pre>
        tx_signal <= '0';
END IF;
END PROCESS;
```

TX\_PACKET <= tx\_packet\_signal; COUNT\_PACKET\_TX <= count\_packet\_tx\_signal;

### AIII.7. Slaves: VHDL code of the block "Recognize Header"

-- RECOGNIZE HEADER BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all;

#### ENTITY RECOGNIZE\_HEADER\_RX IS

| PORT |  |
|------|--|
| (    |  |

);

| END_TX<br>COMPARE<br>CLK<br>PRESET<br>LISTEN<br>STATE | :IN<br>:IN<br>:IN<br>:IN<br>:OUT<br>:OUT | STD_LOGIC_VECTOR (0 TO 1);<br>STD_LOGIC;<br>STD_LOGIC;<br>STD_LOGIC;<br>STD_LOGIC;<br>STD_LOGIC;<br>STD_LOGIC_VECTOR (0 TO 1); |
|-------------------------------------------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| STATE<br>SEL                                          | :OUT<br>:OUT                             | STD_LOGIC_VECTOR (0 TO 1);<br>STD_LOGIC_VECTOR (0 TO 1)                                                                        |
|                                                       |                                          |                                                                                                                                |

#### END RECOGNIZE\_HEADER\_RX;

#### ARCHITECTURE A OF RECOGNIZE\_HEADER\_RX IS

| :INTEGER RANGE 18 DOWNTO 0; |
|-----------------------------|
| :STD_LOGIC := '0';          |
| :STD_LOGIC := '0';          |
| :STD_LOGIC_VECTOR (0 TO 1); |
| :STD_LOGIC;                 |
| :STD_LOGIC_VECTOR (0 TO 1); |
| :STD_LOGIC_VECTOR (0 TO 1); |
| :INTEGER RANGE 19 TO 0;     |
| :STD_LOGIC;                 |
|                             |

#### BEGIN

PROCESS (END\_TX, COMPARE, CLK, PRESET) BEGIN

wait until CLK'event AND CLK = '1';

IF(PRESET = '0') THEN listen signal  $\leq 1'$ ; sel\_signal <= "00";</pre> state\_signal\_aux <= "00";</pre> state\_signal <= "00";</pre> END IF; IF (reset\_rx\_signal = '1') THEN reset rx signal <= '0'; listen signal <= '1'; sel\_signal <= "00"; state signal aux  $\leq 00"$ ; state\_signal <= "00"; recog\_sync <= '0'; recog id rx  $\leq 0';$  $\operatorname{count} \leq 0$ ; END IF; IF state\_signal\_aux /= "00" THEN state\_signal\_aux <= "00";</pre> END IF;

CASE state\_signal IS

```
WHEN "00" | "01" =>
          IF (COMPARE = '1' AND recog sync = '0') THEN
                     \operatorname{count} \leq 0;
                     recog_sync <= '1';</pre>
                     sel_signal <= "10";
          ELSIF (COMPARE = '1' AND recog sync = '1') THEN
                     \operatorname{count} \ll \operatorname{count} + 1;
                     recog_id_rx <= '1';
                     listen signal \leq 0';
                     state signal aux <= "01";
                     state_signal <= "01";</pre>
          ELSIF recog_sync = '1' THEN
                     \operatorname{count} \ll \operatorname{count} + 1;
          END IF;
          IF (count = 8 AND recog_id_rx = '0') THEN
                     reset rx signal <= '1';
          ELSIF (count = 18) THEN
                     recog_sync <= '0';
                     recog_id_rx \ll 0';
                     \operatorname{count} \leq 0;
          END IF;
          IF END TX = "01" THEN
                     sel signal \leq "01";
                     state_signal_aux <= "10";</pre>
                     state_signal <= "10";
                     listen signal <= '1';
                     timeout signal <= 19;
          END IF:
WHEN "10" =>
          IF (timeout signal = 0) THEN
                     reset rx signal <= '1';
          ELSIF (recog sync = '0') THEN
                     timeout_signal <= timeout_signal - 1;</pre>
          END IF:
          IF (COMPARE = '1' AND recog sync = '0') THEN
                     \operatorname{count} \leq 0;
                     recog_sync <= '1';</pre>
          sel_signal <= "10";
ELSIF (COMPARE = '1' AND recog_sync = '1') THEN
                     \operatorname{count} \leq \operatorname{count} + 1;
                     recog id rx \leq 1';
                     listen signal <= '0';
                     state_signal_aux <= "11";</pre>
                     state signal <= "10";
          ELSIF recog_sync = '1' THEN
                     count \leq count + 1;
          END IF:
          IF (count = 8 AND recog id rx = '0') THEN
                     reset rx signal <= '1';
          END IF;
          IF (END TX = "10") THEN
                     sel_signal <= "00";
                     state_signal_aux <= "00";</pre>
                     state signal <= "00";
                     listen_signal <= '1';
                     recog_sync <= '0';
                     recog_id_rx <= '0';
                     \operatorname{count} \leq 0;
          END IF:
WHEN OTHERS =>
          NULL:
```

END CASE;

#### END PROCESS;

SEL <= sel\_signal; LISTEN <= listen\_signal; STATE <= state\_signal\_aux;

## AIII.8. Slaves: VHDL code of the block "Buffer"

-- BUFFER BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all;

#### ENTITY BUFFER\_RX IS

PORT

(

| END TX     | :IN  | STD LOGIC VECTOR (0 TO 1);  |
|------------|------|-----------------------------|
| DATĀ, CLK  | :IN  | STD_LOGIC;                  |
| STATE      | :IN  | STD_LOGIC_VECTOR (0 TO 1);  |
| PDU_number | :OUT | STD_LOGIC;                  |
| START_TX   | :OUT | STD_LOGIC;                  |
| FEC_CRC_LE | :OUT | STD_LOGIC;                  |
| PAYLOAD    | :OUT | STD_LOGIC_VECTOR (0 TO 15); |
| ID_TX      | :OUT | STD_LOGIC_VECTOR (0 TO 7);  |
| OUTENAB    | :OUT | STD_LOGIC                   |
|            |      |                             |

);

#### END BUFFER\_RX;

#### ARCHITECTURE A OF BUFFER\_RX IS

SIGNAL count\_1 SIGNAL count\_2 SIGNAL flag\_buffer SIGNAL mem\_ind\_1 SIGNAL mem\_ind\_payload SIGNAL start\_tx\_signal SIGNAL state\_signal SIGNAL outenab signal

#### :INTEGER RANGE 9 DOWNTO 0; :INTEGER RANGE 268 DOWNTO 0; :BOOLEAN := false; :INTEGER RANGE 7 DOWNTO 0 := 0; :INTEGER RANGE 15 DOWNTO 0 := 0; :STD\_LOGIC := '0'; :STD\_LOGIC\_VECTOR (0 TO 1):= "00"; :STD\_LOGIC := '0';

#### BEGIN

PROCESS (END TX, DATA, CLK, STATE) BEGIN wait until CLK'event AND CLK = '1'; IF (STATE = "01" OR STATE = "11") THEN count  $1 \le 0;$  $\operatorname{count}_2 \leq 0;$ flag buffer <= true; mem ind  $1 \le 0$ ; mem\_ind\_payload <= 0; END IF; IF start tx signal <= '1' THEN start\_tx\_signal <= '0';</pre> END IF: IF STATE /= "00" THEN state\_signal <= STATE;</pre> END IF; CASE state\_signal IS WHEN "01" => IF flag buffer THEN CASE count 1 IS WHEN 0 to  $7 \Rightarrow$ ID\_TX(mem\_ind\_1) <= DATA;

```
mem_ind_1 \le mem_ind_1 + 1;
                          WHEN 8 =
                                   FEC CRC LE <= DATA;
                          WHEN 9 \Rightarrow
                                   flag buffer <= false;
                                   start_tx_signal <= '1';</pre>
                          WHEN OTHERS =>
                                   NULL;
                 END CASE;
                 count_1 \leq count_1 + 1;
         END IF;
         IF (END TX = "01") THEN
                 ID TX \leq (OTHERS = '0');
         END IF;
WHEN "11" => NULL;
        IF flag buffer THEN
                 CASE count 2 IS
                          WHEN 0 to 7 \Rightarrow
                                   ID TX(mem ind 1) \leq DATA;
                                   mem ind 1 \le mem ind 1 + 1;
                          WHEN 8 =>
                                   PDU number <= DATA;
                          WHEN 9 | 10 =>
                                   NULL;
                          WHEN 11 to 266 =>
                                   PAYLOAD(mem ind payload) <= DATA;
                                   IF outenab_signal = '1' THEN
                                            outenab signal \leq 0';
                                   END IF;
                                   IF mem ind payload = 15 THEN
                                            outenab signal <= '1';
                                            mem ind payload \leq 0;
                                   ELSE
                                         mem_ind_payload <= mem_ind_payload + 1;</pre>
                                   END IF;
                          WHEN 267 =>
                                   outenab signal <= '0';
                          WHEN 268 =>
                                   flag_buffer <= false;
                                   start_tx_signal <= '1';</pre>
                          WHEN OTHERS =>
                                   NULL;
                 END CASE;
                 count 2 \leq \text{count } 2 + 1;
        END IF;
        IF (END TX = "10") THEN
                 ID TX \leq (OTHERS = '0');
                 PDU number <= '0';
                 PAYLOAD \le (OTHERS \implies '0');
                 FEC CRC LE \leq 0';
        END IF;
WHEN OTHERS =>
```

NULL;

END CASE;

END PROCESS;

START\_TX <= start\_tx\_signal; OUTENAB <= outenab\_signal;</pre>

## AIII.9. Slaves: VHDL code of the block "Parallel Serial Converter"

-- PARALLEL SERIAL CONVERTER BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all;

#### ENTITY PARALLEL\_SERIAL\_CONVERTER\_RX IS

PORT (

);

| DATA status | :IN  | STD LOGIC;                 |
|-------------|------|----------------------------|
| STATE       | :IN  | STD_LOGIC_VECTOR (0 TO 1); |
| FEC_CRC_LE  | :IN  | STD_LOGIC;                 |
| START_TX    | :IN  | STD_LOGIC;                 |
| PDU_number  | :IN  | STD_LOGIC;                 |
| CLK         | :IN  | STD_LOGIC;                 |
| DATA_TX     | :OUT | STD_LOGIC;                 |
| END_TX      | :OUT | STD_LOGIC_VECTOR (0 TO 1)  |
|             |      |                            |

#### END PARALLEL SERIAL CONVERTER RX;

#### ARCHITECTURE A OF PARALLEL\_SERIAL\_CONVERTER\_RX IS

wait until CLK'event AND CLK = '1';

| SIGNAL count_1          | :INTEGER RANGE 25 DOWNTO 0 := 0;     |
|-------------------------|--------------------------------------|
| SIGNAL count_2          | :INTEGER RANGE 27 DOWNTO 0 := 0;     |
| SIGNAL mem_ind_1        | :INTEGER RANGE 0 TO $7 := 0$ ;       |
| SIGNAL flag_tx          | :BOOLEAN := false;                   |
| SIGNAL end_tx_signal    | :STD_LOGIC_VECTOR (0 TO 1):= "00";   |
| SIGNAL state_signal     | :STD_LOGIC_VECTOR (0 TO 1):= "00";   |
|                         |                                      |
| CONSTANT id_tx          | :STD_LOGIC_VECTOR (0 TO 7) := X"35"; |
| CONSTANT id_rx          | :STD_LOGIC_VECTOR (0 TO 7) := X"CA"; |
| CONSTANT sync_trail_lc  | :STD_LOGIC_VECTOR (0 TO 7) := X"8E"; |
| CONSTANT sync_trail_ack | :STD_LOGIC_VECTOR (0 TO 7) := X"ED"; |
|                         |                                      |

#### BEGIN

PROCESS (DATA\_status, STATE, FEC\_CRC\_LE, START\_TX, PDU\_number, CLK) BEGIN

IF START\_TX = '1' THEN flag\_tx <= true; count\_1 <= 0; count\_2 <= 0; mem\_ind\_1 <= 7; END IF; IF (state /= "00") THEN state\_signal <= STATE; END IF; IF (end\_tx\_signal = "01" OR end\_tx\_signal = "10") THEN end\_tx\_signal <= "00"; END IF; CASE state\_signal IS WHEN "01" =>

IF flag\_tx THEN CASE count\_1 IS

```
WHEN 0 to 7 \Rightarrow
                                                                       DATA TX <= sync trail lc(mem ind 1);
                                                              WHEN 8 to 15 =>
                                                                       DATA_TX <= id_rx(mem_ind_1);
                                                              WHEN 16 to 23 =>
                                                                       DATA_TX <= id_tx(mem_ind_1);
                                                              WHEN 24 =>
                                                                       DATA TX <= FEC CRC LE;
                                                              WHEN 25 =>
                                                                       DATA_TX <= '0';
                                                                      end_tx_signal <= "01";
                                                                       flag tx <= false;
                                                              WHEN OTHERS =>
                                                                      NULL;
                                                     END CASE;
                                                     count_1 \le count_1 + 1;
                                                     mem_ind_1 \le mem_ind_1 - 1;
                                            END IF;
                                   WHEN "11" =>
                                            IF flag tx THEN
                                                     CASE count 2 IS
                                                              WHEN 0 to 7 \Rightarrow
                                                                      DATA_TX <=
sync_trail_ack(mem_ind_1);
                                                                      mem ind 1 \le \text{mem} ind 1 - 1;
                                                              WHEN 8 to 15 =>
                                                                      DATA TX \leq id rx(mem ind 1);
                                                                      mem ind 1 \le mem ind \overline{1} - 1;
                                                              WHEN 16 to 23 \Rightarrow
                                                                       DATA TX \leq id tx(mem ind 1);
                                                                      mem ind 1 \le \text{mem} ind \overline{1} - 1;
                                                              WHEN 24 =>
                                                                       DATA_TX <= PDU_number;
                                                              WHEN 25 =>
                                                                       DATA TX <= DATA status;
                                                              WHEN 26 =>
                                                                      DATA_TX <= FEC_CRC_LE;
                                                              WHEN 27 =>
                                                                       DATA_TX <= '0';
                                                                      end_tx_signal <= "10";
                                                                       flag tx \leq false;
                                                              WHEN OTHERS =>
                                                                      NULL;
                                                     END CASE;
                                                     count 2 \leq \text{count } 2 + 1;
                                            END IF:
                                   WHEN OTHERS =>
                                            NULL;
                          END CASE;
        END PROCESS;
```

END\_TX <= end\_tx\_signal;

## AIII.10. Slaves: VHDL code of the block "Multiplexer"

-- MULTIPLEXER BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all;

ENTITY MULTIPLEXER\_RX IS

PORT (

);

| SEL    | :IN  | STD_LOGIC_VECTOR (0 TO 1);    |
|--------|------|-------------------------------|
| OUTPUT | :OUT | STD_LOGIC_VECTOR (7 DOWNTO 0) |
|        |      |                               |

END MULTIPLEXER\_RX;

#### ARCHITECTURE A OF MULTIPLEXER\_RX IS

| CONSTANT | sync_trail_le   | :STD_LOGIC_VECTOR (0 TO 7) := X"A2"; |
|----------|-----------------|--------------------------------------|
| CONSTANT | sync_trail_data | :STD_LOGIC_VECTOR (0 TO 7) := X"96"; |
| CONSTANT | id_rx           | :STD_LOGIC_VECTOR (0 TO 7) := X"CA"; |

BEGIN

PROCESS (SEL) BEGIN

CASE SEL IS

```
WHEN "00" =>
OUTPUT <= sync_trail_le;
WHEN "01" =>
OUTPUT <= sync_trail_data;
WHEN "10" =>
OUTPUT <= id_rx;
WHEN OTHERS =>
NULL;
```

END CASE;

END PROCESS;

## AIII.11. Slaves: VHDL code of the block "Compare Header"

-- COMPARE HEADER BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all;

ENTITY COMPARE\_HEADER\_RX IS

PORT (

| DATA_A  | :IN  | STD_LOGIC_VECTOR (0 TO 7); |
|---------|------|----------------------------|
| DATA B  | :IN  | STD LOGIC VECTOR (0 TO 7); |
| CLEARN  | :IN  | STD LOGIC;                 |
| COMPARE | :OUT | STD_LOGIC                  |
|         |      |                            |

);

END COMPARE HEADER RX;

ARCHITECTURE A OF COMPARE\_HEADER\_RX IS

BEGIN

```
PROCESS (DATA_A, DATA_B, CLEARN)
BEGIN
IF(CLEARN = '1') THEN
IF (DATA_A = DATA_B) THEN
COMPARE <= '1';
ELSE
COMPARE <= '0';
END IF;
END IF;
END IF;
END PROCESS;
```

## AIII.12. Slaves: VHDL code of the block "Compare Payload"

-- COMPARE PAYLOAD BLOCK

LIBRARY ieee; USE ieee.std\_logic\_1164.all;

ENTITY COMPARE\_PAYLOAD\_RX IS

PORT (

);

| PAYLOAD_16  | :IN  | STD_LOGIC_VECTOR (0 TO 15); |
|-------------|------|-----------------------------|
| ID_TX       | :IN  | STD_LOGIC_VECTOR (0 TO 7);  |
| OUTENAB     | :IN  | STD_LOGIC;                  |
| STATE       | :IN  | STD_LOGIC_VECTOR (0 TO 1);  |
| CLK         | :IN  | STD_LOGIC;                  |
| DATA_STATUS | :OUT | STD_LOGIC;                  |
| COUNT_ERROR | :OUT | INTEGER RANGE 0 TO 100      |
|             |      |                             |

#### END COMPARE PAYLOAD RX;

#### ARCHITECTURE A OF COMPARE PAYLOAD RX IS

| SIGNAL flag               |           | :BOOLEAN;                               |
|---------------------------|-----------|-----------------------------------------|
| SIGNAL count_error_signal |           | :INTEGER RANGE 0 TO 100;                |
| CONSTANT                  | payload_a | :STD_LOGIC_VECTOR (0 TO 15) := X"96D4"; |
| CONSTANT                  | payload_b | :STD_LOGIC_VECTOR (0 TO 7) := X"CA";    |

#### BEGIN

PROCESS (PAYLOAD\_16, ID\_TX, OUTENAB, STATE, CLK) BEGIN

wait until CLK'event AND CLK = '1';

IF STATE = "11" THEN flag <= true; DATA\_STATUS <= '0'; END IF;

IF OUTENAB = '1' THEN

#### IF flag THEN

```
IF ID_TX /= X"35" THEN

flag <= false;

DATA_STATUS <= '0';

count_error_signal <= count_error_signal + 1;

ELSIF (PAYLOAD_16 = payload_a) THEN

DATA_STATUS <= '1';

ELSIF (PAYLOAD_16 = payload_b & payload_b) THEN

DATA_STATUS <= '1';

ELSE

flag <= false;

DATA_STATUS <= '0';

count_error_signal <= count_error_signal + 1;

END IF;
```

END IF;

END IF;

END PROCESS;

COUNT\_ERROR <= count\_error\_signal;

## Annex IV. Acronyms

Contents

| AIV.1 Acronyms |
|----------------|
|----------------|

## AIV.1. Acronyms

| ACK        | Acknowledgement                         |
|------------|-----------------------------------------|
| A/D        | Analogic/Digital                        |
| AJ         | Anti Jam                                |
| APD        | Avalanche Photodiode                    |
| ARQ        | Automatic Repeat Request                |
| AWGN       | Additive White Gaussian Noise           |
| BER        | Bit Error Rate                          |
| BPF        | Band Pass Filter                        |
| BPS        | Bits Per Second                         |
| BPSK       | Binary Phase Shift Keying               |
| BTMA       | Busy Tone Multiple Access               |
| BW         | Band Width                              |
| CA (CSMA)  | Collision Avoidance                     |
| CD (CSMA)  | Collision Detection                     |
| CDMA       | Code Division Multiple Access           |
| CRC        | Cyclic Redundancy Check                 |
| CSMA       | Carrier Sense Multiple Access           |
| CTS        | Clear To Send                           |
| D/A        | Digital/Analogic                        |
| DBTMA      | Dual BTMA                               |
| DCF        | Distributed Coordination Function       |
| DIFS       | DCF Interframe Space                    |
| DFWMAC     | Distributed Foundation Wireless MAC     |
| DLC        | Data Link Control                       |
| DS         | Direct Sequence                         |
| DSSS       | Direct Sequence Spread Spectrum         |
| EPLD       | Erasable Programmable Logic Device      |
| FCC        | Federal Communication Commission        |
| FDMA       | Frequency Division Multiple Access      |
| FEC        | Forward Error Correction                |
| FDTD       | Finite Differences Time Domain          |
| FHSS       | Frequency Hopping Spread Spectrum       |
| FIR (IrDA) | Fast InfraRed                           |
| FOV        | Field Of View                           |
| FPGA       | Field Programmable Gate Array           |
| FWM        | Four Wave Mixing                        |
| GMSK       | Gaussian Minimum Shift Keying           |
| GPS        | Global Positioning System               |
| GTFC       | Grupo de Tecnología Fotónica y          |
|            | Comunicaciones (ULPGC)                  |
| HPF        | High Pass Filter                        |
| ID         | Identity code                           |
| IEEE       | Institute of Electrical and Electronics |
|            | Engineers                               |

| IM            | Intensity Modulation                    |
|---------------|-----------------------------------------|
| IrDA          | InfraRed Data Association               |
| IRED          | InfraRed Emitting Diode                 |
| ISM           | Industrial Scientific and Medical       |
| ISO           | International Standardization           |
|               | Organization                            |
| ISP           | In System Programmability               |
| JTAG          | Joint Test Action Group                 |
| LAN           | Local Area Network                      |
| LASER         | Light Amplification by Stimulated       |
|               | Emission of Radiation                   |
| LED           | Light Emitting Diode                    |
| LC PDU        | Link Confirm PDU                        |
| LE PDU        | Link Establish PDU                      |
| LLC           | Logical Link Control                    |
| LOS           | Line Of Sight                           |
| LPF           | Low Pass Filter                         |
| LPI           | Low Probability of Intercept            |
| MAC           | Medium Access Control                   |
| MACA          | Medium Access with Collision Avoidance  |
| MAN           | Metropolitan Area Network               |
| MB            | Multi Band                              |
| MIR (IrDA)    | Medium InfraRed                         |
| ML            | Maximum Likelihood                      |
| МОМ           | Method Of Moment                        |
| MUI           | Multi User Interference                 |
| NAV           | Net Allocation Vector                   |
| NRZ           | Non Return to Zero                      |
| NTIA          | National Telecommunications and         |
| 0.00          | Information Administration              |
| OCS           | Optical Communication System            |
| OFDM          | Orthogonal Frequency Division Multiplex |
|               | Optical Orthogonal Codes                |
|               | On Off Keying                           |
|               | Open System Interconnection             |
| PAM           | Pulse Amplitude Modulation              |
|               | Point Coordination Function             |
| PDU           | Protocol Data Unit                      |
|               | Physical layer                          |
| PIFS<br>DIN   | PCF Interframe Space                    |
|               | Positive Intrinsic Negative             |
| PINU DDM      | Picolvet Coorainator                    |
|               | Puise Position Modulation               |
| PKNG<br>DDMA  | Pseudo Kanaom Number Generator          |
| rkivia<br>Ded | Packet Reservation Multiple Access      |
|               | Power Spectral Density                  |
| <b>VAM</b>    | Quadrature Amplitude Modulation         |

| RF          | Radio Frequency                         |
|-------------|-----------------------------------------|
| RTS         | Request To Send                         |
| SER         | Symbol Error Rate                       |
| SIFS        | Short Interframe Space                  |
| SIR (IrDA)  | Serial InfraRed                         |
| SIR         | Signal to Interference Ratio            |
| SNR         | Signal to Noise Ratio                   |
| SNIR        | Signal to Noise plus Interference Ratio |
| SPM         | Self Phase Modulation                   |
| SS          | Spread Spectrum                         |
| STI         | Simulation Time Interval                |
| TDMA        | Time Division Multiple Access           |
| TH          | Time Hopping                            |
| THSS        | Time Hopping Spread Spectrum            |
| USB         | Universal Serial Bus                    |
| UFIR (IrDA) | Ultra Fast InfraRed                     |
| UWB         | Ultra Wide Band                         |
| VFIR (IrDA) | Very Fast InfraRed                      |
| WDMA        | Wavelength Division Multiple Access     |
| WPAN        | Wireless Personal Area Networks         |
| XOR         | eXclusive OR                            |
Author's address: Eugenio Manlio Ducci Via Cagliari, 29 – 95127 Catania, Italy Web telephone: 06452218954 E-mail: em.ducci@gmail.com