sfxc-guide
                Differences
This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
| sfxc-guide [2023/07/10 14:22] – keimpema | sfxc-guide [2023/07/10 14:38] (current) – keimpema | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| - | < | + | ====== SFXC User's Manual ====== | 
| - | < | + | Mark Kettenis (JIVE) | 
| - | <span class=" | + | |
| - | running it is somewhat dependent on the <acronym class=" | + | |
| - | implementation installed on your system. | + | |
| - | for OpenMPI, which currently seems to be the most popular Open Source | + | |
| - | MPI implementation for Linux systems. | + | |
| - | </ | + | ===== Chapter 1. Running the SFXC correlator ===== | 
| - | <code class=" | + | SFXC is an MPI application. This means that running it is somewhat dependent on the MPI implementation installed on your system. The instructions here are for OpenMPI, which currently seems to be the most popular Open Source MPI implementation for Linux systems. | 
| - | </ | + | |
| - | where <em class=" | + | '' | 
| - | control file that describes the correlation | + | $ **mpirun --machinefile | 
| - | parameters, <em class=" | + | '' | 
| - | that describes the experiment, <em class=" | + | |
| - | MPI processes to start as described by the machine | + | |
| - | file <em class=" | + | |
| - | file <em class=" | + | |
| - | </ | + | |
| - | When creating the rank file, there are a few things that need to be | + | |
| - | taken into account. | + | |
| - | The process with rank 0 becomes | + | where // | 
| - | process doesn' | + | |
| - | a single slot to it. | + | |
| - | The process with rank 1 becomes the log process. | + | When creating the rank file, there are a few things that need to be taken into account. The process with rank 0 becomes the manager process. Since the manager process doesn' | 
| - | process, there is no point in assigning more than a single slot. | + | |
| - | The process with rank 2 becomes | + | The processes starting at rank 3 become input processes. There will be one input process for each station in the correrlation. When correlating directly from Mark5 disk packs, these processes will need to run on the Mark5s containing the diskpacks for those stations. When correlating from files, these processes will need to run on machines that have access to the data files for these stations. | 
| - | able to take advantage | + | |
| - | good idea if you expect a significant output data rate. | + | |
| - | At JIVE we usually run all these processes on the cluster head node. | + | The remainder of the processes will be assigned to correlations processes. A single slot is sufficient | 
| - | </ | + | |
| - | The processes | + | |
| - | be one input process for each station in the correrlation. | + | |
| - | correlating directly from Mark5 disk packs, these processes will need | + | |
| - | to run on the Mark5s containing the diskpacks | + | |
| - | When correlating from files, | + | |
| - | machines that have access to the data files for these stations. | + | |
| - | The process with rank 3 will be assigned to the station that comes | + | === Example 1.1. Rank file example === | 
| - | first when the stations are ordered alphabetically by station code. | + | |
| - | The process with rank 4 will be assigned to the station that comes | + | |
| - | second, etc. | + | |
| - | The input processes do the unpacking and corner turning of the input | + | <code> | 
| - | data, which can be cpu intensive. | + | |
| - | good idea. By default the unpacking happens in two seperate threads, | + | |
| - | so using two or three slots makes sense. | + | |
| - | </ | + | |
| - | The remainder of the processes will be assigned to correlations | + | |
| - | processes. | + | |
| - | </ | + | |
| rank 0=head slot=0 | rank 0=head slot=0 | ||
| rank 1=head slot=1 | rank 1=head slot=1 | ||
| Line 66: | Line 31: | ||
| rank 36=sfxc-a2 slot=7 | rank 36=sfxc-a2 slot=7 | ||
| rank 37=sfxc-a3 slot=7 | rank 37=sfxc-a3 slot=7 | ||
| - | </pre></ | + | </code> | 
| - | <span class=" | + | |
| - | that's included in the distribution. | + | SFXC will automatically generate delay tables using the CALC10 code that's included in the distribution. The CALC10 needs some additional input files to do its work. These are the JPL Solar System Ephemeris ('' | 
| - | input files to do its work. These are the JPL Solar System Ephemeris | + | |
| - | (<code class=" | + | ===== Chapter 2. The correlator control file | 
| - | (<code class=" | + | |
| - | (<code class=" | + | The correlator control file uses the JavaScript Object Notation (JSON) format. It is constumary to give these files a '' | 
| - | directory pointed to by the <code class=" | + | |
| - | variable. | + | * '' | 
| - | ocean loading and antenna tilt information for many antennas that | + | A string specifying the name of the file to write the correltor output to. It is costumary to give this file a '' | 
| - | co-observe with the European VLBI Network (EVN) can be found | + | |
| - | in <code class=" | + | * '' | 
| - | distribution. | + | An integer specifying the number of desired spectral channels in the correlator output. Has to be power of two. | 
| - | </ | + | |
| - | The correlator control file uses the JavaScript Object Notation (JSON) | + | * '' | 
| - | format. | + | A floating-point number specifying the integration time in seconds. Will be rounded to the nearest integral microsecond. | 
| - | a <code class=" | + | |
| - | </ | + | * '' | 
| - | A string specifying the name of the file to write the | + | A boolean indicating whether cross hands should be calculated or not. | 
| - | correltor output to. It is costumary to give this file | + | |
| - | a <code class=" | + | * '' | 
| - | </ | + | A list of strings specifying the stations that are to be correlated. | 
| - | An integer specifying the number of desired spectral channels | + | |
| - | in the correlator output. | + | * '' | 
| - | </ | + | An object containing a list of strings for each station specifying the data source locations for each station. Each data source location is specified in the form of a Uniform Resource Identifier (URI). To correlate data from plain files, the standard file scheme can be used. Correlating data directly from Mark5 disk packs is achieved by specifying an appropriate mk5: URI. All URIs for a single station must use the same scheme. Specifying multiple URIs for a single station is currently only supported for the file scheme. | 
| - | A floating-point number specifying the integration time in | + | |
| - | seconds. | + | * '' | 
| - | </ | + | A string specifying the start time of the correlation. The time should be specified in VEX (#### | 
| - | A boolean indicating whether cross hands should be calculated | + | |
| - | or not. | + | * '' | 
| - | </ | + | A string specifying the end time of the correlation. The time should be specified in VEX (#### | 
| - | A list of strings specifying the stations that are to be correlated. | + | |
| - | </ | + | * '' | 
| - | An object containing a list of strings for each station | + | A string specifying the experiment name. Used for generating and referencing the appropriate delay tables. | 
| - | specifying the data source locations for each station. | + | |
| - | data source location is specified in the form of a Uniform | + | * '' | 
| - | Resource Identifier (URI). | + | A string specifying the directory in which to store the delay tables. | 
| - | files, the standard | + | |
| - | Correlating data directly from Mark5 disk packs is achieved by | + | |
| - | specifying an appropriate | + | |
| - | single station must use the same scheme. | + | |
| - | URIs for a single station is currently only supported for | + | |
| - | the <code class=" | + | |
| - | </ | + | |
| - | A string specifying the start time of the correlation. | + | |
| - | time should be specified in VEX (#### | + | |
| - | representing UTC. For real-time correlation the | + | |
| - | string | + | |
| - | instruct the correlator to use the current wall clock time (in | + | |
| - | UTC) as the start time. | + | |
| - | </ | + | |
| - | A string specifying the end time of the correlation. | + | |
| - | time should be specified in VEX (#### | + | |
| - | representing UTC. | + | |
| - | </ | + | |
| - | A string specifying the experiment name. Used for generating | + | |
| - | and referencing the appropriate delay tables. | + | |
| - | </ | + | |
| - | A string specifying the directory in which to store the delay tables. | + | |
| - | </ | + | |
| An example of a control file is given below: | An example of a control file is given below: | ||
| - | </ | + | |
| + | === Example 2.1. Control file example === | ||
| + | <code> | ||
| { | { | ||
| " | " | ||
| Line 154: | Line 99: | ||
| " | " | ||
| } | } | ||
| - | </pre></ | + | </ | 
| - | Some information needs to be provided in the VEX file that is | + | |
| - | typically not emitted by the scheduling software. | + | |
| - | that you have $CLOCK and $EOP blocks. | + | |
| - | with SFXC also use the $TAPELOG_OBS block. | + | |
| - | $EOP block you provide entries at a 24 hour intervals and have an | + | |
| - | additional entry for the day before and the day after the observation. | + | |
| - | All these blocks need to be properly referenced; from the $GLOBAL | + | |
| - | block for $EOP and from the $STATION block fot the $CLOCK and $EOP | + | |
| - | blocks. | + | |
| - | </ | + | |
| - | It is important that the description of the data format in the VEX | + | |
| - | file is correct. | + | |
| - | and VDIF data format and includes some heuristics to determine the | + | |
| - | correct data format from the VEX file.  If <span class=" | + | |
| - | hang or complains it cannot find any valid data, please check that the | + | |
| - | data format description in your VEX file matches reality. | + | |
| - | </ | + | |
| - | record_transport_type should be set to Mark5A and | + | |
| - | electronics_rack_type should be set to Mark4 or VLBA4 in the | + | |
| - | $DAS block; track_frame_format should be set to Mark4 in the | + | |
| - | $TRACKS section | + | |
| - | </ | + | |
| - | record_transport_type should be set to Mark5A and | + | |
| - | electronics_rack_type should be set to VLBA in the $DAS block; | + | |
| - | track_frame_format should be set to VLBA in the $TRACKS | + | |
| - | section | + | |
| - | </ | + | |
| - | record_transport_type should be set to Mark5B in the $DAS | + | |
| - | block, and either a $TRACKS setion should be present and have | + | |
| - | its track_frame_format keyword set to Mark5B | + | |
| - | <a href="# | + | |
| - | , or a $BITSTREAMS block must be present as proposed for the | + | |
| - | upcoming VEX 2 standard. | + | |
| - | </ | + | |
| - | VEX 1.5 does not provide the means to properly specify VDIF as | + | |
| - | the recording format. | + | |
| - | the $THREADS block as proposed for the new VEX 2 standard by | + | |
| - | Walter Brisken from NRAO. | + | |
| - | <a href="# | + | |
| - | However this proposal has been withdrawn in favour of a new | + | |
| - | $DATASTREAMS block. | + | |
| - | $DATASTREAMS blocks once the final VEX 2 standard arrives. | + | |
| - | the meantime a $THREADS block will need to be added, as SCHED | + | |
| - | doesn' | + | |
| - | </ | + | |
| - | record_transport_type should be set to Mark5C or VDIF in the | + | |
| - | $DAS block. | + | |
| - | electronics_rack_type must be WIDAR. | + | |
| - | present. | + | |
| - | </ | + | |
| - | <span class=" | + | |
| - | Your mileage may vary with output from other VLBI scheduling software. | + | |
| - | </ | + | |
| - | SCHED spells this as MARK5B, which is tolerated by <span class=" | + | |
| - | </ | + | |
| - | <a class=" | + | |
| - | </ | + | |
| - | As with the Mark4 hardware correlator, <span class=" | + | |
| - | an AIPS++/CASA MeasurementSet using the <span class=" | + | |
| - | program. | + | |
| - | the VEX file. Copy the VEX file into this directory and rename it to | + | |
| - | <code class=" | + | |
| - | where <em class=" | + | |
| - | experiment as given in the VEX file. | + | |
| - | </ | + | ===== Chapter 3. Preparing your VEX file ===== | 
| - | <code class=" | + | |
| - | </ | + | |
| - | where <em class=" | + | Some information needs to be provided in the VEX file that is typically not emitted by the scheduling software. It is essential that you have $CLOCK and $EOP blocks. Some of the tools distributed with SFXC also use the $TAPELOG_OBS block. We recommend that in the $EOP block you provide entries at a 24 hour intervals and have an additional entry for the day before and the day after the observation. All these blocks need to be properly referenced; from the $GLOBAL block for $EOP and from the $STATION block fot the $CLOCK and $EOP blocks. | 
| - | file. This will produce a MeasurementSet | + | |
| - | named <code class=" | + | |
| - | is possible to specify multiple correlator output files on | + | |
| - | the <span class=" | + | |
| - | files are simply concatenated and written out into a single | + | |
| - | MeasurementSet. | + | |
| - | </ | + | |
| - | To convert data into FITS-IDI such that it can be read into AIPS, | + | |
| - | the <span class=" | + | |
| - | </ | + | It is important that the description of the data format in the VEX file is correct. SFXC currently supports the Mark4, VLBA, Mark5B and VDIF data format and includes some heuristics to determine the correct data format from the VEX file. If SFXC crashes, seems to hang or complains it cannot find any valid data, please check that the data format description in your VEX file matches reality. | 
| - | <code class=" | + | |
| - | </ | + | * '' | 
| + | record_transport_type should be set to Mark5A and electronics_rack_type should be set to Mark4 or VLBA4 in the $DAS block; track_frame_format should be set to Mark4 in the $TRACKS section | ||
| + | |||
| + | * '' | ||
| + | record_transport_type should be set to Mark5A and electronics_rack_type should be set to VLBA in the $DAS block; track_frame_format should be set to VLBA in the $TRACKS section | ||
| + | |||
| + | * '' | ||
| + | record_transport_type should be set to Mark5B in the $DAS block, and either a $TRACKS setion should be present and have its track_frame_format keyword set to Mark5B [1] , or a $BITSTREAMS block must be present as proposed for the upcoming VEX 2 standard. | ||
| + | |||
| + | * '' | ||
| + | VEX 1.5 does not provide the means to properly specify VDIF as the recording format. Current versions of $sfxc; recognize the $THREADS block as proposed for the new VEX 2 standard by Walter Brisken from NRAO. [2] However this proposal has been withdrawn in favour of a new $DATASTREAMS block. The intention is to have SFXC recognize $DATASTREAMS blocks once the final VEX 2 standard arrives. In the meantime a $THREADS block will need to be added, as SCHED doesn' | ||
| + | |||
| + | record_transport_type should be set to Mark5C or VDIF in the $DAS block. If the record_transport_type is set to Mark5C, electronics_rack_type must be WIDAR. A $THREADS block must be present. | ||
| + | |||
| + | SFXC has been tested extensively with VEX output from (NRAO) SCHED. Your mileage may vary with output from other VLBI scheduling software. | ||
| + | |||
| + | |||
| + | [1] SCHED spells this as MARK5B, which is tolerated by SFXC | ||
| + | |||
| + | [2] https:// | ||
| + | |||
| + | ===== Chapter 4. Post-processing ===== | ||
| + | |||
| + | As with the Mark4 hardware correlator, SFXC output is converted into an AIPS++/CASA MeasurementSet using the j2ms2 program. Create a directory with the name of experiment as given in the VEX file. Copy the VEX file into this directory and rename it to experiment.vix where experiment is again the name of the experiment as given in the VEX file. | ||
| + | |||
| + | '' | ||
| + | $ **j2ms2 file ...** | ||
| + | '' | ||
| + | |||
| + | where '' | ||
| + | |||
| + | To convert data into FITS-IDI such that it can be read into AIPS, the **tConvert** program can be used. | ||
| + | |||
| + | '' | ||
| + | $ **tConvert experiment.ms experiment.IDI** | ||
| + | '' | ||
| + | |||
| + | The resulting FITS-IDI can be read directly into AIPS using **FITLD**. | ||
| + | |||
| + | Note that at JIVE we run some additional post-processing tools on the MeasurementSet before converting data into FITS-IDI. The most important things are: | ||
| + | |||
| + | Amplitude correction for a-bit data; currently **j2ms2** assumes all data is 2-bit. | ||
| - | The resulting FITS-IDI can be read directly into AIPS using <span class=" | ||
| - | </ | ||
| - | Note that at JIVE we run some additional post-processing tools on the | ||
| - | MeasurementSet before converting data into FITS-IDI. | ||
| - | important things are: | ||
| - | </ | ||
| - | Amplitude correction for a-bit data; | ||
| - | currently <span class=" | ||
| - | </ | ||
| Flagging of delay-rate zero events. | Flagging of delay-rate zero events. | ||
| - | </ | + | |
| Flagging of data with low weights. | Flagging of data with low weights. | ||
| - | </ | + | |
| - | If you correlate and convert your own data, you may have to take care | + | If you correlate and convert your own data, you may have to take care of these things when reducing the data in AIPS. | 
| - | of these things when reducing the data in AIPS. | + | |
| - | </ | + | |
| - | </ | + | |
sfxc-guide.1688998957.txt.gz · Last modified: 2023/07/10 14:22 by keimpema
                
                