Information
We are currently investigating an issue with the editor of some pages. Please save your work and avoid to create new pages until this banner is gone.
The ALMA uv coverage assessment tool
Table of Contents |
---|
...
Lastest version is assess_ms.py,v 2.24 25 2024/0512/0717.
Under construction.
...
1) Check out the beamWG directory from the JAO CVS repositoryObtain the assess_ms package and install it:
Code Block |
---|
cvs -d :pserver:<your user ID>@cvs01.osf.alma.cl:2401/project21/CVS checkout AIV/science/ArrayConfiguration/beamWGunder construction |
2) Copy the script "run_assess_ms.py" to the directory where you keep the production version of scripts to run.
3) Edit your copy of "run_assess_ms.py" to adapt it to your working environment. What settings you have to change is described in the detailed comments in the script text!
...
(version assess_ms.py,v 2.22 25 2024/04/25 09:49:32 12/17 dpetry)
assess_ms and mshistotools have been under development since 2020. The method has acquired a large range of functionalities,
however, the recommended usage only needs some of them and can leave all other settings at their default.
...
Code Block |
---|
run_assess_ms
Run the assess_ms tool on the given list (vis) of MSs with standard ALMA QA settings.
vis - the list of MSs to assess together as one dataset
outputdir - the directory where to write the output files
use_actual_parameters - if True, determine AR, LAS, representative freq, and on-source time
from the MS(s) themselves.
default: False - take the expected values from the file given by 'reference'
reference - the csv file containing the SB parameters for the ALMA Cycle in question
(provided by the ALMA Scheduling subsystem)
If the given file is not found in the given path, it is searched for in
the directory where the mshistotools module resides.
The expected format of the reference file is a csv file with the column names defined in row 0.
The following columns MUST be present under these exact names. The order can be arbitrary.
Other columns can optionally be present and are ignored.
['SB_UID', 'MOUS_STATUS_UID', 'REQUESTED_EXECUTIONS', 'REPRESENTATIVE_FREQUENCY_GHZ', 'MIN_ANGULAR_RESOLUTION_ARCSEC',
'MAX_ANGULAR_RESOLUTION_ARCSEC', 'MRS_ARCSEC', 'FIELD_SOURCE_NAME', 'FIELD_INTEGRATION_TIME_SEC']
pass_thresh, az_inhomogen_limit - the parameters controlling the QA decision, see help of assess_ms()
defaults: 0.25, 2.0
useL80 - for the case use_actual_parameters==False, this parameter is handed on to assess_ms(), see help of assess_ms()
default: True
mosfields - list of values describing which fields to assess in case the observation is a mosaic, see help of assess_ms()
default: [] - assess all fields
per_eb - if True, set the number of expected executions to the number of input MSs (per SB)
default: False - take the number of expected executions from the reference file
NOTE: only has an effect in the case that use_actual_parameters==False
Returns the return value of assess_ms().
|
Example:
havegroup - if True, regard the set of MSs as a GROUP, default: False
Automatically determined if use_actual_parameters==False
Returns the return value of assess_ms().
|
Example:
Code Block |
---|
sys.path.append('./AIV/science/ArrayConfiguration/beamWG') import assess_ms as ams ams.run_assess_ms(vis=['uid___A002_Xff99e1_X8275.ms', 'uid___A002_Xff294f_X684.ms']) |
...
Code Block |
---|
assess_ms compare the BL length histo of a given observation with the expectation from the PI parameters return True if QA2_PASS is recommended vis - the observed MS(s) or [] (empty list) if the observed histograms are to be taken from storagedir (if a list of MSs is entered, they are combined) Examples: [] - take the observed histograms from the files histo_*.pkl in the directory provided by parameter storagedir ['uid___A002_Xe64b7b_X2ac81.ms.split.cal','uid___A002_Xe64b7b_X2ad02.ms.split.cal'] - extract the observed histogram from the combination of the two given MSs using targetid and repspwid for field and SPW selection. freq_ghz - the frequency at which the PI parameters are given (GHz) If set to None, the central freq of the repspwid will be used. And if repspwid is also None, the central freq of the first science SPW is used. ar_asec_range - the angular resolution range (arcsec) a list of two values: min and max of the expectation range (Negative values are replaced by the angular scale corresponding to the L80 minus 20% for the min AR and +20% for the max AR). las_asec - the largest angular scale (arcsec) (A negative value is replaced by the angular scale corresponding to the L05.) time_s - the estimated necessary exposure time (s) (A negative value is replaced by the actual time on-source as derived for the targetid taking into account flagging.) ar_asec_to_test - the angular resolution(s) (arcsec) the list of the angular resolutions to test in the QA assessment default: [] - behaviour depends on value of parameter "useL80": - if useL80==False: determine best AR from a fit to the observation over five values covering the range given by ar_asec_range - if useL80==True: use L80 value of AR determined from observation targetid - the representative target field id or field NAME. Use the NAME in particular for mosaics to capture all mosaic pointings. (only needed if vis != [], i.e. MSs are to be read) default: the first science target will be used repspwid - the representative SPW id (only needed if vis != [], i.e. MSs are to be read) default: the SPW containing the rep. freq, i.e. freq_ghz, will be used condition - the condition for the calculation of the overall QA assessment options: 'c' - determine filling fraction in nffradbins bins, filling fraction > pass_tresh in all bins, >= 1 in uppermost 10% of the bins, average filling fraction > 0.9 2D inhomogeneity < az_inhomogen_limit in all radial bins. default: 'c' pass_thresh - the passing threshold used in the condition given by parameter "condition". (This threshold is marked in the ten-bin filling fraction plots with a red line.) default: 0.25 az_inhomogen_limit - the maximum accepted chi2 of a constant fit to the azimuthal bins of one radial bin in the 2D FF. (This threshold is marked in the inhomogeneity plot with a red line.) Has no effect if the number of azimuthal bins is < 2. default: 2.0 storagedir - the directory into which to store all plots and histograms The plots are stored as png files. The histograms are stored via the msh.save() method. default: '.' (current working dir) binningversion - the version of the "special" binning to be used for the result histograms: 1 or 2 default: 2 expcalcversion - choose between different options to calculate the expected base line distribution 0: ana_fill=True, rr=True 1: ana_fill=False, rr=True 2: ana_fill=True, rr=False 3: ana_fill=False, rr=False 10: use filldish.from_ex_1d for the 1D histos, rr=False 11: use filldish.from_ex_1d for the 1D histos, rr=True default: 0 relweighting - True: apply only relative weighting when calculating the observed BLDs rather than absolute False: apply relative weighting multiplied by the ratio (OT Tsys (for the given reference freq)/EB Tsys) squared (capped at 1.5) => filling fractions are equivalent to ALMA Execution Fractions default: True - apply only relative weighting useL80 - if True: determine the L80 from the observation and the equivalent AR and append it to the list of ARs to be evaluated for the QA2 decision (see also parameter "ar_asec_to_test") default: False ffplotlim - the upper end of the filling fraction scale to plot in the ten bin plots default: 0. - adapt to the actual values of the filling fractions nffradbins - the number of equidistant radial (i.e. baseline length) bins in which the filling fractions are calculated; number must be even. default: 10 - i.e. use bins which have a width which is 10% of the total BL range nffazbins - the number of equidistant azimuthal (i.e. baseline orientation) bins in which the filling fractions are calculated; number must be 1 or an even number NOTE: this is the number of bins over the range of 180 degrees! default: 1 - i.e. don't distinguish different baseline orientations mosfields - List of the mosaic fields to use in case the observation is a mosaic NOTE: values other than the default are only supported for homogeneous datasets, i.e. using only one array with one and the same mosaic setup for each EB. NOTE: does not affect the "mosfieldcheck" plot, which is always done for all mosaic fields default: [] - use all fields Examples: [0] - use only the first field (counted from the lowest field ID in the mosaic) [0,3] - use the first and the fourth field (if there is no fourth, use the last) [0,'last'] - use the first and the last field [0,'middle'] - use the first and the (n/2)-th field where n == number of mosaic fields plotname - (optional) string to use in the title of the produced plots default: '' - derive the label from the vis parameter havegroup - If True, the set of input MSs is supposed to be a interpreted as a group. This means that in particular different MSs can have different numbers of mosaic fields. default: False Example: assess_ms(['uid___A002_Xe27761_X5551.ms.split.cal'], ar_asec_range=[0.24,0.36], las_asec=5., time_s=112., freq_ghz=336., ar_asec_to_test=[0.24,0.31,0.36], storagedir='SPT0109-47results') |
...