g02qfc performs a multiple linear quantile regression, returning the parameter estimates and associated confidence limits based on an assumption of Normal, independent, identically distributed errors. g02qfc is a simplified version of g02qgc.
The function may be called by the names: g02qfc, nag_correg_quantile_linreg_easy or nag_regsn_quant_linear_iid.
3Description
Given a vector of observed values,
, an design matrix , a column vector, , of length holding the th row of and a quantile , g02qfc estimates the -element vector as the solution to
(1)
where is the piecewise linear loss function , and is an indicator function taking the value if and otherwise.
g02qfc assumes Normal, independent, identically distributed (IID) errors and calculates the asymptotic covariance matrix from
where is the sparsity function, which is estimated from the residuals,
(see Koenker (2005)).
Given an estimate of the covariance matrix, , lower, , and upper, , limits for a confidence interval are calculated for each of the parameters, via
where is the percentile of the Student's distribution with degrees of freedom, where is the rank of the cross-product matrix .
Further details of the algorithms used by g02qfc can be found in the documentation for g02qgc.
4References
Koenker R (2005) Quantile Regression Econometric Society Monographs, Cambridge University Press, New York
5Arguments
1: – IntegerInput
On entry: , the number of observations in the dataset.
Constraint:
.
2: – IntegerInput
On entry: , the number of variates in the model.
Constraint:
.
3: – const doubleInput
Note: where appears in this document, it refers to the array element
.
On entry: , the design matrix, with the
th value for the th variate supplied in , for and .
4: – const doubleInput
On entry: , the observations on the dependent variable.
5: – IntegerInput
On entry: the number of quantiles of interest.
Constraint:
.
6: – const doubleInput
On entry: the vector of quantiles of interest. A separate model is fitted to each quantile.
Constraint:
where is the machine precision returned by X02AJC, for .
7: – double *Output
On exit: the degrees of freedom given by , where is the number of observations and is the rank of the cross-product matrix .
8: – doubleOutput
Note: where appears in this document, it refers to the array element
.
On exit: , the estimates of the parameters of the regression model, with containing the coefficient for the variable in column of X, estimated for .
9: – doubleOutput
Note: where appears in this document, it refers to the array element
.
On exit: , the lower limit of a confidence interval for , with holding the lower limit associated with .
10: – doubleOutput
Note: where appears in this document, it refers to the array element
.
On exit: , the upper limit of a confidence interval for , with holding the upper limit associated with .
11: – IntegerOutput
On exit: holds additional information concerning the model fitting and confidence limit calculations when .
Code
Warning
Model fitted and confidence limits calculated successfully.
The function did not converge whilst calculating the parameter estimates. The returned values are based on the estimate at the last iteration.
A singular matrix was encountered during the optimization. The model was not fitted for this value of .
The function did not converge whilst calculating the confidence limits. The returned limits are based on the estimate at the last iteration.
Confidence limits for this value of could not be calculated. The returned upper and lower limits are set to a large positive and large negative value respectively.
It is possible for multiple warnings to be applicable to a single model. In these cases the value returned in info is the sum of the corresponding individual nonzero warning codes.
12: – NagError *Input/Output
The NAG error argument (see Section 7 in the Introduction to the NAG Library CL Interface).
6Error Indicators and Warnings
NE_ALLOC_FAIL
Dynamic memory allocation failed.
See Section 3.1.2 in the Introduction to the NAG Library CL Interface for further information.
NE_BAD_PARAM
On entry, argument had an illegal value.
NE_INT
On entry, .
Constraint: .
On entry, .
Constraint: .
NE_INT_2
On entry, and .
Constraint: .
NE_INTERNAL_ERROR
An internal error has occurred in this function. Check the function call and any array sizes. If the call is correct then please contact NAG for assistance.
See Section 7.5 in the Introduction to the NAG Library CL Interface for further information.
NE_NO_LICENCE
Your licence key may have expired or may not have been installed correctly.
See Section 8 in the Introduction to the NAG Library CL Interface for further information.
NE_REAL_ARRAY
On entry, .
Constraint: where is the machine precision returned by X02AJC, for all ntau.
NW_POTENTIAL_PROBLEM
A potential problem occurred whilst fitting the model(s). Additional information has been returned in info.
7Accuracy
Not applicable.
8Parallelism and Performance
Background information to multithreading can be found in the Multithreading documentation.
g02qfc is threaded by NAG for parallel execution in multithreaded implementations of the NAG Library.
g02qfc makes calls to BLAS and/or LAPACK routines, which may be threaded within the vendor library used by this implementation. Consult the documentation for the vendor library for further information.
Please consult the X06 Chapter Introduction for information on how to control and interrogate the OpenMP environment used within this function. Please also consult the Users' Note for your implementation for any additional implementation-specific information.
9Further Comments
Calling g02qfc is equivalent to calling g02qgc with
A quantile regression model is fitted to Engels 1857 study of household expenditure on food. The model regresses the dependent variable, household food expenditure, against household income. An intercept is included in the model by augmenting the dataset with a column of ones.