### MASSACHUSETTS INSTITUTE OF TECHNOLOGY

### HAYSTACK OBSERVATORY

#### WESTFORD, MASSACHUSETTS 01886

Telephone: Fax: 508-692-4764 617-981-0590

9 July, 1998

TO: K. Young

FROM: A. Whitney, J. Goodman

SUBJECT: SMA Correlator DSP Software

#### References:

1. Mark4 Memo #239.1 "Definition and Management of Correlator Board DSP routine" Whitney, A.R, Goodman, J.I., 20 October 1997

This memo describes briefly the proposed table structure and theory of operation for collection and accumulation of correlator frame data by the DSP chip on the correlator board.

| CNWD | ROUTINE        |
|------|----------------|
| 8    | DSP_demux_data |
| 9    | DSP_zero_array |

## DSP\_demux\_data

The *DSP\_demux\_data* task is used to recombine correlated time division multiplexed data. The Cell Pointer Table (CPT) holds 512 addresses that point to the starting address of lags contained in each of the 512 cells on the board. The Walsh Pointer Table (WPT) will hold 1024 words (for a 32 phase Walsh Cycle) that point to one of four Walsh phase buffers in which data is accumulated. The Data Collapse Table (DCT) holds 16 words that correspond to the starting offset in a Walsh phase buffer where each cells lags are accumulated. Table 1. Illustrates the format of the *DSP\_demux\_data* TCB:

|    |       |        |                           | WALSH CYCI | LE  | WALSH INDEX |   |
|----|-------|--------|---------------------------|------------|-----|-------------|---|
|    | Ι     | MEM_ID |                           | (CPT)      |     |             |   |
|    | Ι     | MEM_ID | WALSH POINTER TABLE (WPT) |            |     |             |   |
|    | Ι     | MEM_ID | DATA COLLAPSE TABLE (DCT) |            |     |             |   |
| 31 | 24 23 | 3      | 16                        | 15         | 8 7 |             | 0 |

 Table 1: TCB for DSP\_demux\_data

where

| Word | Bits | Name        | Explanation                                                                                                                                                                                                                                                                                                                  |  |  |
|------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 4    | 7-0  | WALSH INDEX | Index into Walsh pointer table that denotes the current phase of the Walsh cycle                                                                                                                                                                                                                                             |  |  |
|      | 15-8 | WALSH CYCLE | Length of Walsh cycle                                                                                                                                                                                                                                                                                                        |  |  |
| 5    | 23-0 | СРТ         | Pointer to table of pointers to chip cell lags<br><u>Organization of CPT</u> : Starting from Chip1, Cell<br>1 and running to Chip 32, Cell 16, each entry<br>points to the start of 33 raw lags read from each<br>cell                                                                                                       |  |  |
| 6    | 23-0 | WPT         | Pointer to table of pointers to accumulation<br>phase buffers<br><u>Organization of WPT</u> : Starting from Chip1,<br>Walsh Cycle1 and running to Chip 32, Walsh<br>Cycle <i>N</i> , where <i>N</i> is the number of phases in<br>Walsh cycle period                                                                         |  |  |
| 7    | 23-0 | DCT         | Pointer to table of template values holding<br>offsets from start of Walsh buffer where data<br>from each correlator chip is accumulated<br><u>Organization of DCT</u> : Entries 1-16<br>corresponding to Cells 1-16 that hold value<br>0,1,2 or 3, corresponding to a subset of 32 lags<br>contained in the particular cell |  |  |

Table 2: Explanation for DSP\_demux\_data TCB

# DSP\_zero\_array

The *DSP\_zero\_array* task is used to initialize a phase buffer with zeros at the start of each new Walsh Cycle

|    | ARRAY INC | ARRAY_SIZE |        |                 |    |   |   |   |
|----|-----------|------------|--------|-----------------|----|---|---|---|
|    |           | Ι          | MEM_ID | ZERO ARRAY (ZA) |    |   |   |   |
| 31 | 24        | 23         | 3      | 16              | 15 | 8 | 7 | 0 |

 Table 3: TCB for DSP\_demux\_dat

