G01AUF combines sets of summaries produced by
G01ATF.
Assume a dataset containing
$n$ observations, denoted by
$x=\left\{{x}_{i}:i=1,2,\dots ,n\right\}$ and a set of weights,
$w=\left\{{w}_{i}:i=1,2,\dots ,n\right\}$, has been split into
$b$ blocks, and each block summarised via a call to
G01ATF. Then G01AUF takes the
$b$ communication arrays returned by
G01ATF and returns the mean (
$\stackrel{}{x}$), standard deviation (
${s}_{2}$), coefficients of skewness (
${s}_{3}$) and kurtosis (
${s}_{4}$), and the maximum and minimum values for the whole dataset.
 1: $\mathrm{B}$ – INTEGERInput

On entry: $b$, the number of blocks the full dataset was split into.
Constraint:
${\mathbf{B}}\ge 1$.
 2: $\mathrm{MRCOMM}\left(20,{\mathbf{B}}\right)$ – REAL (KIND=nag_wp) arrayCommunication Array

On entry: the
$j$th column of
MRCOMM must contain the information returned in
RCOMM from one of the runs of
G01ATF.
 3: $\mathrm{PN}$ – INTEGEROutput

On exit: the number of valid observations, that is the number of observations with
${w}_{i}>0$, for $\mathit{i}=1,2,\dots ,n$.
 4: $\mathrm{XMEAN}$ – REAL (KIND=nag_wp)Output

On exit: $\stackrel{}{x}$, the mean.
 5: $\mathrm{XSD}$ – REAL (KIND=nag_wp)Output

On exit: ${s}_{2}$, the standard deviation.
 6: $\mathrm{XSKEW}$ – REAL (KIND=nag_wp)Output

On exit: ${s}_{3}$, the coefficient of skewness.
 7: $\mathrm{XKURT}$ – REAL (KIND=nag_wp)Output

On exit: ${s}_{4}$, the coefficient of kurtosis.
 8: $\mathrm{XMIN}$ – REAL (KIND=nag_wp)Output

On exit: the smallest value.
 9: $\mathrm{XMAX}$ – REAL (KIND=nag_wp)Output

On exit: the largest value.
 10: $\mathrm{RCOMM}\left(20\right)$ – REAL (KIND=nag_wp) arrayCommunication Array

On exit: an amalgamation of the information held in
MRCOMM. This is in the same format as
RCOMM from
G01ATF.
 11: $\mathrm{IFAIL}$ – INTEGERInput/Output

On entry:
IFAIL must be set to
$0$,
$1\text{ or}1$. If you are unfamiliar with this argument you should refer to
Section 3.4 in How to Use the NAG Library and its Documentation for details.
For environments where it might be inappropriate to halt program execution when an error is detected, the value
$1\text{ or}1$ is recommended. If the output of error messages is undesirable, then the value
$1$ is recommended. Otherwise, if you are not familiar with this argument, the recommended value is
$0$.
When the value $\mathbf{1}\text{ or}\mathbf{1}$ is used it is essential to test the value of IFAIL on exit.
On exit:
${\mathbf{IFAIL}}={\mathbf{0}}$ unless the routine detects an error or a warning has been flagged (see
Section 6).
If on entry
${\mathbf{IFAIL}}=0$ or
$1$, explanatory error messages are output on the current error message unit (as defined by
X04AAF).
Not applicable.
G01AUF is not threaded in any implementation.
The order that the
$b$ communication arrays are stored in
MRCOMM is arbitrary. Different orders can lead to slightly different results due to numerical accuracy of floatingpoint calculations.
Both G01AUF and
G01ATF consolidate results from multiple summaries. Whereas the former can only be used to combine summaries calculated sequentially, the latter combines summaries calculated in an arbitrary order allowing, for example, summaries calculated on different processing units to be combined.
This example summarises some simulated data. The data is supplied in three blocks, the first consisting of $21$ observations, the second $51$ observations and the last $28$ observations. Summaries are produced for each block of data separately and then an overall summary is produced.