Template configuration file: fcfc_2pt.conf
.
- Specifications of the input catalogues
- Fiducial cosmology for coordinate conversion
- Configurations for the 2-point correlation function
- Definitions of the bins
- Other settings
Filename of the input catalogues. They can be either strings or string arrays.
Examples
CATALOG = /path/to/input_data.dat
CATALOG = [ data_catalog.dat, \
rand_catalog.dat ]
Label of the input catalogs. They must be non-repetitive uppercase letters, and are used for indicating the sources of the pairs to be counted. For instance, the two sources of a pair "DR
" are the catalogues labelled by "D
" and "R
", respectively.
If this parameter is not set, the input catalogues are labelled in alphabetical order, i.e. [A
, B
, ...].
Examples
CATALOG_LABEL = A
CATALOG_LABEL = [D,R,S]
Format of the input catalogs. They must be integers or integer arrays, depending on the dimension of CATALOG
. The allowed values are:
0
(default): for ASCII format text files;1
: for FITS tables;2
: for HDF5 files.
In particular, FITS and HDF5 formats are supported through external libraries (see README.md for details).
Examples
CATALOG_TYPE = 0
CATALOG_TYPE = [0,1]
Number of lines to be skipped for ASCII format input files. They can be non-negative long integers or long integer arrays, depending on the dimension of CATALOG
.
Examples
ASCII_SKIP = 10
ASCII_SKIP = [0,5]
Indicator of comment lines for ASCII format input files. They can be characters or character arrays, depending on the dimension of CATALOG
. If the first non-whitespace character of a line is the specified character, then the whole line of the input catalogue is omitted. If empty characters (''
) are supplied, then no line is treated as comments.
Examples
ASCII_COMMENT = '#'
ASCII_COMMENT = ['', '!']
C99-style formatter specifying the format of columns of ASCII format input files. They must be strings or string arrays, depending on the dimension of CATALOG
. Note however that only formatters with the following argument types are supported (see cppreference.com for details):
int *
long *
float *
double *
char *
Examples
ASCII_FORMATTER = "%d %ld %f %lf %s" # for int, long, float, double, and string types
ASCII_FORMATTER = "%*d,%10s,%[123]"
# Column separators are ',';
# The first column is treated as an integer, but is omitted;
# The second column is a string with 10 characters;
# The third column is a string composed of characters '1', '2', and '3'.
3-D coordinates, in the order of {x, y, z} or {RA, Dec, redshift}, where RA and Dec must be in degrees. The dimension of this parameter must be at least 3 times that of CATALOG
.
The strings must be column indicators, or expressions, which are parsed using the libast library. The syntaxes of column indicators for different file formats are summarised below:
File format | Column indicator | Description | Example |
---|---|---|---|
ASCII | $number or ${number} | number indicates the index of a column (starting from 1, omitted columns are not counted), and must be enclosed by braces if it is not less than 10 | $3 , ${12} |
FITS | ${name} | name indicates the name of a column (column with multiple values is not supported so far) | ${RA} |
HDF5 | ${name} or ${name(index)} | name indicates the full name of a dataset, and index indicates the index of the shorter dimension (starting from 1) if the the dataset is in 2D | ${/data/x} , ${position(1)} |
Moreover, expressions are supported for pre-processing the columns, with some basic arithmetic operators, and mathematical functions (see libast for details).
Examples
POSITION = [${RA}*180/3.1415927, ${DEC}, ${Z}, $1, $2, $3]
Weights for pair counts. They can be column indicators or expressions, depending on the dimension of CATALOG
. If this parameter is not set, no weights are applied to any of the catalogues.
Examples
WEIGHT = ${WEIGHT_SYSTOT} * ${WEIGHT_NOZ} * ${WEIGHT_CP} * ${WEIGHT_FKP}
WEIGHT = [1, $4 * ($5 + $6 - 1)]
Selection criteria for the input catalogues. They can be column indicators or expressions. Numerical, bitwise, and logical expressions are all supported. Only objects with columns fulfilling the conditions are kept.
Examples
SELECTION = isfinite($1) && $3 == "YES" && log($4) < 1.0
SELECTION = [($5 & 1) != 0, $3 >= 0.5]
Specify whether coordinate conversion is needed for the data and random catalogues. They must be boolean values or boolean arrays, depending on the dimension of CATALOG
. If the conversion for any of the catalogues is enabled, the parameters specified in the section Fiducial cosmology for coordinate conversion are used.
Examples
COORD_CONVERT = T
COORD_CONVERT = [1,False] # 1 for true
Density parameter of matter at z = 0. It must be a double-precision floating point number, in the range (0, 1].
Density parameter of dark energy at z = 0. It must be a double-precision floating point number, and ≥ 0. By default it is 1 − OMEGA_M
.
Dark energy equation of state. It must be a double-precision floating point number, and ≤ 1/3. By default it is −1.
The tolerance of the integration error. It must be larger than the machine epsilon, i.e., around 1e-16
.
Filename of an ASCII table for redshift to radial comoving distance conversion. The first two columns of this file have to be redshift and radial comoving distance, respectively. If the columns or units are not appropriate, the file can be passed to the program via command line options and pipe, e.g.
./FCFC_2PT --cmvdst-file <(awk '{printf("%lf %lf\n", $3, $4 * 0.676)}' input_cnvt_file.txt)
Data structure used for pair count evaluations. It must be an integer, and the allowed values are:
0
(default): k-d tree;1
: ball tree.
In most cases the choice of data structure does not significantly affect the performance.
Binning scheme of the 2PCF to be evaluated. It must be an integer, and the allowed values are:
0
: isotropic separation bins for ξ(s)1
: anisotropic separation bins for ξ(s, μ) (required by 2PCF multipoles);2
: 2-D separation bins for ξ(sperp, π) (required by the projected 2PCF).
Identifiers of pair counts, which are consist of CATALOG_LABEL
. The labels indicate the source catalogues of the pairs. This parameter must be two-character strings or string arrays.
Examples
PAIR_COUNT = DD # auto pair counts of catalog 'D'
PAIR_COUNT = [DD,DR,RR] # "DR" denotes cross pairs from catalogs 'D' and 'R'
Name of the files for pair counts. It can be a string or string array, depending on the dimension of PAIR_COUNT
. If a specified file exists, then the pair counts are read from this file; otherwise the pair counts are evaluated and saved to the file.
Estimators of the 2PCFs to be evaluated. It can be expressions consist of PAIR_COUNT
.
Examples
CF_ESTIMATOR = DD / RR - 1 # natural estimator
CF_ESTIMATOR = (DD - 2*DR + RR) / RR # Landy-Szalay estimator
Name of the output files for 2PCFs. It can be a string or string array, depending on the dimension of CF_ESTIMATOR
.
Legendre multipoles of the power spectra to be evaluated. It must be a non-negative integer, or integer arrays. The current maximum supported ℓ is 6
. Note that these multipoles are evaluated for all 2PCFs defined by CF_ESTIMATOR
.
Examples
MULTIPOLE = [0,2,4] # for monopole. quadrupole, and hexadecapole
Name of the output files for 2PCF multipoles. It can be a string or string array, depending on the dimension of CF_ESTIMATOR
.
Indicate whether the projected 2PCF is required. It must be a boolean value, and is applied to all 2PCFs defined by CF_ESTIMATOR
.
Name of the output files for the projected 2PCFs. It can be a string or string array, depending on the dimension of CF_ESTIMATOR
.
Note: all bins defined in this section are left-closed and right-open (unless otherwise stated), i.e., the lower boundary is included in the bin, while the upper boundary is not.
Name of the file defining separation (either s or sperp bins. The file should be an ASCII table, with the first two columns being the lower and upper boundary of each separation bin, respectively.
If this parameter is not set, then linear separation bins defined by SEP_BIN_MIN
, SEP_BIN_MAX
, and SEP_BIN_SIZE
are used.
Lower boundary of separation (either s or sperp bins. It is the minimum separation of interest. It must be a double-precision floating-point number.
Upper boundary of separation (either s or sperp bins. Only separations below this value are recorded. It must be a double-precision floating-point number.
The width of all separation bins. It must be a positive double-precision floating-point number.
Number of μ bins in the range [0, 1) or [0, 1] (if the program is compiled with WITH_MU_ONE = T
, see README.md for details). It must be a positive integer.
Name of the file defining π bins. The file should be an ASCII table, with the first two columns being the lower and upper boundary of each π bin, respectively.
If this parameter is not set, then linear separation bins defined by PI_BIN_MIN
, PI_BIN_MAX
, and PI_BIN_SIZE
are used.
Lower boundary of π bins. It is the minimum separation of interest. It must be a double-precision floating-point number.
Upper boundary of π bins. Only separations below this value are recorded. It must be a double-precision floating-point number.
The width of all π bins. It must be a positive double-precision floating-point number.
Format of the output pair count files (PAIR_COUNT_FILE
). It must be an integer, and the allowed values are:
0
(default): FCFC binary format;1
: ASCII text format.
The binary format stores all metadata of the pair counts, and can be read with the script read_pair_count.py
.
An integer value indicating whether to overwrite existing files. Allowed values are
0
(default): quit the program when an output file exist;1
: overwrite 2PCF files silently, but keep (read from) existing pair count files;2
or larger: overwrite all output files silently whenever possible;- negative: notify at most this number (absolute value) of times, for asking whether overwriting existing files.
A boolean value indicating whether to show detailed standard outputs.