Performs Nason's 1996 two-fold cross-validation estimation using packet-ordered non-decimated wavelet transforms and one, global, threshold.
wstCV(ndata, ll = 3, type = "soft", filter.number = 10, family =
"DaubLeAsymm", tol = 0.01, verbose = 0, plot.it = FALSE, norm =
l2norm, InverseType = "average", uvdev = madmad)
A list returning the results of the cross-validation algorithm. The list includes the following components:
a copy of the input noisy data
a reconstruction of the best estimate computed using this algorithm. It is the inverse (computed depending on what the InverseType argument was) of the xvwrWSTt
component.
a thresholded version of the packet-ordered non-decimated wavelet transform of the noisy data using the best threshold discovered by this cross-validation algorithm.
the universal threshold used as the upper bound for the algorithm that tries to discover the optimal cross-validation threshold. The lower bound is always zero.
the best threshold as discovered by cross-validation. Note that this is one number, the global threshold. The wstCVl
function should be used to compute a level-dependent threshold.
a vector containing the various thresholds used by the optimisation algorithm in trying to determine the best one. The length of this vector cannot be pre-determined but depends on the noisy data, thresholding method, and optimisation tolerance.
a vector containing the value of the estimated error used by the optimisation algorithm in trying to minimize the estimated error. The length, like that of xkeep cannot be predetermined for the same reasons.
the noisy data. This is a vector containing the signal plus noise. The length of this vector should be a power of two.
the primary resolution for this estimation. Note that the primary resolution is problem-specific: you have to find out which is the best value.
whether to use hard or soft thresholding. See the explanation for this argument in the threshold.wst
function.
This selects the smoothness of wavelet that you want to use in the decomposition. By default this is 10, the Daubechies least-asymmetric orthonormal compactly supported wavelet with 10 vanishing moments.
specifies the family of wavelets that you want to use. The options are "DaubExPhase" and "DaubLeAsymm".
the cross-validation tolerance which decides when an estimate is sufficiently close to the truth (or estimated to be so).
If TRUE
then informative messages are printed during the progression of the function, otherwise they are not.
If TRUE
then a plot of the progress of optimising the error estimate for different values of the threshold is generated as the algorithm proceeds. The algorithm tries to minimize the error estimate so you should see a ``bowl'' developing. After each iteration the error estimate is plotted with the iteration number so you should see the numbers tend to the bottom of the bowl.
which measure of distance to judge the dissimilarity between the estimates. The functions l2norm
and linfnorm
are suitable examples.
The possible options are "average" or "minent". The former uses basis averaging to form estimates of the unknown function. The "minent" function selects a basis using the Coifman and Wickerhauser, 1992 algorithm to select a basis to invert.
Universal thresholding is used to generate an upper bound for the ideal threshold. This argument provides the function that computes an estimate of the variance of the noise for use with the universal threshold calculation (see threshold.wst
).
Version 3.6 Copyright Guy Nason 1995
G P Nason
This function implements the cross-validation method detailed by Nason, 1996 for computing an estimate of the error between an estimate and the ``truth''. The difference here is that it uses the packet ordered non-decimated wavelet transform
rather than the standard Mallat wd
discrete wavelet transform. As such it is an examples of the translation-invariant denoising of Coifman and Donoho, 1995 but uses cross-validation to choose the threshold rather than SUREshrink.
Note that the procedure outlined above can use AvBasis
basis averaging or basis selection and inversion using the Coifman and Wickerhauser, 1992 best-basis algorithm
GetRSSWST
, linfnorm
, linfnorm
, threshold.wst
, wst
, wst.object
, wstCVl
.