# Reconfigurable Signal Processing and Hardware Architecture for Broadband Wireless Communications # **Ying-Chang Liang** Institute for InfoComm Research (I2R), 21 Heng Mui Keng Terrace, Singapore 119613 Email: ycliang@i2r.a-star.edu.sg # Sayed Naveen Institute for InfoComm Research (I2R), 21 Heng Mui Keng Terrace, Singapore 119613 Email: naveen@i2r.a-star.edu.sg ## Santosh K. Pilakkat Institute for InfoComm Research (I2R), 21 Heng Mui Keng Terrace, Singapore 119613 Email: pilakkat@i2r.a-star.edu.sg ## Ashok K. Marath Institute for InfoComm Research (I2R), 21 Heng Mui Keng Terrace, Singapore 119613 Email: ashok@i2r.a-star.edu.sg Received 1 October 2004; Revised 22 April 2005 This paper proposes a broadband wireless transceiver which can be reconfigured to any type of cyclic-prefix (CP) -based communication systems, including orthogonal frequency-division multiplexing (OFDM), single-carrier cyclic-prefix (SCCP) system, multicarrier (MC) code-division multiple access (MC-CDMA), MC direct-sequence CDMA (MC-DS-CDMA), CP-based CDMA (CP-CDMA), and CP-based direct-sequence CDMA (CP-DS-CDMA). A hardware platform is proposed and the reusable common blocks in such a transceiver are identified. The emphasis is on the equalizer design for mobile receivers. It is found that after block despreading operation, MC-DS-CDMA and CP-DS-CDMA have the same equalization blocks as OFDM and SCCP systems, respectively, therefore hardware and software sharing is possible for these systems. An attempt has also been made to map the functional reconfigurable transceiver onto the proposed hardware platform. The different functional entities which will be required to perform the reconfiguration and realize the transceiver are explained. Keywords and phrases: reconfigurable signal processing, broadband communications, software-defined radio, cyclic prefix, frequency-domain equalization. # 1. INTRODUCTION A number of wireless standards govern personal wireless communications, to name a few, GSM and CDMA for 2G cellular networks; WCDMA, CDMA-2000, and TDS-CDMA for 3G cellular networks; IEEE 802.11a/b/g for wireless local area networks; IEEE 802.16 for wireless wide area networks (WiMAX); and IEEE 802.15 for personal area networks (PAN). In order to satisfy the need of customers' mobility, the designed radio transceivers should not be tied to any specific network. Software-defined radios (SDRs) [1] or cognitive radios (CRs) [2] are the well-suited implementations of such network independent radios. Different frame format and modulation schemes have been proposed for different networks. For example, orthogonal frequency-division multiplexing (OFDM) [3] has been adopted in IEEE 802.11a and IEEE 802.11g, and IEEE 802.16. Single-carrier cyclic-prefix (SCCP) system is selected for IEEE 802.16 as well. Cyclic-prefix (CP) -based CDMA systems are considered for beyond 3G systems. For example, CP-CDMA and CP-based direct-sequence CDMA (CP-DS-CDMA) are candidate schemes for enhanced versions of 3G DS-CDMA systems [4, 5, 6, 7]; multicarrier CDMA (MC-CDMA) and multicarrier direct-sequence CDMA (MC-DS-CDMA) [8] are being extensively studied for potential adoption in beyond 3G (B3G) or fourth-generation (4G) cellular This is an open access article distributed under the Creative Commons Attribution License, which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited. systems [10, 21]. The common feature of these systems is that they are block-based transmission systems, and a CP portion is inserted to each data block in order to suppress the interblock interference (IBI) and to simplify the receiver design. SDR structures and implementations have been explored in [11, 12, 13, 14, 15, 16, 17, 18, 19] in different ways. In this paper, we propose a universal mobile transceiver which is configurable to any type of CP-based systems. We present a hardware platform for the proposed transceiver and identify the reusable common blocks. In particular, a study of the equalizer design at the mobile terminals is carried out for each system. Single-user environments are considered for OFDM and SCCP systems. For CDMA multiuser systems, we target a receiver architecture for the downlink only. It is found that after block despreading operation, MC-DS-CDMA and CP-DS-CDMA have the same equalization blocks as OFDM and SCCP systems, respectively, showing that hardware and software sharing is possible for these systems. More specifically, denoting N and G as the block size and processing gain, respectively, these two systems perform signal detection of N symbols over G consecutive time blocks. However, MC-CDMA and CP-CDMA require only one time block to perform signal detection. The receiver complexity of MC-CDMA and CP-CDMA can be much higher if near ML detection is required [5] due to the requirement of N-dimensional signal detection within each time block. In [11], a reconfigurable architecture for multicarrier based CDMA systems is proposed. Specifically, the systems discussed there include MC-CDMA, MC-DS-CDMA, and MT-CDMA of [8] only. The architecture proposed in our paper is more generic in the sense that it can be reconfigured to support both multicarrier systems and single-carrier systems, including SCCP, CP-CDMA, and CP-DS-CDMA. Furthermore, we propose a hardware platform to support the reconfigurable architecture. An attempt has been made to map the functional reconfigurable transceiver onto the proposed hardware platform. The different functional entities which will be required to perform the reconfiguration and realize the transceiver are explained. This paper is organized as follows. In Section 2, the system models are described for various CP-based systems. In Section 3, the linear MMSE receivers are specified for different systems. Section 4 proposes the reconfigurable transceiver and details the configurations for each system. We also analyze the complexity of the equalizer for each system. The hardware architecture for the proposed transceiver is proposed in Section 5. Finally, conclusions are drawn in Section 6. # 2. SYSTEM DESCRIPTION In this section, we review the input-output relations for the CP-based systems, which serve as the basis for the design of reconfigurable signal processing and hardware architecture. The transmission is on a block-by-block basis, with each block consisting of the CP sub-block of *P* symbols and the data sub-block of N symbols. Thanks to the use of CP, the channel matrix is a circular matrix, which can be represented as $\mathbf{H} = \mathbf{W}^{\mathcal{H}} \mathbf{\Lambda} \mathbf{W}$ , where $\mathbf{W}$ is the N-point DFT matrix, and $\mathbf{\Lambda} = \mathrm{diag}\{\lambda_1, \ldots, \lambda_N\}$ is a diagonal matrix, the elements of which are the channel's frequency-domain responses in each subcarrier. For multicarrier systems, the data symbol sub-block is pretransformed using the N-point IDFT matrix $\mathbf{W}^{\mathcal{H}}$ ; while for single-carrier systems, the data symbol sub-block is sent out directly. At the receiver side, both single-carrier and multicarrier systems first pretransform the received data block with the DFT matrix $\mathbf{W}$ , the output of which is then utilized to recover the transmitted signals via either linear or nonlinear receivers. For the multiuser CDMA case, spreading and despreading are added in the transmitter and receiver, respectively. Since the transceiver design for the mobile terminal is of interest, for the CDMA multiuser case, we concentrate on the receiver architecture for the downlink only. For OFDM and SCCP systems, single-user environments are considered. #### 2.1. OFDM For OFDM systems, the input-output relation at the *n*th time block after FFT can be expressed as [3] $$\mathbf{y}(n) = \mathbf{\Lambda}\mathbf{s}(n) + \mathbf{u}(n),\tag{1}$$ where $\mathbf{s}(n)$ is the $N \times 1$ input signal vector, $\mathbf{y}(n)$ is the $N \times 1$ FFT output of the received signal vector, and $\mathbf{u}(n)$ is the FFT output of the AWGN vector, which is of dimension $N \times 1$ . # 2.2. SCCP systems For SCCP systems, the input-output relation at the *n*th block after FFT can be expressed as [20] $$\mathbf{y}(n) = \mathbf{\Lambda} \mathbf{W} \mathbf{s}(n) + \mathbf{u}(n), \tag{2}$$ where $\mathbf{s}(n)$ , $\mathbf{y}(n)$ , and $\mathbf{u}(n)$ are defined as in OFDM systems. Next, we look at four CDMA-based systems: MC-DS-CDMA, MC-CDMA, CP-CDMA, and CP-DS-CDMA. Suppose all users have the same processing gain G. We introduce the following common notations for all systems: T for total number of users; $\mathbf{D}(n)$ for long scrambling codes at the nth block, where $\mathbf{D}(n) = \text{diag}\{d(n;0),\ldots,d(n;N-1)\}$ ; $\mathbf{c}_i$ for short codes of user i, $\mathbf{c}_i = [c_i(0),\ldots,c_i(G-1)]^T$ , with $\mathbf{c}_i^{\mathcal{H}}\mathbf{c}_j = 1$ for i = j, and $\mathbf{c}_i^{\mathcal{H}}\mathbf{c}_j = 0$ for $i \neq j$ . # 2.3. MC-DS-CDMA MC-DS-CDMA performs time-domain spreading [8] as follows. - (1) N symbols from each user-specific spreading codes - (2) The chip signals corresponding to the same symbol index from all users are summed and transmitted over the same subcarrier but through different times blocks. Thus it takes G consecutive blocks to transmit out the whole chip sequences of the N symbols. Mathematically, the *n*th received block after FFT operation can be written as $$\widehat{\mathbf{y}}(n) = \mathbf{\Lambda} \mathbf{D}(n) \sum_{i=0}^{T-1} c_i(n) \mathbf{s}_i + \widehat{\mathbf{u}}(n), \tag{3}$$ where $$\hat{\mathbf{y}}(n) = [y(n;0), \dots, y(n;N-1)]^{T},$$ $$\mathbf{\Lambda} = \operatorname{diag} \{\lambda_{0}, \dots, \lambda_{N-1}\},$$ $$\mathbf{D}(n) = \operatorname{diag} \{d(n;0), \dots, d(n;N-1)\},$$ $$\mathbf{s}_{i} = [s_{i}(0), \dots, s_{i}(T-1)]^{T},$$ $$\hat{\mathbf{u}}(n) = [u(n;0), \dots, u(n;N-1)]^{T}.$$ (4) Note that $\hat{\mathbf{u}}(n)$ is the FFT output of the AWGN vector. On the other hand, gathering the received signals of the kth subcarrier from 0th block to (G-1)th block yields $$\widetilde{\mathbf{y}}(k) = \lambda_k \sum_{i=0}^{M} s_i(k) \widetilde{\mathbf{D}}(k) \mathbf{c}_i + \widetilde{\mathbf{u}}(k), \tag{5}$$ where $$\widetilde{\mathbf{y}}(k) = [y(0;k), \dots, y(G-1;k)]^{T}, \widetilde{\mathbf{D}}(k) = \text{diag} \{d(0;k), \dots, d(G-1;k)\}, \widetilde{\mathbf{u}}(k) = [u(0;k), \dots, u(G-1;k)]^{T}.$$ (6) Despreading $\tilde{\mathbf{y}}(k)$ using $\tilde{\mathbf{D}}(k)\mathbf{c}_i$ , we obtain $$z_{i}(k) = \mathbf{c}_{i}^{\mathcal{H}} \widetilde{\mathbf{D}}^{\mathcal{H}}(k) \widetilde{\mathbf{y}}(k)$$ $$= \lambda_{k} s_{i}(k) + u(k). \tag{7}$$ Thus we have $$\mathbf{z}_i = \mathbf{\Lambda} \mathbf{s}_i + \hat{\mathbf{u}}_i, \tag{8}$$ where $\mathbf{z}_i = [z_i(0), \dots, z_i(N-1)]^{\mathcal{T}}$ , and $\mathbf{u}_i$ is defined accordingly. Therefore, after block despreading, an MC-DS-CDMA is equivalent to an OFDM, and it does not experience any MAI and ISI. ## 2.4. MC-CDMA MC-CDMA performs spreading over frequency domain. Denote T as the total number of users and M = N/G as a positive integer. The nth received block after FFT can be written as $$\mathbf{y}(n) = \mathbf{\Lambda}\mathbf{D}(n)\mathbf{C}\mathbf{s}(n) + \mathbf{u}(n), \tag{9}$$ where $$\mathbf{y}(n) = [y(n;0), \dots, y(n;N-1)]^{\mathcal{T}},$$ $$\mathbf{D}(n) = \operatorname{diag} \{d(n;0), \dots, d(n;N-1)\},$$ $$\mathbf{C} = \operatorname{diag} \{\bar{\mathbf{C}}, \dots, \bar{\mathbf{C}}\},$$ $$\mathbf{s}(n) = [\bar{\mathbf{s}}_{1}^{\mathcal{T}}(n), \dots, \bar{\mathbf{s}}_{M}^{\mathcal{T}}(n)]^{\mathcal{T}},$$ $$(10)$$ and $\mathbf{u}(n)$ is the FFT output of the AWGN vector. Further, $$\bar{\mathbf{C}} = [\mathbf{c}_0, \dots, \mathbf{c}_{T-1}], \bar{\mathbf{s}}_i(n) = [s_0(n; i), \dots, s_{T-1}(n; i)]^T.$$ (11) Dividing y(n) into M nonoverlapping short-column vectors, each with G elements, (9) can then be decoupled as $$\mathbf{y}_i(n) = \mathbf{\Lambda}_i \mathbf{D}_i(n) \bar{\mathbf{C}} \bar{\mathbf{s}}_i(n) + \mathbf{u}_i(n)$$ (12) for i = 1,..., M, where $\Lambda_i$ and $\mathbf{D}_i(n)$ are the *i*th sub-blocks of $\Lambda$ and $\mathbf{D}(n)$ . From (12), MC-CDMA experiences MAI, but not ISI. #### 2.5. CP-CDMA CP-CDMA is a single-carrier dual of MC-CDMA. The M = N/G symbols of each user are first spread out with user-specific spreading codes, then the chip sequence for all users are summed up; the total chip signal of size N is then passed to CP inserter, which adds a CP. Using the duality between CP-CDMA and MC-CDMA, from (12), the nth received block of CP-CDMA after FFT can be written as [5] $$\mathbf{y}(n) = \mathbf{\Lambda} \mathbf{W} \mathbf{D}(n) \mathbf{C} \mathbf{s}(n) + \mathbf{u}(n). \tag{13}$$ From the above, it is seen that CP-CDMA experiences both MAI and ISI. ## 2.6. CP-DS-CDMA CP-DS-CDMA is the single-carrier dual of MC-DS-CDMA. It performs block spreading as follows: the *N* symbols of each user are first spread out with its own spreading codes, then the chip sequence for all users are summed up; the total chip signal corresponding to different chip indices is transmitted over different time block, thus it takes *G* blocks to send out the whole chip sequence of the *N* symbols. The *n*th received block after FFT can be written as [5] $$\mathbf{y}(n) = \mathbf{\Lambda} \mathbf{W} \mathbf{D}(n) \sum_{i=0}^{T-1} c_i(n) \mathbf{s}_i + \mathbf{u}(n),$$ (14) where n = 0, ..., G - 1. Simplification is available if the same set of long scrambling codes are chosen for blocks from 0 to (G-1), or if long scrambling codes are not used $(\mathbf{D}(n) = \mathbf{I})$ . We consider the case when long scrambling codes are not used, and collect the kth subcarrier's received signals from the 0th to (G-1)th blocks, we obtain $$\widetilde{\mathbf{y}}(k) = \lambda_k \sum_{i=0}^{T-1} \mathbf{W}(k,:) \mathbf{s}_i \mathbf{c}_i + \widetilde{\mathbf{u}}(k), \tag{15}$$ where W(k,:) denotes the kth row of matrix W, $$\widetilde{\mathbf{y}}(k) = \left[ y(0;k), \dots, y(G-1;k) \right]^{\mathcal{T}},$$ $$\mathbf{c}_i = \left[ c_i(0), \dots, c_i(G-1) \right]^{\mathcal{T}},$$ $$\widetilde{\mathbf{u}}(k) = \left[ u(0;k), \dots, u(G-1;k) \right]^{\mathcal{T}}.$$ (16) Using $\mathbf{c}_i$ to perform despreading, we obtain $$z_{i}(k) = \mathbf{c}_{i}^{\mathcal{H}} \widetilde{\mathbf{y}}(k)$$ $$= \lambda_{k} \mathbf{W}(k,:) \mathbf{s}_{i} + \widehat{u}(k).$$ (17) Thus we have $$\mathbf{z}_i = \mathbf{\Lambda} \mathbf{W} \mathbf{s}_i + \mathbf{u}_i, \tag{18}$$ which is the single-carrier duality of the MC-DS-CDMA model (8). From (18), it is seen that CP-DS-CDMA does not experience MAI, but it does have ISI. # 3. LINEAR EQUALIZERS We first look at the generic multiple-input multiple-output (MIMO) channel model. Suppose the MIMO channel is described by the following input-output relation: $$\mathbf{x} = \mathbf{H}\mathbf{s} + \mathbf{n},\tag{19}$$ where $\mathbf{s}$ , $\mathbf{x}$ , and $\mathbf{n}$ denote the transmitted signal vector, received signal vector, and received noise vector, respectively; $\mathbf{H}$ is the channel matrix, representing the responses from the transmit antennas to the receive antennas. Without loss of generality, we assume that $\mathbf{s}$ , $\mathbf{x}$ , and $\mathbf{n}$ are all $N \times 1$ vectors, and $\mathbf{H}$ is an $N \times N$ matrix. Assume that $\mathcal{E}[\mathbf{s}\mathbf{s}^{\mathcal{H}}] = \sigma_s^2\mathbf{I}$ , $\mathcal{E}[\mathbf{n}\mathbf{n}^{\mathcal{H}}] = \sigma_n^2\mathbf{I}$ , and $\mathcal{E}[\mathbf{s}\mathbf{n}^{\mathcal{H}}] = \mathbf{0}$ . Denote $\mathbf{P}$ as the linear equalizer for the channel (19), which generates the output $$\mathbf{z} = \mathbf{P}^{\mathcal{H}} \mathbf{x}.\tag{20}$$ Then, the minimum mean square error (MMSE) equalizer is given by $$\mathbf{P} = \sigma_s^2 \left[ \sigma_s^2 \mathbf{H} \mathbf{H}^{\mathcal{H}} + \sigma_n^2 \mathbf{I} \right]^{-1} \mathbf{H}. \tag{21}$$ Now, we are ready to specify the linear receivers for each of the CP-based systems. ## 3.1. MC-DS-CDMA/OFDM An MC-DS-CDMA after block despreading is equivalent to an OFDM. Thus both can employ the same one-tap equalizer to retrieve the transmitted signals: $(\sigma_s^2[\sigma_s^2|\mathbf{\Lambda}|^2 + \sigma_n^2\mathbf{I}]^{-1}\mathbf{\Lambda})^{\mathcal{H}}$ . Note that MC-DS-CDMA performs symbol-level equalization. ## 3.2. MC-CDMA For MC-CDMA, the signal separation is done for each subblock. The channel matrix for the *i*th sub-block of the *n*th block is $$\mathbf{H}_i = \mathbf{\Lambda}_i \mathbf{D}_i(n) \bar{\mathbf{C}}. \tag{22}$$ Thus the MMSE equalizer is given by $$\mathbf{P}_{i} = \sigma_{s}^{2} \left[ \sigma_{s}^{2} \left| \mathbf{\Lambda}_{i} \right|^{2} + \sigma_{n}^{2} \mathbf{I} \right]^{-1} \mathbf{\Lambda}_{i} \mathbf{D}_{i}(n) \bar{\mathbf{C}}$$ (23) for $i=1,\ldots,Q$ , which can realized through a one-tap equalizer, $(\sigma_s^2[\sigma_s^2|\mathbf{\Lambda}|^2+\sigma_n^2\mathbf{I}]^{-1}\mathbf{\Lambda})^{\mathcal{H}}$ , followed by multiple despreaders, $[\mathbf{D}_i(n)\bar{\mathbf{C}}]^{\mathcal{H}}$ , $i=1,\ldots,Q$ . Note that MC-CDMA performs chip-level equalization. ## 3.3. CP-CDMA For CP-CDMA, the channel matrix for the *n*th block is given by $$\mathbf{H} = \mathbf{\Lambda} \mathbf{W} \mathbf{D}(n) \mathbf{C}. \tag{24}$$ Thus the MMSE equalizer is given by $$\mathbf{P} = \sigma_s^2 \left[ \sigma_s^2 |\mathbf{\Lambda}|^2 + \sigma_n^2 \mathbf{I} \right]^{-1} \mathbf{\Lambda} \mathbf{W} \mathbf{D}(n) \mathbf{C}$$ (25) which is realized through a one-tap equalizer, $(\sigma_s^2[\sigma_s^2|\mathbf{\Lambda}|^2 + \sigma_n^2\mathbf{I}]^{-1}\mathbf{\Lambda})^{\mathcal{H}}$ , followed by an IDFT operator $\mathbf{W}^{\mathcal{H}}$ , followed by a despreader $[\mathbf{D}(n)\mathbf{C}]^{\mathcal{H}}$ . Note that CP-CDMA performs chiplevel equalization. # 3.4. CP-DS-CDMA/SCCP A CP-DS-CDMA performs block despreading using *G* consecutive blocks, and after block despreading, it is equivalent to a SCCP system both have the following channel matrix: $$\mathbf{H} = \mathbf{\Lambda} \mathbf{W}.\tag{26}$$ Thus the MMSE equalizer is given by $$\mathbf{P} = \sigma_s^2 \left[ \sigma_s^2 |\mathbf{\Lambda}|^2 + \sigma_n^2 \mathbf{I} \right]^{-1} \mathbf{\Lambda} \mathbf{W}$$ (27) which is realized through a one-tap equalizer, $(\sigma_s^2[\sigma_s^2|\Lambda|^2 + \sigma_n^2\mathbf{I}]^{-1}\Lambda)^{\mathcal{H}}$ , followed by a IDFT operator $\mathbf{W}^{\mathcal{H}}$ . Note that chip-level equalization is performed for CP-DS-CDMA. FIGURE 1: Block diagram of the proposed transceiver configurable for CP-based systems. FIGURE 2: Functional block of the reconfigurable Modem Tx. FIGURE 3: Functional block of the reconfigurable Modem Rx. ## 4. PROPOSED TRANSCEIVER Based on the input-output relations and the detailed equalizers presented in the previous section for each CP-based system, in this section, a universal transceiver is proposed which is configurable to any type of these systems. ## 4.1. Transceiver overview The proposed transceiver is illustrated in Figure 1, which contains source coding, scrambling, channel coding, interleaving, and pilot insertion blocks, as well as Modem Tx and burst formation block at the transmitter side; and receiver front end (FE) and Modem Rx as well as constellation demapper, descrambling, decoding, and deinterleaving at the receiver side. The data symbols are passed to the reconfigurable Modem Tx block where they are modulated according to the required specification. The burst formation and Tx front-end format the processed symbols to proper framing structure with suitable preambles and they are modulated onto a carrier and transmitted. After undergoing the channel and additive noise distortion, the received signal is downconverted in the RX FE processing and fed to the configurable Modem Rx, which does the synchronization (frame, code, and frequency), CP removal, FFT, channel estimation, channel equalization, and phase compensation. The detected symbols are further processed in the subsequent block to generate the information bits. In the reconfigurable transceiver, though each block has to be reconfigured to meet the particular standard's requirement, here we restrict our discussion to the Modem Tx and Modem Rx blocks. # 4.2. System configurations The Modem Tx and Modem Rx are shown in Figures 2 and 3, respectively, and are realized as parameterized functions. We define a flag parameter i(A) for block A; if i(A) = 1, the block will be functioning; and if i(A) = 0, it will be unity. We also use "CS" to denote code spreading block; "BI" for block interleaving block; "IFFT" for IFFT block; "FFT" for FFT block; "BDI" for block despreading and deinterleaving block; "OTE" for one-tap equalizer; and "DS" for despreading block. Denote G and N as the processing gain and the size of each block. Note that G = 1 for non-CDMA systems. The Modem Tx takes in a set of M data symbols, where M = N for OFDM, SCCP, MC-DS-CDMA, and CP-DS-CDMA, and M = N/G for MC-CDMA and CP-CDMA. The flag parameters and selection of M for Modem Tx are shown in Table 1 for different systems. For non-CDMA systems, the CS block is a unity function. The BI block works for MC-DS-CDMA and CP-DS-CDMA, which translates the spread output of size NG into G serial blocks, each with size N. The BI block may also work for MC-CDMA to achieve almost equal diversity for each transmitted symbol [9]. The IFFT processing block in Modem Tx is switched off in the case of single-carrier systems (SCCP, CP-CDMA, and CP-DS-CDMA). A CP insertion block is added to remove IBI and to translate the channel matrix into a circular matrix. Finally, parallel-to-serial conversion is done for signal transmission. At Modem Rx, a common synchronization (SYN) block is applied to each system. For-single-user case, this SYN Table 1: Parameter configurations for Modem Tx. | Schemes | M | i(CS) | i(BI) | i(IFFT) | |------------|-----|-------|-------|---------| | OFDM | N | 0 | 0 | 1 | | SCCP | N | 0 | 0 | 0 | | MC-DS-CDMA | N | 1 | 1 | 1 | | MC-CDMA | N/G | 1 | 0/1 | 1 | | CP-CDMA | N/G | 1 | 0 | 0 | | CP-DS-CDMA | N | 1 | 1 | 1 | Table 2: Parameter configurations for Modem Rx. | Schemes | i(BDI) | i(OTE) | i(IFFT) | i(DS) | |------------|--------|--------|---------|-------| | OFDM | 0 | 1 | 0 | 0 | | SCCP | 0 | 1 | 1 | 0 | | MC-DS-CDMA | 1 | 1 | 0 | 0 | | MC-CDMA | 0 | 1 | 0 | 1 | | CP-CDMA | 0 | 1 | 1 | 1 | | CP-DS-CDMA | 1 | 1 | 1 | 0 | block implements time and frequency synchronization as well as phase noise estimation. Code acquisition is needed for CDMA case. Channel estimation block is also common for each system, which can be implemented using preamble blocks or common pilot channels or dedicated pilot channels, based on the systems to be configured to. The FFT is performed in Modem Rx for all systems. The other parameters are system dependent, which are summarized in Table 2. - (i) For OFDM, only OTE is needed; for MC-DS-CDMA, both BDI and OTE are required. - (ii) For SCCP, OTE and IFFE blocks function; for CP-DS-CDMA, BDI, OTE, and IFFT blocks are required. - (iii) For MC-CDMA, both OTE and DS blocks are needed; for CP-CDMA, OTE, IFFT, and DS blocks are all required. # 4.3. Complexity issues The equalizer complexities of different systems are compared. For non-CDMA systems, such as OFDM and SCCP, the block size *N* is usually small, say 64 in IEEE 802.11a. For CDMA systems, the block size *N* can be much larger, say at least 256. Thus we only compare the receiver complexities of CDMA-based systems. Table 3 illustrates the required operations per block for each CDMA-based system. Note that for both BDI and DS blocks, the number of despreaders of size G is considered. We use the number of complex multiplications (NCM) per block as the complexity metric. As the despreading operation may only involve addition operations since the codes are usually BPSK or QPSK modulated, this complexity is ignored. Treat the required NCM for an N-dimensional OTE as 3N, and the NCM for an N-point FFT (IFFT) as $N\log_2(N)$ . Then the required NCMs per block for each CDMA system are given TABLE 3: Equalizer complexity per block for CDMA-based systems. | Schemes | FFT | BDI | OTE | IFFT | DS | |------------|-----|-----|-------------|-------------|-----| | MC-DS-CDMA | 1 | N/G | 1/ <i>G</i> | 0 | 0 | | MC-CDMA | 1 | 0 | 1 | 0 | N/G | | CP-CDMA | 1 | 0 | 1 | 1 | N/G | | CP-DS-CDMA | 1 | N/G | 1/ <i>G</i> | 1/ <i>G</i> | 0 | | | | | | | | as follows: - (i) MC-DS-CDMA: $N \log_2(N) + 3(N/G)$ ; - (ii) MC-CDMA: $N \log_2(N) + 3N$ ; - (iii) CP-CDMA: $2N \log_2(N) + 3N$ ; - (iv) CP-DS-CDMA: $N \log_2(N) + 3(N/G) + (N/G) \log_2(N)$ . It is seen that MC-CDMA and CP-CDMA have relatively higher complexity than the other two. However, we point out here that the lower complexity of MC-DS-CDMA and CP-DS-CDMA is achieved with the assumption that the wireless channel is static within the *G* consecutive blocks, which may not be the case for fast-fading environments. In those cases, MC-CDMA and CP-CDMA could be a better choice. Fortunately, the complexity increment for these two systems is around 2 times only. As we mentioned earlier, we target the reconfigurable receiver architecture for the downlink only. Now, we quantify the gain of doing so with respect to the multimode receiver which gathers the implementation for each system. Adding the NCM for OFDM, which is $N \log_2(N) + 3N$ , and the NCM for SCCP, which is $2N \log_2(N) + 3N$ , with those for CDMA systems, the required NCM per data block for the simple architecture supporting the six modes is given by $(8N + (N/G)) \log_2(N) + 12N + 6(N/G)$ . With the reconfigurable receiver, the required blocks are FFT, BDI, OTE, IFFT, and DS. Again, ignoring the complexity for BDI and DS, then the total NCM required by the reconfigurable receiver per data block is $2N \log_2(N) + 3N$ . For large processing gain, the required NCM for the reconfigurable receiver is about 25% of that for the multimode receiver. Finally, we list out the typical values of block size N for different standards. In 802.11a/g, N=64, and in the proposals for 802.11n, N=64 or N=128. N=256 for 802.16a/e OFDM mode, and N is as high as 1024 [21] for B3G systems. For CDMA-based systems, when the chip rate is fixed, the processing gain is usually variable depending on the user's data rate [21]. # 5. HARDWARE ARCHITECTURE The proposed transceiver architecture is mapped onto the hardware architecture shown in Figure 4. In this figure, generic high-level functional subsystems and interfaces of the software-defined radio (SDR) transceiver system are shown. The main entities of the architecture are the general-purpose processor (GPP) and SDR modem subsystem. The GPP is an x86-based processor with a PCI-based interface for the SDR modem subsystem. The processing resources available on the SDR modem subsystem are Ti DSP FIGURE 4: Transceiver architecture blocks and interfaces. TMS320C6416 running at a clock speed of 600 MHz, a Xilinx FPGA (XCV2V6000), and the RF front end. Along with the analog RF circuitry, the RF front end also has the ADC (analog devices AD6544), DAC (AD9777), and some reconfigurable logic for digital front-end processing. The logical functions performed in these resources will be dependent on the type of system (OFDM, MC-DS-CDMA, SCCP, CP-DS-CDMA, MC-CDMA, CP-CDMA) that is being realized. A set of logical entities should be realized on the hard-ware platform comprised of GPP and SDR modem subsystem. The specific functions performed in these resources will be dependent on the type of system being realized in the platform. The transient functions in the architecture which are configuration dependent are shown in dotted outlines in Figure 4. The functions that are always present irrespective of the configured system are shown in solid outlines. SDR modem subsystem as shown in Figure 4 covers the RF and digital signal processing functions in the system. This subsystem interfaces to the GPP as a device (specifically as a PCI device). Burst formation, transmitter front-end (FE) processing and receiver FE processing functions are realized in the RF front end. In the receive path, the RF signals down-converts (5 GHz band signals for 802.11a WLAN) to a 70 MHz IF and quadrature is digitized into *I* and *Q* for further processing by baseband run-time reconfigurable (RTR) engine in the receive section. In the transmit section, the RF subsystem upconverts the baseband *I* and *Q* signals to the required frequency (5 GHz band for 802.11a WLAN) for transmission. The RF front end is configured to the required configuration during the initial configuration process. The parameters for configuration are provided by the respective waveform driver. The platform has a run-time reconfigurable (RTR) programmable logic hardware engine. This is used in computation-intensive front-end signal processing of Modem Tx shown in Figure 2 and Modem Rx of Figure 3. This subsystem consists of reconfigurable hardware and a management firmware module that runs on the embedded Ti DSP processor, managing the resources on the hardware. The major functions implemented in the RTR engine are channelization, synchronization and timing recovery, channel estimation and equalization, demodulation, despreading, and de-interleaving. These are typically computation intensive processing suitable for parallel hardware implementation. Corresponding reverse processing is done in the uplink. The rest of the functions such as source/channel coding, scrambling, pilot insertion, and so forth and their corresponding reverse in the receiver path are performed using the processing resources of DSP. Again the exact functions performed by these engines depend on the system applications that are configured. The firmware engine, which is implemented in the DSP, represents the run-time reconfigurable firmware subsystem. This typically implements some of the Layer-1 control procedures like scheduling and Layer-1 management and MAC processing (for example in IEEE 802.11a). These functions also depend on the waveform application being reconfigured to as the processing requirements for different CP-based systems are different. An SDR executive provides the platform services needed to reconfigure and activate waveform applications, such as 802.11a for OFDM system. It is independent of any other application running on the platform. The SDR executive consists of the RTOS, a basic set of resource and configuration management processes and communication and data path management functions. The executive interfaces with the system and configuration manager (SCM) on GPP through the SDR Modem driver and waveform driver executed on the GPP. The SDR executive incorporates a command interpreter to receive and process the commands from the drivers. It also manages the communication channels between the GPP and SDR Modem. To enable instantiation of different waveform applications on the same hardware, the SDR executive supports dynamic loading of COFF modules and reconfiguration of FPGAs. The SDR executive will be stored on a nonvolatile storage and will be loaded at boot time. This module receives firmware and bit map information from the system and configuration manager and configures on the platform subsystems. System and configuration manager (SCM) is the central management function of the architecture. The SCM uses the GPP resources to perform high-level functions like system management, configuration/reconfiguration management of the platform, configuration storage, user interface, and so forth. This module performs its functions in conjunction with other platform functions, specifically the SDR executive, kernel/OS, user interface, and configuration database. The major functions performed by the SCM are - (a) SDR Modem control (reset, platform loading, initialization, etc.); - (b) waveform application database management (add/delete waveform applications); - (c) waveform application management (loading, activation, deactivation, unloading); - (d) diagnostic support (diagnostic commands, error and message logging, etc.). The SCM uses the SDR Modem driver to communicate with the SDR executive to download platform components as needed SDR Modem driver, a kernel driver, interfaces the SDR modem subsystem platform to the system and configuration manager process and acts as the root device driver for the SDR Modem hardware. The driver will be loaded when the SDR Modem device is detected and basically interfaces with the SDR executive to pass command and response between the SCM and SDR executive. This also provides facility to transfer the COFF files and FPGA bit maps to configure the DSP and FPGA, respectively. Kernel/OS block in Figure 4 is the operating-system kernel on the GPP. The operating system used is a general-purpose OS, LINUX, with real-time extensions, or a dedicated real-time OS like LynxOS could also be used. The real-time extensions are necessary as part of the waveform applications, depending on the application, may be implemented inside the kernel. Waveform driver $\langle n \rangle$ , are function-specific drivers in the host OS. These are shown in dotted outline to indicate that they are not always present. A driver will be loaded into the host memory only when corresponding waveform application is being instantiated; and it is unloaded when the application is unloaded. These are technology specific and some of them may be modified versions of standard drivers. For example in the case of OFDM, this will be a modified, dynamically loadable version of the standard wireless LAN 802.11a drivers. As for CDMA application, this may be a specific driver developed for the purpose, incorporating the Layer 2 and higher protocols interfacing with Layer-1 functions inside the SDR Modem. These driver modules are loaded and unloaded by the SCM, whenever the corresponding waveform application is created and destroyed. Upper-layer protocols and application software will make use of the communication capabilities provided by the waveform drivers and interface with them. A configuration database holds all the configuration and status information including all the system images for each of the waveform applications that are supported. At least part of it will be nonvolatile (e.g., disk based). The SCM manages the configuration database, it maintains the current status of the system, and will estimate, along with the SDR executive, the resource availability for the selected application. If sufficient resources are available, the waveform application will be installed and feedback will be given to the user. If resources are not available, it will abort the loading and free up all the resources reserved for this waveform application. The loading process includes, in addition to loading of SDR Modem firmware modules and FPGA bit maps, any host driver modules. A loaded waveform application can be activated only upon explicit activation by the SCM. This involves activation of RF subsystem, hardware and firmware components (loaded and configured during the loading process), as well as loading of the driver on the host side. The SCM implements error logging and diagnostic command support for the development and testing support. This includes ability to log module-wise diagnostic messages into nonvolatile stor- Finally, the user interface exposes the user features provided by the SCM to the user. # 6. CONCLUSIONS In this paper, we have proposed a broadband mobile transceiver and a hardware architecture which can be configured to any cyclic-prefix (CP) -based system. We have identified the reusable common blocks and studied the receiver complexity of the equalization block for different systems. It is found that after the despreading operation, MC-DS-CDMA and CP-DS-CDMA have the same equalization blocks as OFDM and SCCP systems, respectively, showing that both hardware and software sharing is possible for those systems. We also noticed that although MC-CDMA and CP-CDMA require only one block to perform signal detection, the receiver complexity is higher than the other two CDMA systems. However, MC-DS-CDMA and CP-DS-CDMA rely on the assumption that the wireless channel is static within the G blocks. For fast-fading environments, MC-CDMA and CP-CDMA may still be the better choice to compromise the fast fading and complexity issues. Further, functionality of the different functions in the proposed hardware architecture is elaborated. It is seen that though different functions can be realized on a reconfigurable hardware, the major challenge is to have an efficient system configuration and management function which will initiate and control the reconfiguration as per waveform application requirements. ## **REFERENCES** - [1] J. Mitola III, "The software radio architecture," *IEEE Commun. Mag.*, vol. 33, no. 5, pp. 26–38, 1995. - [2] J. Mitola III and G. Q. Maguire Jr., "Cognitive radio: making software radios more personal," *IEEE Pers. Commun.*, vol. 6, no. 4, pp. 13–18, 1999. - [3] L. J. Cimini Jr., "Analysis and simulation of a digital mobile channel using orthogonal frequency division multiplexing," *IEEE Trans. Commun.*, vol. 33, no. 7, pp. 665–675, 1985. - [4] Y.-C. Liang, A. S. Madhukumar, and F. Chin, "Single carrier cyclic prefix based CDMA systems," Tech. Rep., Centre for Wireless Communications (Now Institute for InfoComm Research), Singapore, Singapore, 2001. - [5] Y.-C. Liang, "Block-Iterative GDFE (BI-GDFE) for CP-CDMA," in Proc. 61st IEEE Semiannual Vehicular Technology Conference (VTC '05), Stockholm, Sweden, May–June 2005. - [6] K. L. Baum, T. A. Thomas, F. W. Vook, and V. Nangia, "Cyclic-prefix CDMA: an improved transmission method for broadband DS-CDMA cellular systems," in *Proc. IEEE Wireless Communications and Networking Conference (WCNC '02)*, vol. 1, pp. 183–188, Orlando, Fla, USA, March 2002. - [7] S. Zhou, P. Xia, G. Leus, and G. B Giannakis, "Chipinterleaved block-spread CDMA versus DS-CDMA for cellular downlink: a comparative study," *IEEE Transactions on Wireless Communications*, vol. 3, no. 1, pp. 176–190, 2004. - [8] S. Hara and R. Prasad, "Overview of multicarrier CDMA," *IEEE Commun. Mag.*, vol. 35, no. 12, pp. 126–133, 1997. - [9] X. Cai, S. Zhou, and G. B. Giannakis, "Group-orthogonal multicarrier CDMA," *IEEE Trans. Commun.*, vol. 52, no. 1, pp. 90–99, 2004. - [10] A. Jamalipour, T. Wada, and T. Yamazato, "A tutorial on multiple access technologies for beyond 3G mobile networks," *IEEE Commun. Mag.*, vol. 43, no. 2, pp. 110–117, 2005. - [11] K.-C. Chen and S.-T. Wu, "A programmable architecture for OFDM-CDMA," *IEEE Commun. Mag.*, vol. 37, no. 11, pp. 76–82, 1999. - [12] S.-T. Wu and K.-C. Chen, "Programmable multiuser synchronization for OFDM-CDMA," in *Proc. 53rd IEEE Vehicular Technology Conference (VTC '01)*, vol. 2, pp. 830–834, Rhodes, Greece, May 2001. - [13] J. Helmschmidt, E. Schuler, S. Rao, S. Rossi, S. di Matteo, and R. Bonitz, "Reconfigurable signal processing in wireless terminals [mobile applications]," in *Proc. Design, Automation and Test in Europe Conference and Exhibition (DATE '03)*, pp. 244–249, Munich, Germany, March 2003. - [14] J. R. Moorman, "Implementation of a 3G W-CDMA software radio," in *Proc. IEEE International Conference on Communi*cations (ICC '03), vol. 4, pp. 2494–2499, Anchorage, Alaska, USA, May 2003. - [15] I. P. Seskar and N. B. Mandayam, "A software radio architecture for linear multiuser detection," *IEEE J. Select. Areas Commun.*, vol. 17, no. 5, pp. 814–823, 1999. - [16] J. Palicot and C. Roland, "FFT: a basic function for a reconfigurable receiver," in *Proc. 10th International Conference on Telecommunications (ICT '03)*, vol. 1, pp. 898–902, Papeete, Tahiti, February–March 2003. - [17] P. Burns and M. C. Reed, "A complexity cost function for the signal processing in a WCDMA base station for dimensioning of a software defined radio," in *Proc. 8th IEEE International Symposium on Spread Spectrum Techniques and Appli-* - cations (ISSSTA '04), pp. 854–858, Sydney, Australia, August–September 2004. - [18] A. Gupta, A. Forenza, and R. W. Heath Jr., "Rapid MIMO-OFDM software defined radio system prototyping," in *Proc. IEEE Workshop on Signal Processing Systems (SIPS '04)*, pp. 182–187, Austin, Tex, USA, October 2004. - [19] S. Chuprun, J. Kleider, and C. Bergstrom, "Emerging software defined radio architectures supporting wireless high data rate OFDM," in *Proc. IEEE Radio and Wireless Conference (RAW-CON '99)*, pp. 117–120, Denver, Colo, USA, August 1999. - [20] D. Falconer, S. L. Ariyavisitakul, A. Benyamin-Seeyar, and B. Eidson, "Frequency domain equalization for single-carrier broadband wireless systems," *IEEE Commun. Mag.*, vol. 40, no. 4, pp. 58–66, 2002. - [21] N. Maeda, Y. Kishiyama, H. Atarashi, and M. Sawahashi, "Variable spreading factor-OFCDM with two dimensional spreading that prioritizes time domain spreading for forward link broadband wireless access," in *Proc. 57th IEEE Semiannual Vehicular Technology Conference (VTC '03)*, vol. 1, pp. 127–132, Jeju, Korea, April 2003. Ying-Chang Liang received the Ph.D. degree in electrical engineering from Jilin University, China, in 1993. He is now a Lead Scientist in the Institute for Infocomm Research (I2R), Singapore. He also holds Adjunct Associate Professor positions in Nanyang Technological University and the National University of Singapore, Singapore. From December 2002 to December 2003, he was a Visiting Scholar in the De- partment of Electrical Engineering, Stanford University. From August 1997 to November 2001, he was a Senior Member of technical staff in the Centre for Wireless Communications, Singapore. His research interests include space-time wireless communications, reconfigurable signal processing and cognitive radio, smart antennas, ultra-wideband communications, and capacity-achieving schemes for MIMO fading channels. He received the Best Paper Award from the 50th IEEE Vehicular Technology Conference. He was also the corecipient of the 1997 National Natural Science Award from China. He has been an Associate Editor for IEEE Transactions on Wireless Communications since 2002. He was the Publication Chair for 2001 IEEE Workshop on Statistical Signal Processing and is a Senior Member of IEEE. Sayed Naveen is an Associate Scientist in the Communications & Devices Division, Institute for Infocomm Research (I2R), Singapore. He received his B.E. degree in electronics and communication engineering from the University of Madras, India, in 1992, and the M.Eng. degree in communication systems from the Regional Engineering College, Trichy, India, in 1995. After the M.S. degree, he joined the Central Re- search Laboratory, Bharat Electronics Limited, Bangalore, India, as a member of research staff, where he was working on power amplifier linearization and wireless transceivers for defense communications. In 1999, he joined the WCDMA base station development team, Sanyo LSI Technology India, Bangalore, India, as a Senior Engineer of signal processing. In 2000, he joined I2R (formerly Centre for Wireless Communications). His research interests include reconfigurable signal processing and architectures for broadband wireless communications and software-defined radio. Santosh K. Pilakkat received his B.Tech. degree in electronics from the Regional Engineering College, Calicut, India, in 1987. He is currently a Principal Research Engineer and Project Manager at the Institute for Infocomm Research, A-STAR, Singapore. He has been involved in research and development of wireline and wireless communication systems in various capacities through out his career. His current areas of interest include embedded real-time systems, software-defined radios, and reconfigurable system architectures. Ashok K. Marath is the Manager of the Embedded Systems Department, Institute for Infocomm Research (I2R), Singapore. He graduated from the National Institute of Technology, Calicut, in 1986, and completed his M.S. degree in the National University of Singapore in 1999. Starting his career as an RF design engineer with SAMEER (Society for Applied Microwave Electronics Engineering & Research), Bombay, India, he has more than 15 years of research and development experience in wireless communications in RF design and physical layer processing. He has been active in software radio research for the past 3 years and he is currently involved in a software-radio-based multimode terminal development project. Prior to this, he was involved in projects dealing with RF and system-level issues in various wireless systems such as WATM, RF ID, PHS, and WCDMA. Prior to joining I2R, he was a design engineer with PCI Ltd, Singapore, involved in the design of GSM hand phone. From 1987 to 1993 he was with transmission R&D of Indian Telephone Industries, Bangalore, designing RF and baseband subsystems for digital transmission equipments. He has got extensive experience in system-level issues of various communication systems. He holds 2 patents and has got few pending applications.