# Connection to and control of the PC-EVN recorder

R. Dodson Institute of Space and Astronautical Science, JAXA, 3-1-1 Yoshinodai, Sagamihara, Kanagawa 229-8510, Japan

September 9, 2004

### 1 Introduction

This document covers use of the VSIB connections and the control software. It describes the connectors and software which will allow recording of data and statistics, bandpass checking, and fringe checking for that data with 16 MHz or 64 MHz bands.

## 2 VSIB boards and module

Two Metsähovi boards are required for VLBI recording. VSIB, a VSI-H (VLBI Standard Interface, Hardware) compliant DMA card which allows data to be written to or read from the hard drives on the PC. The VSIC is a converter card for many legacy VLBI formats. The VSIC comes with a 50 to 40 way connector which drops many of the duplicate ground lines from the S2 format.

The VSIB module for linux is written by Ari Mujunen and is a character driver for Metsähovi VSIB I/O PCI board. It uses the **bigphysarea** patch to the linux kernel to ensure that there will be sufficient contiguous memory allocated for the card.

The **bigphysarea** is set, in units of 4k pages, at boot time. The usual way is to add this line to the lilo.conf (or whatever the boot controller uses).

append="bigphysarea=36000"

This can be checked via the /proc/bigphysarea file. Then the module needs to be loaded. It is important to give the bigbufsize parameter as the default size is small (5MB) and quickly over-runs when used (which can be detected as regular zeros in the data file).

insmod vsib.o bigbufsize=144000000

#### 2.1 Current issues

Discussion is ongoing as to whether the **bigphysarea** patch can be bypassed, and whether it is worth doing.

## 3 Connectors

The primary data sampler for Australian telescopes will be the ATNF-DAS for the foreseeable future. The DAS has two inputs, IF1 and IF2, which are 64 MHz wide and centred on a  $2 \times N+1$  multiple of 32 MHz. Each of these are filtered and output by a Band Splitter unit (BS) and a Fine Tuner unit (FT). These provide bands of 16-, 8-, or 4-MHz on a 50-way ECL connector designed for the S2. The DAS can also provides the same outputs to the autocorrelators, both AT and MB. The most common modes of operation are;

VSOP Two contiguous 16MHz bands either side of the band centre

MP16S 16 MHz at the band centre from each input

MPXS X MHz at the band centre from each input

If we wish to run in parallel with the S2, i.e. in a fringe checker mode, we can sample the data from the output of the S2 formatter feed-through port: C2a. The output is not the same as the input, but a trivial reordering of the pins achieves this. Figure 1a shows the pin connections, and Figure 1b shows the board, known as the BG2 connector. The format selection is via the usual VLBI setup.



Figure 1: BG2 connector: Layout and picture



Figure 2: BG3 connector: Layout and picture

If we wish to replace the S2 with the PC-EVN we can connect the DAS directly to the VSIC using the S2 cable (C1). This will provide eight bit streams to the PC-EVN, two each from each of the BS and FT units. The format selection is via the usual VLBI setup.

If we wish to record the full input to the DAS we can connect the DAS to the VSIC using the BG3 connector. This can be run in parallel to the S2 and replaces the ATNF multibeam correlator. Figure 2a shows the pin and port connections, and Figure 2b shows the board. The 1PPS comes from either S2-C2a or the DAS-S2 ports. The data and clocks are read from the two DAS correlator ports, which can be programmed to write in the old AT or sign magnitude MB formats. The latter is required (parameter 75 set to 1). See Figure 3 for the DAS setting. Digital filtering can be applied to this data, but to achieve the maximum bandpass the unfiltered, raw digitised output (64-MHz bandwidth and 2 bit sampled) should be selected. Options are;

| CONN bandpass                     | miter (parameter 70) | comments              |
|-----------------------------------|----------------------|-----------------------|
| 64-MHz 2 bits                     | 5                    |                       |
| 32-MHz 2 bit                      | 4                    | Also available via S2 |
| $2\!\times\!16\mathrm{MHz}$ 2 bit | 3                    | A very flexible mode  |
|                                   |                      |                       |

Both of these modes require the VSIC to be set to mode 1110 (reading left to right). Other VSIC modes of interest are the VSI-H test mode (0111) and the countdown test mode (0110).

#### 3.1 Current issues

The DAS limits us to 512 MBps. Whilst 1024 Mbps is not possible with the VSIB (as it would overload the PCI and IDE bus) it is possible to run at greater than 512 Mbps. Do we wish to take this very non-standard route? The MAXIM AD cards will provide up to 50 MHz of band pass at 10 bits. With 'smart' IO cards to select the

| Profile: LBA_DAS                                                                                                                                                                                                                                                                                                                                                  | GPROSZ-REC. PORT                                                                                                                                                                                                                                                                                       | IF PRUC, 1 (V3.1)                                                                                                                                                                                                                              |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| <70> BAND WIDTH SE                                                                                                                                                                                                                                                                                                                                                | LECT : O                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                |  |  |
| ( 0: BW<=16<br>( 1: BW= 32<br>( 2: BW= 64<br>( 3: TEST C                                                                                                                                                                                                                                                                                                          | MHz 2x2Bit DATA, selectable vi<br>MHz 2x2Bit DATA BSB<br>MHz 4x1Bit SIGN BSB, unprocess<br>NNLY 4x1Bit MAGN BSB, unprocess                                                                                                                                                                             | a <71> & <72> )<br>)<br>ed data )<br>ed data )                                                                                                                                                                                                 |  |  |
| <71> S2_INO & S2_I<br><72> S2_IN2 & S2_I<br>( 0:X-BS, 1:Y-BS,                                                                                                                                                                                                                                                                                                     | N1 SOURCE : 1 <73> S2_IN0<br>N3 SOURCE : 0 <74> S2_IN2<br>2:X-FT, 3:Y-FT ) ( 0                                                                                                                                                                                                                         | & S2_IN1 FORMAT : 1<br>& S2_IN3 FORMAT : 1<br>:AT, 1:VLBA )                                                                                                                                                                                    |  |  |
| COR                                                                                                                                                                                                                                                                                                                                                               | RELATOR PORT IF                                                                                                                                                                                                                                                                                        | PROCESSOR 1                                                                                                                                                                                                                                    |  |  |
| <75> CORRELATOR FC<br>( 0:AT-CORR, 1:MB-                                                                                                                                                                                                                                                                                                                          | RMAT : 1<br>CORR )                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                |  |  |
| <pre>&lt;76&gt; MB/AT-CORR DATA SOURCE : 5 &lt;79&gt; MB-CORR DATA 2.SOURCE : 0 ( 0:X-BS, 1:Y-BS, 2:X-FT, 3:Y-FT ) ( 0:X-BS, 1:Y-BS, 2:X-FT, 3:Y-FT ) ( 4:32MHz-BS, 5:64MHz-BS )</pre>                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                |  |  |
| ( 4:32MHź-BS, 5:64                                                                                                                                                                                                                                                                                                                                                | MHz-BS )                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                |  |  |
| ( 4:32MHź–BS, 5:64<br><77> AT–CORR DATA                                                                                                                                                                                                                                                                                                                           | MHz-BS )<br>Adjust : 0 ( 0,1,2,                                                                                                                                                                                                                                                                        | 3 CLK-Cycles Delay )                                                                                                                                                                                                                           |  |  |
| ( 4:32MHź-BS, 5:64<br><77> AT-CORR DATA<br><s> = S</s>                                                                                                                                                                                                                                                                                                            | MHZ-BS)<br>ADJUST : 0 ( 0, 1, 2,<br>ETUP, <enter> = NEXT SCEEN, <ai< th=""><th>3 CLK-Cycles Delay )<br/>DDR&gt; = CHANGE VALUE : []</th></ai<></enter>                                                                                                                                                 | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []                                                                                                                                                                                               |  |  |
| ( 4:32MHŹ-BS, 5:64<br><77> AT-CORR DATA<br><s> = S</s>                                                                                                                                                                                                                                                                                                            | IMHZ-BS ) ADJUST : 0 ( 0, 1, 2, SETUP, <enter> = NEXT SCEEN, <ai &="" correlator="" ie="" one<="" processor="" s2_recorder="" th=""><th>3 CLK-Cycles Delay )<br/>DDR&gt; = CHANGE VALUE : []<br/>popup</th></ai></enter>                                                                               | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []<br>popup                                                                                                                                                                                      |  |  |
| ( 4:32MHŹ-BS, 5:64<br><77> AT-CORR DATA<br><s> = S<br/>S2 RECORDER PORT:<br/>Bandwidth:</s>                                                                                                                                                                                                                                                                       | MHZ-BS)<br>ADJUST: 0 (0,1,2,<br>ETUP, (ENTER) = NEXT SCEEN, (A)<br>S2_Recorder & Correlator<br>IF Processor One<br>BW=64MHz 4x18it Sign BS, unprocessed data                                                                                                                                           | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []<br>IF Processor Two<br>BW=64MHz 4x1Bit Sign BS, unprocessed data                                                                                                                              |  |  |
| ( 4:32MHŹ-BS, 5:64<br><77> AT-CORR DATA<br><8> = 8<br>S2 RECORDER PORT:<br>Bandwidth:<br>S2_INO & S2_INI Source:                                                                                                                                                                                                                                                  | MHZ-BS)<br>ADJUST: 0 ( 0, 1, 2,<br>ETUP, <enter> = NEXT SEEEN, <ai<br>S2_Recorder &amp; Correlator<br/>IF Processor One<br/>BW=64MHz 4x1Bit Sign BS, unprocessed data<br/>Y+BS F</ai<br></enter>                                                                                                       | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []<br>IF Processor Two<br>BW=64MHz 4x1Bit Sign BS, unprocessed data                                                                                                                              |  |  |
| ( 4:32MHZ-BS, 5:64<br><77> AT-CORR DATA<br><s> = S<br/>S2 RECORDER PORT:<br/>Bandwidth:<br/>S2_INO &amp; S2_IN1 Source:<br/>S2_IN2 &amp; S2_IN3 Source</s>                                                                                                                                                                                                        | IMHZ-BS)<br>ADJUST : 0 ( 0, 1, 2,<br>SETUP, (ENTER) = NEXT SCEEN, (AI<br>S2_Recorder & Correlator<br>IF Processor One<br>BW=64MHz 4x1Bit Sign BS, unprocessed data<br>Y-BS =<br>X-BS =                                                                                                                 | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []<br>popup<br>IF Processor Two<br>BW=64MHz 4x1Bit Sign BS, unprocessed data<br>Y-BS =<br>x-BS =                                                                                                 |  |  |
| ( 4:32MHZ-BS, 5:64<br><77> AT-CORR DATA<br><8> = 5<br>S2 RECORDER PORT:<br>Bandwidth:<br>S2_IN0 & S2_IN1 Source:<br>S2_IN2 & S2_IN3 Source<br>S2_IN2 & S2_IN3 Format:                                                                                                                                                                                             | MHZ-BS)<br>ADJUST : 0 ( 0, 1, 2,<br>ETUP, <enter> = NEXT SEEEN, <ai<br>S2_Recorder_&amp;_Correlator<br/>IF Processor One<br/>BW=64MHz 4x1Bit Sign BS, unprocessed data<br/>Y-BS F<br/>X-BS F<br/>YLBA F</ai<br></enter>                                                                                | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []<br>popup<br>IF Processor Two<br>BW=64MHz 4x1Bit Sign BS, unprocessed data<br>Y-BS =<br>X-BS =<br>VLBA =                                                                                       |  |  |
| ( 4:32MHŹ-BS, 5:64<br><77> AT-CORR DATA<br><s> = 5<br/>S2 RECORDER PORT:<br/>Bandwidth:<br/>S2_INO &amp; S2_IN1 Source:<br/>S2_INO &amp; S2_IN1 Source<br/>S2_INO &amp; S2_IN1 Format:<br/>S2_IN2 &amp; S2_IN3 Format:</s>                                                                                                                                        | MHZ-BS )<br>ADJUST : 0 ( 0, 1, 2,<br>ETUP, <enter) <a<br="" =="" next="" sceen,="">S2_Recorder &amp; Correlator<br/>IF Processor One<br/>BW-64MHz 4x1Bit Sign BS, unprocessed data<br/>YHBS =<br/>YHBA =<br/>YLBA =</enter)>                                                                           | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []<br>popup<br>IF Processor Two<br>BW=64MHz 4x1Bit Sign BS, unprocessed data<br>Y-BS =<br>X-BS =<br>VLBA =<br>VLBA =                                                                             |  |  |
| ( 4:32MHZ-BS, 5:64<br>(77) AT-CORR DATA<br>(S) = S<br>S2 RECORDER PORT:<br>Bandwidth:<br>S2_IN0 & S2_IN1 Source:<br>S2_IN2 & S2_IN3 Source<br>S2_IN2 & S2_IN3 Format:<br>S2_IN2 & S2_IN3 Format:<br>CORRELATOR PORT:                                                                                                                                              | MHZ-BS )<br>ADJUST : 0 ( 0, 1, 2,<br>ETUP, <enter> = NEXT SCEEN, <al<br>S2 Recorder &amp; Correlator<br/>IF Processor One<br/>BW=64MHz 4x1Bit Sign BS, unprocessed data<br/>Y-BS F<br/>X-BS F<br/>VLBA F</al<br></enter>                                                                               | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []<br>popup<br>IF Processor Two<br>BW=64MHz 4x1Bit Sign BS, unprocessed data<br>Y-BS =<br>X-BS =<br>VLBA =                                                                                       |  |  |
| ( 4:32MHZ-BS, 5:64<br><77> AT-CORR DATA<br><s> = S<br/>S2 RECORDER PORT:<br/>Bandwidth:<br/>S2_IN0 &amp; S2_IN1 Source:<br/>S2_IN2 &amp; S2_IN3 Source<br/>S2_IN2 &amp; S2_IN3 Format:<br/>CORRELATOR PORT:<br/>Correlator Format:</s>                                                                                                                            | MHZ-BS       )         ADJUST       : 0       (0,1,2,         ETUP, <enter> = NEXT SCEEN, <a< td="">       S2 Recorder &amp; Correlator         IF Processor One         BW-64MHz 4x1Bit Sign BS, unprocessed data         Y:BS F       XBS F         VLBA F       Multibeam Correlator F</a<></enter> | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []<br>popup<br>IF Processor Two<br>BW=64MHz 4x1Bit Sign B5, unprocessed data<br>Y-BS =<br>VLBA =<br>VLBA =<br>Multibeam Correlator =                                                             |  |  |
| ( 4:32MHZ-BS, 5:64<br>(77> AT-CORR DATA<br>(8> = 8<br>S2 RECORDER PORT:<br>Bandwidth:<br>S2_IN0 & S2_IN1 Source:<br>S2_IN2 & S2_IN3 Source<br>S2_IN2 & S2_IN3 Format:<br>S2_IN2 & S2_IN3 Format:<br>CORRELATOR PORT:<br>Correlator Format:<br>MultiBeam/AT Corr Data Source:                                                                                      | MHZ-BS )<br>ADJUST : 0 ( 0, 1, 2,<br>SETUP, <enter> = NEXT SCEEN, <al<br>S2_Recorder &amp; Correlator<br/>IF Processor One<br/>BW=64MHz 4x1Bit Sign BS, unprocessed data<br/>Y-BS F<br/>X-BS F<br/>YLBA F<br/>VLBA F<br/>Multibeam Correlator F<br/>64MHz-BS F</al<br></enter>                         | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []<br>popup<br>IF Processor Two<br>BW=64MHz 4x1Bit Sign BS, unprocessed data<br>Y-BS =<br>X-BS =<br>VLBA =<br>VLBA =<br>Multibeam Correlator =<br>64MHz-BS =                                     |  |  |
| ( 4:32MHZ-BS, 5:64<br>(77) AT-CORR DATA<br>(S) = S<br>S2 RECORDER PORT:<br>Bandwidth:<br>S2_IN0 & S2_IN1 Source:<br>S2_IN2 & S2_IN3 Source<br>S2_IN2 & S2_IN3 Format:<br>S2_IN2 & S2_IN3 Format:<br>CORRELATOR PORT:<br>CORRELATOR PORT:<br>MultiBeam/AT Corr Data Source:<br>MultiBeam Corr Data 2nd Source:                                                     | MHZ-BS )<br>ADJUST : 0 ( 0, 1, 2,<br>ETUP, (ENTER) = NEXT SEEEN, (A)<br>S2 Recorder & Correlator<br>IF Processor One<br>BW=64MHz 4x1Bit Sign BS, unprocessed data<br>Y-BS<br>X-BS<br>VLBA<br>VLBA<br>Multibeam Correlator<br>64MHz-BS<br>X-BS<br>X-BS<br>                                              | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []<br>popup<br>IF Processor Two<br>BW=64MHz 4x1Bit Sign BS, unprocessed data<br>Y-BS =<br>X-BS =<br>VLBA =<br>Multibeam Correlator =<br>64MHz-BS =<br>X-BS =                                     |  |  |
| ( 4:32MHZ-BS, 5:64<br>(77> AT-CORR DATA<br>(8) = 5<br>S2 RECORDER PORT:<br>Bandwidth:<br>S2_IND & S2_IN1 Source:<br>S2_IN2 & S2_IN1 Source:<br>S2_IN2 & S2_IN1 Format:<br>S2_IN2 & S2_IN3 Format:<br>CORRELATOR PORT:<br>CORRELATOR PORT:<br>CORRELATOR PORT:<br>MultiBeam/AT Corr Data Source:<br>Multibeam Corr Data 2nd Source:<br>AT Correrlator Data Adjust: | MHZ-BS )<br>ADJUST : 0 ( 0, 1, 2,<br>ETUP, <enter> = NEXT SEEEN, <a<br>S2_Recorder &amp; Correlator<br/>IF Processor One<br/>BW=64MHz 4x1Bit Sign BS, unprocessed data<br/>Y-BS F<br/>X-BS F<br/>YLBA F<br/>Multibeam Correlator F<br/>64MHz-BS F<br/>X-BS F<br/>3.Clock-Cycles Delay F</a<br></enter> | 3 CLK-Cycles Delay )<br>DDR> = CHANGE VALUE : []<br>popup<br>IF Processor Two<br>BW=64MHz 4x1Bit Sign BS, unprocessed data<br>Y-BS<br>X-BS<br>VLBA<br>Multibeam Correlator<br>64MHz BS<br>X-BS<br>3 Clock-Cycles Delay<br>3 Clock-Cycles Delay |  |  |

Figure 3: The required DAS setting for 64 MHz bandwidth recording

best bits we could run at any combination of speeds and bandpasses (within the VSIB limitations). The bandpass formation would need to be before the AD card. One option would be 12 16-MHz bandpasses. In this mode the ATNF multibeam correlator can not be run, but the PC-EVN could be run as a replacement for this, as it has all the necessary data.

The narrower DAS outputs have not been carefully considered for useful operation, but should be straight forward as the same number of bits are supplied with a reduced clock speed.

### 4 Recording

The recording programme is based on the one provided by Metsähovi: **wr**. The flags as follows and the input (or output) should be the the vsib character device, e.g,

>wr -<br/>r 32 -t 3600s -o /i1/t/file\_%03d.dat < /dev/vsib

- -r N, the recording rate in MB/s. Defaults to 32
- -t N[s], the recording amount, if in seconds rate should be given
- -b N, size of one block in bytes, default is 32,000
- -f N, the number of blocks per file, default is 10,000
- -o s, the filename, with standard formating commands
- -c s, the compacting mode
- -m N, the recording mode

-l loop the recording endlessly

- -h usage message
- -v verbose mode

The VSIB has 13 record modes, of which the first five are fully documented. These four are;

- mode 0 all 32 bits read, i.e. four words
- mode 1 the even bits read into two words
- mode 2 the lower 16 bit read into two words
- mode 3 the lower 8 bits read into one word.
- mode 4 the lower 8 even bits read into one word.

The other modes are autocorrelation, test and VLBA modes. These are unlikely to be useful because we can sub-select the bits required in software unless we are overclocking the data. See wr.c for discussion of them. The adapted version of wr adds a header;

- Header style 0.1 was a 16 character time stamp.
- Header style 0.9 is the same 16 time stamp, and a 800 char free format description. It is based on the gico header, which is VSI-E compliant. This should include at the beginning **\$HEAD\_SIZE** %d.
- Header style 1.0 will drop the 16 bit timestamp (as it is included in the header).

The items defined in the header are;

| %2d?%2d |
|---------|
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |
|         |

All are passed as strings, but parsing will need to take account of the nature of the information, i.e. three exponential values for the position, a single integer for the header size, any number values for the clock polynomial, any format for the time or position strings.

A subroutine **read\_head** will be prepared to do all these tasks. Currently it handles any of the header standards, and extracts the time from that.

The data are written with bit stream D0 on the least significant bit (LSB), and so on for as many bits are read (i.e., depending on the mode, 1,2,4,8,16 or 32). With offset binary format, i.e. VLBA statistics mode on the DAS the value can be read as the integer value is the unsigned character value logically ANDed with 0x1,0x3 or 0xF for 1,2 or 4 bit numbers, less 2 to the power of the number of bits less one. That is, for 2 bit numbers, in C, data=c&0x3-2. If full digital sampling correction is not performed the two bits are usually mapped as 1,-1,3,-3 for ATNF statistics, and 3,-1,1,-3 for VLBA.

wr can also write a subset of the data input, this feature is primarily for use with the parallel S2 observations, collected from the S2 formatter C2a port. The output here corresponds to the S2 mode, **32x4-2** or **32a4-2** or other. In these cases the data is either first 4 channels (UIC 0 to 3) or the first two and skip two (UIC 0,1 and 4,5). wr band selection can be any of the pairs of bit streams, and is referred to in the same way as vsipack. Mode "ooxx" selects the first four bitstreams and "oxox" the odd ones. These two modes match the S2 modes **32x4-2** and **32a4-2**.

The header values can be set via **control\_wr**, which also stops, pauses and starts the recording. These are transferred via a shared memory segment.

#### 4.1 Current issues

Full compliance to VSI-E standards would be an obvious approach, but as the Swinburne baseband library is being used conforming to their header style also makes sense. A final choice is yet to be made, but an additional header routine will probably be added to the bandband libraries. Digital filters could be included. **read\_head** is a work in progress.

### 5 Monitoring the data

Obviously monitoring the data quality is an important task as collecting it. Two programs have been written for this: **maxim\_stats** for offset binary data: two, four or eight bits in length and **make\_cross\_fft** a XF correlator for VLBI data.

At a station **make\_cross\_fft** is run in autocorrelation mode, where it checks for the presence of the 1PPS, calculates the statistics for the results (17%,33%,33%,17% for a perfectly sampled Gaussian noise dataset). It can also calculate the lag spectra, and plot these as lag amplitude, real or imaginary, and bandpass amplitude or phase. With the delay information it is also a simple cross correlator, which requires no extra or special libraries. A configuration file example.

0.1 0 1 512 1600 J1037-2934.DELAY 1 0 #nsec refant IFno nchan freq delayfile record\_mode bit\_type PKS /mnt/cdrom/pks-bpass-mode3-000 2 0 #Station file\_name delay\_column offset\_usec CAT /mnt/cdrom/cat-bpass-mode3-000 6 0

The program is run as

> make\_cross\_fft configure.file h:m:s [pgplot\_device type]

Types are a,r,i,b,p for lag amplitude, real and imaginary, bandpass amplitude and phase. Figure 4 shows the statistics for a BG2 recording (when the data from IF2 are all held high) and the bandpass for IF1.

#### 5.1 Current issues

make\_cross\_fft does not have a 64 MHz option as yet, and assumes the bandpasses are 16 MHz wide. It can run as real time correlator, with one 2-GHz CPU per product. It has also been demonstrated as a fringe checker. It can be run in correlate-rotate mode, or vice versa. Only narrow band multichannel (spectral line) VLBI observations require the slower rotate-correlate mode. A FX version has been written but further development depends on demand.



Figure 4: Autocorrelation output from make\_cross\_fft, showing the statistics distribution, and the bandpass for all four stokes.