The HKU Scholars Hub The University of Hong Kong 香港大學學術庫



| Title       | A recursive all-lag reference-code correlator for generating odd correlations           |
|-------------|-----------------------------------------------------------------------------------------|
| Author(s)   | Ng, TS; Yip, KW; Cheng, CL                                                              |
| Citation    | leee Asia-Pacific Conference On Circuits And Systems -<br>Proceedings, 2000, p. 666-669 |
| Issued Date | 2000                                                                                    |
| URL         | http://hdl.handle.net/10722/46230                                                       |
| Rights      | Creative Commons: Attribution 3.0 Hong Kong License                                     |

# A Recursive All-Lag Reference-Code Correlator for Generating Odd Correlations

Tung-Sang Ng, Kun-Wah Yip and Chin-Long Cheng

Department of Electrical and Electronic Engineering, The University of Hong Kong, Pokfulam Road, Hong Kong, China Fax. ++ 852 + 2559 8738. Tel.: ++ 852 + 2857 8406. Email: {tsng, kwyip, clcheng}@eee.hku.hk

Abstract — An all-lag reference-code correlator generates an all-lag even- or odd-correlation vector at a rate equal to the rate of incoming data samples. Direct implementation of an all-lag reference-code correlator requires N parallel correlators, and the resultant degree of complexity is of the order  $N^2$ , where N is the length of the reference code. In a previous paper, a recursive form for generating all-lag even correlations was derived. In this paper, we derive the recursive form for generating all-lag odd correlations. It is shown that the corresponding correlator can be implemented with a complexity approximately equal to that of a single parallel correlator. That is, the degree of complexity of the proposed recursive all-lag reference-code correlator is of the order N. Thus, substantial reduction in the implementation complexity is achieved.

# I. Advantages of all-lag correlators and the need for efficient implementation

An all-lag reference-code correlator correlates a stream of data samples,  $\{d_n\}$ , with 0, 1,  $\cdots$ , N - 1 lags of a length-N reference code sequence,  $\{c_0, c_1, \cdots, c_{N-1}\}$ , and thereby produces a stream of all-lag even-correlation vectors,  $\{\mathbf{r}_n\}$ , or a stream of all-lag odd-correlation vectors,  $\{\mathbf{\bar{r}}_n\}$ , at a rate equal to the rate of incoming data samples. In this context,  $\mathbf{r}_n = [r_{0,n}, r_{1,n}, \cdots, r_{N-1,n}]^T$  and  $\mathbf{\bar{r}}_n = [\bar{r}_{0,n}, \bar{r}_{1,n}, \cdots, \bar{r}_{N-1,n}]^T$  are given by

 $\mathbf{r}_n = \mathbf{C}\mathbf{d}_n$ 

and

$$\overline{\mathbf{r}}_n = \overline{\mathbf{C}} \mathbf{d}_n, \tag{2}$$

respectively, where

$$\mathbf{C} = \begin{bmatrix} c_0 & c_1 & c_2 & \cdots & c_{N-2} & c_{N-1} \\ c_{N-1} & c_0 & c_1 & \cdots & c_{N-3} & c_{N-2} \\ c_{N-2} & c_{N-1} & c_0 & \cdots & c_{N-4} & c_{N-3} \\ \vdots & \vdots & \vdots & \vdots & \vdots \\ c_2 & c_3 & c_4 & \cdots & c_0 & c_1 \\ c_1 & c_2 & c_3 & \cdots & c_{N-1} & c_0 \end{bmatrix}$$
(3)

and

|                | $c_0$             | $c_1$           | <i>c</i> <sub>2</sub> | •••  | $c_{N-2}$             | <i>c</i> <sub><i>N</i>-1</sub> ] |       |
|----------------|-------------------|-----------------|-----------------------|------|-----------------------|----------------------------------|-------|
|                | $-c_{N-1}$        | $c_0$           | $c_1$                 | •••  | $c_{N-3}$             | c <sub>N-2</sub>                 |       |
| <del>C</del> = | -c <sub>N-2</sub> | $-c_{N-1}$      | <i>c</i> ₀<br>∶       | •••• | c <sub>N-4</sub><br>: | c <sub>N−3</sub><br>∶            | , (4) |
|                | -c <sub>2</sub>   | -c <sub>3</sub> | -c <sub>4</sub>       | •••  | $c_0$                 | $c_1$                            |       |
|                | $-c_1$            | $-c_{2}$        | $-c_3$                | •••  | $-c_{N-1}$            | $c_0$                            |       |

are  $N \times N$  matrices, and

$$\mathbf{d}_{n} = \left[ d_{n-(N-1)}, d_{n-(N-2)}, \cdots, d_{n-1}, d_{n} \right]^{T}$$
(5)

is a data vector containing N most-recent data samples. The subindex m of  $r_{m,n}$  and  $\overline{r}_{m,n}$  refers to a lag of the reference code sequence while the second subindex n is time.

#### A. Advantages

Interest in all-lag reference-code correlators arises because they provide more correlation information than serial correlators, parallel correlators and banks of serial correlators, the latter three types of correlators being commonly used in practical situations [1]-[9]. We shall illustrate the advantages of all-lag correlators by considering the acquisition process of a direct-sequence spread-spectrum (DSSS) signal [10]. Consider first the case of using a parallel correlator that correlates a sequence of DSSS signal samples  $\{d_n\}$  with a reference code  $\{c_n\}$ and generates a sequence of correlation values,  $\{u_n\}$ , at a rate equal to the rate of incoming signal samples, where

$$u_n = c_0 d_{n-(N-1)} + c_1 d_{n-(N-2)} + c_2 d_{n-(N-3)} + \dots + c_{N-2} d_{n-1} + c_{N-1} d_n$$
(6)

is the correlation result obtained at the nth sampling instant. The reference-code length N is normally selected such that it is equal to the length of the spreading sequence multiplied by the number of samples per chip. Before acquisition, the DSSS signal is not code-aligned with the receiver's copy of the reference code sequence. Since the reference-code length is N, we can code-align, or acquire, the incoming DSSS signal at the receiver by computing N

(1)

0-7803-6253-5/00/\$10.00 ©2000 IEEE.

666

This work was supported by the Hong Kong Research Grants Council and by the University Research Committee of The University of Hong Kong, Hong Kong. The authors are with The University of Hong Kong. Fax: ++ 852 + 2559 8738. Tel.: ++ 852 + 2857 8406. (Email: {tsng, kwyip, clcheng}@eee.hku.hk)

correlation values corresponding to the correlation of the signal with 0, 1,  $\cdots$ , N - 1 lags (or delays) of the reference code. The receiver is therefore required to compute

$$u_{n} = c_{0}d_{n-(N-1)} + c_{1}d_{n-(N-2)} + \dots + c_{N-1}d_{n}$$

$$u_{n+1} = c_{0}d_{n-(N-2)} + c_{1}d_{n-(N-3)} + \dots + c_{N-1}d_{n+1}$$

$$\vdots$$

$$u_{n+N-2} = c_{0}d_{n-1} + c_{1}d_{n} + \dots + c_{N-1}d_{n+N-2}$$

$$u_{n+N-1} = c_{0}d_{n} + c_{1}d_{n+1} + \dots + c_{N-1}d_{n+N-1}$$
(7)

and the acquisition circuit determines which one of these values has the largest magnitude. Acquisition is declared on the time position where the largest magnitude occurs.

In the absence of data modulation embedded in the DSSS signal, the signal is a periodic repetition of the reference code sequence. The intended information contained in signal samples  $d_{n+1}, d_{n+2}, \dots, d_{n+N-1}$  is also contained in  $d_{n-(N-1)}, d_{n-(N-2)}, \dots, d_{n-1}$ , respectively, so that (7) can be expressed as

$$u_{n} = c_{0}d_{n-(N-1)} + c_{1}d_{n-(N-2)} + \dots + c_{N-1}d_{n}$$

$$u_{n+1} = c_{0}d_{n-(N-2)} + c_{1}d_{n-(N-3)} + \dots + c_{N-1}d_{n-(N-1)}$$

$$\vdots$$

$$u_{n+N-2} = c_{0}d_{n-1} + c_{1}d_{n} + \dots + c_{N-1}d_{n-2}$$

$$u_{n+N-1} = c_{0}d_{n} + c_{1}d_{n-(N-1)} + \dots + c_{N-1}d_{n-1}$$
(8)

Thus, computation of  $u_n$ ,  $u_{n+1}$ ,  $\cdots$ ,  $u_{n+N-1}$  is equivalent to computing  $\mathbf{r}_n$  given by (1). Rapid acquisition of the incoming DSSS signal is achieved by locating the time position having the largest magnitude among  $r_{m,n}$ , m = 0, 1,  $\cdots$ , N - 1. It is apparent that acquisition of a DSSS signal by using  $\mathbf{r}_n$  can be achieved in a duration of N consecutive sampling periods while acquisition using a parallel correlator involves a larger data block of 2N - 1 samples.

In the presence of antipodal data modulation, that is, when the symbols are either +1 or -1, successive symbols may or may not have a transition in polarity. When successive data symbols contained in DSSS signal samples  $d_{n-(N-1)}$ ,  $d_{n-(N-2)}$ ,  $\cdots$ ,  $d_{n+N-1}$  have the same sign, it is easy to show that computation of  $u_n$ ,  $u_{n+1}$ ,  $\cdots$ ,  $u_{n+N-1}$  is equivalent to the computation of  $\mathbf{r}_n$ . Acquisition is declared at the time position having the largest magnitude among  $r_{m,n}$ ,  $m = 0, 1, \dots, N - 1$ . When successive data symbols are opposite in sign, using only the information contained in  $\mathbf{r}_n$  is not sufficient for acquisition unless data transition occurs at the zeroth-lag position, a condition that does not occur frequently. To achieve rapid acquisition, we make use of the information provided by both  $\mathbf{r}_n$  and  $\overline{\mathbf{r}}_n$ . In case successive data symbols are opposite in sign, the correlation peak among  $\overline{r}_{m,n}$ ,  $m = 0, 1, \dots, N-1$ , is located where data transition occurs because of an intentional reversal of sign during correlation of the signal as seen from (2). Therefore, a data-modulated DSSS signal can be acquired by locating the time position having the largest magnitude among the elements of  $\mathbf{r}_n$  and  $\mathbf{\bar{r}}_n$ . Note that acquisition can be accomplished when  $\mathbf{r}_n$  and  $\mathbf{\bar{r}}_n$  are available, that is, after N signal samples are obtained. On the other hand, acquisition using a parallel correlator requires a time of 2N - 1 sampling periods.

#### B. Implementation problems

Direct implementation of an all-lag reference-code correlator is by means of N parallel correlators, where the mth parallel correlator,  $m = 0, 1, \dots, N - 1$ , correlates a block of data samples given by  $\mathbf{d}_n$  with the sequence taken from the *m*th row of **C** or  $\overline{\mathbf{C}}$  according to whether even- or odd-correlation values are to be generated, and produces a sequence of correlation results  $\{r_{m,n}\}$  or  $\{\overline{r}_{m,n}\}$  at a rate of one result per sampling instant. A practical method to implement a parallel correlator is based on the systolic array architecture [1], [2]. Table 1 lists the required numbers of multipliers, adders, etc., for implementing a parallel correlator, wherein the results are taken from [11]. It is apparent that a parallel correlator comprises Nmultipliers, N - 1 adders and N - 1 storage elements, so that the degree of implementation complexity is of the order N. Since an all-lag reference-code correlator implemented using the direct approach comprises N parallel correlators, the degree of implementation complexity is of the order  $N^2$ . The resultant implementation complexity is especially significant when the reference-code length N is large.

Recently, the authors [11] have derived a recursive form for generating all-lag even-correlation vectors. It has been shown that the resultant correlator can be efficiently realized with a complexity approximately equal to that of a single parallel correlator. That is, the resultant implementation complexity is of the order N. For reference, we indicate that the correlator requires Nmultipliers, N + 1 adders, 2N storage elements and 1 negator (Table 1). This result enables system designers to utilize all-lag correlation information while keeping the implementation cost low. In this paper, we complement the work of [11] and derive the recursive form for an all-lag reference-code correlator that generates odd correlations. Implementation aspects are also discussed.

# II. Recursive all-lag reference-code correlator for generating $\{\overline{\mathbf{r}}_n\}$

We proceed to derive the recursive formula for computing  $\overline{\mathbf{r}}_n$  based on the same steps as in deriving the one for  $\mathbf{r}_n$  in [11]. Define an  $N \times N$  shift matrix

$$\overline{\mathbf{S}} = \begin{bmatrix} 0 & 1 & 0 & 0 & \cdots & 0 & 0 \\ 0 & 0 & 1 & 0 & \cdots & 0 & 0 \\ 0 & 0 & 0 & 1 & \cdots & 0 & 0 \\ \vdots & \vdots & \vdots & \vdots & \vdots & \vdots & \vdots \\ 0 & 0 & 0 & 0 & \cdots & 0 & 1 \\ -1 & 0 & 0 & 0 & \cdots & 0 & 0 \end{bmatrix},$$
(9)

which performs a linear transform on a length-N column vector by cyclically shifting up the elements by one step and reversing the sign of the resultant lowest element. This transform is realized in practice by an inverting end-around shift register. It is easy to show that

$$\overline{\mathbf{S}}^{N} = -\mathbf{I}.$$
 (10)

Let  $\overline{\mathbf{c}}_m$  denote the *m*th column<sup>1</sup> of  $\overline{\mathbf{C}}$  for  $m = 0, 1, \dots, N$ - 1, namely,

$$\overline{\mathbf{c}}_{m} = \begin{bmatrix} c_{m}, c_{m-1}, \cdots, c_{1}, c_{0}, -c_{N-1}, -c_{N-2}, \\ \cdots, -c_{m+2}, -c_{m+1} \end{bmatrix}^{T}$$
(11)

It can be easily shown that

$$\overline{\mathbf{c}}_{N-1} = -\overline{\mathbf{S}}\overline{\mathbf{c}}_0$$
  
$$\overline{\mathbf{c}}_{m-1} = \overline{\mathbf{S}}\overline{\mathbf{c}}_m, \qquad m = 1, 2, \cdots, N-1.$$
(12)

 $\mathbf{c}_{m-1} = \mathbf{S}\mathbf{c}_m, \qquad m = 1, 2, \cdots, N-1.$ Since  $\overline{\mathbf{C}} = [\overline{\mathbf{c}}_0 \ \overline{\mathbf{c}}_1 \cdots \overline{\mathbf{c}}_{N-1}]$ , we can express (2) as

$$\bar{\mathbf{r}}_{n} = \sum_{m=0}^{N-1} d_{n+m-(N-1)} \bar{\mathbf{c}}_{m}, \qquad (13)$$

so that

$$\overline{\mathbf{r}}_{n} = d_{n} \overline{\mathbf{c}}_{N-1} + \sum_{m'=1}^{N-1} d_{n-1+m'-(N-1)} \overline{\mathbf{c}}_{m'-1}.$$
 (14)

Applying (12) to the last expression yields

$$\overline{\mathbf{r}}_{n} = d_{n}\overline{\mathbf{c}}_{N-1} + \overline{\mathbf{S}}\sum_{m'=1}^{N-1} d_{n-1+m'-(N-1)}\overline{\mathbf{c}}_{m'} + d_{n-N}(\overline{\mathbf{S}}\overline{\mathbf{c}}_{0} + \overline{\mathbf{c}}_{N-1}).$$
(15)

It follows that the recursive relationship is given by

$$\overline{\mathbf{r}}_n = \mathbf{S}\overline{\mathbf{r}}_{n-1} + (d_n + d_{n-N})\overline{\mathbf{c}}_{N-1},\tag{16}$$

which enables generation of  $\overline{\mathbf{r}}_n$  based on  $\overline{\mathbf{r}}_{n-1}$ . Notice that  $\overline{\mathbf{S}}\overline{\mathbf{r}}_{n-1}$  is an inverting end-around rotation of  $\overline{\mathbf{r}}_{n-1}$ . The initial condition is derived as follows. Repeated application of (16) for N times followed by an application of (10) and (12) yields

$$\overline{\mathbf{r}}_{n} = -\overline{\mathbf{r}}_{n-N} + \overline{\mathbf{C}}(\mathbf{d}_{n} + \mathbf{d}_{n-N}).$$
(17)

Again, assume that signal samples,  $d_n$ 's, are only available for  $n = 1, 2, 3, \cdots$  and that we want to generate  $\overline{\mathbf{r}}_N$ ,  $\overline{\mathbf{r}}_{N+1}$ ,  $\overline{\mathbf{r}}_{N+2}$ ,  $\cdots$ . It is easy identify the desired initial condition to be  $\overline{\mathbf{r}}_0 = \mathbf{0}$  and  $d_0 = d_{-1} = \cdots = d_{-(N-1)} = 0$ , so that (17) and (2) becomes identical for n = N. The recursive formula (16) can be used thereafter to generate  $\overline{\mathbf{r}}_n$ , n > N.

Fig. 1 shows a recursive all-lag reference-code correlator that generates  $\{\overline{\mathbf{r}}_n\}$  and that is constructed according to (16). It is apparent that implementation of this correlator requires a length-N shift register for storing the input signal sequence, an output storage for storing the N correlation results, a negator, N multipliers and N + 1 two-input adders. Values in the shift register and the output storage are reset to zero prior to operation. Table 1 lists the required numbers of components for realizing this correlator, alongside with those results for other correlators. Results of Table 1 indicate that the implementation complexity of all three correlators is approximately the same and is of the order N.

### **III.** Conclusions

A recursive form for generating all-lag odd-correlation sequences  $\{\overline{\mathbf{r}}_n\}$  has been derived. It has been shown that using this recursive form, all-lag reference-code correlators can be implemented with a complexity approximately the same as that of a conventional parallel correlator. The degree of implementation complexity for the recursive alllag reference-code correlator has therefore been reduced substantially from order  $N^2$  to order N.

## References

- [1] H. T. Kung, "Why systolic architectures?" Computer, vol. 15, pp. 37-46, Jan. 1982.
- [2] D. T. Magill and G. Edwards, "Digital matched filter ASIC," Proc. IEEE MILCOM'90, pp. 235-238, Sep. 30 - Oct. 3, 1990.
- [3] R. S. Mowbray and P. M. Grant, "Simplified matched filter receiver designs for spread spectrum communications applications," *IEE Electronics and Communication Engineering Journal*, pp. 59-64, Apr. 1993.
- [4] R. C. Dixon and J. S. Vanderpool, "Spread spectrum correlator," U. S. Pat. No. 5,022,047, Jun. 4, 1991.
- [5] R. C. Dixon and J. S. Vanderpool, "Dual-threshold spread spectrum correlator," U. S. Pat. No. 5,719,900, Feb. 17, 1998.
- [6] R. Price and P. E. Green, Jr., "A communication technique for multipath channels," *Proc. IRE*, vol. 46, pp. 555-570, Mar. 1958.
- [7] M. Luise and R. Reggiannini, "Carrier recovery in alldigital modems for burst-mode transmission," *IEEE Trans. Commun.*, vol. 43, 'pp. 1169-1178,

<sup>&</sup>lt;sup>1</sup> Throughout this paper, the left uppermost element of a matrix is assigned an index (0,0) rather than the usual index (1,1).

Feb./Mar./Apr. 1995.

- [8] U. Fawer, "A coherent spread-spectrum diversity receiver with AFC for multipath fading channels," *IEEE Trans. Commun.*, vol. 42, pp. 1300-1311, Feb./Mar./Apr. 1994.
- [9] A. Q. Hu, P. C. K. Kwok and T. S. Ng, "MPSK DS/CDMA carrier recovery and tracking based on correlation technique," *IEE Electron. Lett.*, vol. 35, pp. 201-203,
- [10] J. Li and S. Tantaratana, "Optimal and suboptimal coherent acquisition schemes for PN sequences with data modulation," *IEEE Trans. Commun.*, vol. 43, pp. 554-564, Feb./Mar./Apr. 1995.
- [11] T.-S. Ng, K.-W. Yip and C.-L. Cheng, "Recursive All-Lag Reference-Code Correlator and its Efficient Implementation," *Proc. IEEE ISCAS 2000*, pp. IV473-IV476, May 28-31, 2000, Geneva, Switzerland.

Table 1. Implementation complexity of various correlators. Results for the parallel correlator and the correlator that generates  $\{\mathbf{r}_n\}$  are taken from [11].

|                                                                                          | Required number of: |        |               |         |  |
|------------------------------------------------------------------------------------------|---------------------|--------|---------------|---------|--|
|                                                                                          | multipliers         | adders | storage units | negator |  |
| Parallel correlator                                                                      | N                   | N-1    | N-1           | ·       |  |
| Recursive all-lag reference-code correlator that generates $\{\mathbf{r}_n\}$            | N                   | N+1    | 2 <i>N</i>    | 1       |  |
| Recursive all-lag reference-code correlator that generates $\{\overline{\mathbf{r}}_n\}$ | N                   | N+1    | 2 <i>N</i>    | . 1     |  |

Fig. 1. A recursive all-lag reference-code correlator that generates a sequence of all-lag odd-correlation vectors  $\{\overline{\mathbf{r}}_n\}$ .

