Skip to content

Latest commit

 

History

History
393 lines (228 loc) · 14.7 KB

FCFC_2PT.md

File metadata and controls

393 lines (228 loc) · 14.7 KB

Configuration parameters for FCFC_2PT

Template configuration file: fcfc_2pt.conf.

Table of Contents

Specifications of the input catalogues

CATALOG (-i / --input)

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 ]

[TOC]

CATALOG_LABEL (-l / --label)

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]

[TOC]

CATALOG_TYPE (-T / --type)

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]

[TOC]

ASCII_SKIP (--skip)

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]

[TOC]

ASCII_COMMENT (--comment)

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 = ['', '!']

[TOC]

ASCII_FORMATTER (-f / --formatter)

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'.

[TOC]

POSITION (-x / --position)

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]

[TOC]

WEIGHT (-w / --weight)

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)]

[TOC]

SELECTION (-s / --select)

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]

[TOC]

COORD_CONVERT (--convert)

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

[TOC]

Fiducial cosmology for coordinate conversion

OMEGA_M (-d / --omega-m)

Density parameter of matter at z = 0. It must be a double-precision floating point number, in the range (0, 1].

[TOC]

OMEGA_LAMBDA (--omega-l)

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.

[TOC]

DE_EOS_W (--eos-w)

Dark energy equation of state. It must be a double-precision floating point number, and ≤ 1/3. By default it is −1.

[TOC]

CMVDST_ERR (--cmvdst-err)

The tolerance of the integration error. It must be larger than the machine epsilon, i.e., around 1e-16.

[TOC]

Z_CMVDST_FILE (--cmvdst-file)

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)

[TOC]

Configurations for the 2-point correlation function

DATA_STRUCT (-S / --data-struct)

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.

[TOC]

BINNING_SCHEME (-B / --bin)

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).

[TOC]

PAIR_COUNT (-p / --pair)

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'

[TOC]

PAIR_COUNT_FILE (-P / --pair-output)

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.

[TOC]

CF_ESTIMATOR (-e / --cf)

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

[TOC]

CF_OUTPUT_FILE (-E / --cf-output)

Name of the output files for 2PCFs. It can be a string or string array, depending on the dimension of CF_ESTIMATOR.

[TOC]

MULTIPOLE (-m / --multipole)

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

[TOC]

MULTIPOLE_FILE (-M / --mp-output)

Name of the output files for 2PCF multipoles. It can be a string or string array, depending on the dimension of CF_ESTIMATOR.

[TOC]

PROJECTED_CF (-u / --wp)

Indicate whether the projected 2PCF is required. It must be a boolean value, and is applied to all 2PCFs defined by CF_ESTIMATOR.

[TOC]

PROJECTED_FILE (-U / --wp-output)

Name of the output files for the projected 2PCFs. It can be a string or string array, depending on the dimension of CF_ESTIMATOR.

[TOC]

Definitions of the bins

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.

SEP_BIN_FILE (--s-file)

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.

[TOC]

SEP_BIN_MIN (--s-min)

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.

[TOC]

SEP_BIN_MAX (--s-max)

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.

[TOC]

SEP_BIN_SIZE (--s-step)

The width of all separation bins. It must be a positive double-precision floating-point number.

[TOC]

MU_BIN_NUM (--mu-num)

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.

[TOC]

PI_BIN_FILE (--pi-file)

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.

[TOC]

PI_BIN_MIN (--pi-min)

Lower boundary of π bins. It is the minimum separation of interest. It must be a double-precision floating-point number.

[TOC]

PI_BIN_MAX (--pi-max)

Upper boundary of π bins. Only separations below this value are recorded. It must be a double-precision floating-point number.

[TOC]

PI_BIN_SIZE (--pi-step)

The width of all π bins. It must be a positive double-precision floating-point number.

[TOC]

Other settings

OUTPUT_FORMAT (-F / --out-format)

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.

[TOC]

OVERWRITE (-O / --overwrite)

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.

[TOC]

VERBOSE (-v / --verbose)

A boolean value indicating whether to show detailed standard outputs.

[TOC]