Learn R Programming

oce (version 0.9-18)

ctdTrim: Trim start/end portions of a CTD cast

Description

Trim start/end portions of a CTD cast.

Usage

ctdTrim(x, method, removeDepthInversions=FALSE, parameters,
        debug=getOption("oceDebug"))

Arguments

x
A ctd object, e.g. as read by read.ctd.
method
A string (or a vector of two strings) specifying the trimming method, or a function to be used to determine data indices to keep. If method is not provided, "downcast" is assumed. See Details.
removeDepthInversions
Logical value indicating whether to remove any levels at which depth is less than, or equal to, a depth above. (This is needed if the object is to be assembled into a section, unless ctdDecimate
parameters
A list whose elements depend on the method; see Details.
debug
a flag that turns on debugging. Set to 1 to get a moderate amount of debugging information, or to 2 to get more.

Value

  • An object of class "ctd", with data having been trimmed in some way.

Details

Often in CTD profiling, the goal is to isolate only the downcast, discarding measurements made in the air, in an equilibration phase in which the device is held below the water surface, and then the upcast phase that follows the downcast. This is handled reasonably well by ctdTrim with method="downcast", although it is almost always best to use plotScan to investigate the data, and then use the method="index" or method="scan" method based on visual inspection of the data. The details methods are as follows.

  • Ifmethod[1]is"downcast"then an attempt is made to only data for which the CTD is descending. This is done in stages, with variants based onmethod[1], if supplied.Step 1.The pressure data are despiked with a smooth() filter with method "3R". This removes wild spikes that arise from poor instrument connections, etc.Step 2.If noparametersare given, then any data with negative pressures are deleted. If there is a parameter namedpmin, then that pressure (in decibars) is used instead as the lower limit. This is a commonly-used setup, e.g.ctdTrim(ctd, parameters=list(pmin=1))removes the top decibar (roughly 1m) from the data. Specifyingpminis a simple way to remove near-surface data, such as a shallow equilibration phase, and if specified will causectdTrimto skip step 4 below.Step 3.The maximum pressure is determined, and data acquired subsequent to that point are deleted. This removes the upcast and any subsequent data.Step 4.If thepminparameter is not specified, an attempt is made to remove an initial equilibrium phase by a regression of pressure on scan number. There are three variants to this, depending on the value of the secondmethodelement. If it is"A"(or not given), the procedure is to callnlsto fit a piecewise linear model of pressure as a function of scan, in which pressure is constant for scan less than a critical value, and then linearly varying for with scan. This is meant to handle the common situation in which the CTD is held at roughly constant depth (typically a metre or so) to equilibrate, before it is lowered through the water column. Case"B"is the same, except that the pressure in the surface region is taken to be zero (this does not make much sense, but it might help in some cases). Note that, prior to early 2016, method"B"was called method"C"; the old"B"method was judged useless and was removed.
If method="index" or "scan", then each column of data is subsetted according to the value of parameters. If the latter is a logical vector of length matching data column length, then it is used directly for subsetting. If parameters is a numerical vector with two elements, then the index or scan values that lie between parameters[1] and parameters[2] (inclusive) are used for subsetting. The two-element method is probably the most useful, with the values being determined by visual inspection of the results of plotScan. While this may take a minute or two, the analyst should bear in mind that a deep-water CTD profile might take 6 hours, corresponding to ship-time costs exceeding a week of salary. If method="range" then data are selected based on the value of the column named parameters$item. This may be by range or by critical value. By range: select values between parameters$from (the lower limit) and parameters$to (the upper limit) By critical value: select if the named column exceeds the value. For example, ctd2 <- ctdTrim(ctd, "range", parameters=list(item="scan", from=5)) starts at scan number 5 and continues to the end, while ctdTrim(ctd,"range",parameters=list(item="scan",from=5,to=100)) also starts at scan 5, but extends only to scan 100.

If method is a function, then it must return a vector of logical values, computed based on two arguments: data, which is set to x@data (a list), and parameters as supplied to ctdTrim. Both inferWaterDepth and removeInversions are ignored in the function case. See Examples.

References

The Seabird CTD instrument is described at http://www.seabird.com/products/spec_sheets/19plusdata.htm.

See Also

The documentation for ctd-class explains the structure of CTD objects, and also outlines the other functions dealing with them.

Examples

Run this code
library(oce)
data(ctdRaw) 
plot(ctdRaw) # barely recognizable, due to pre- and post-cast junk
plot(ctdTrim(ctdRaw)) # looks like a real profile ...
plot(ctdDecimate(ctdTrim(ctdRaw),method="boxcar")) # ... smoothed
# Demonstrate use of a function. The scan limits were chosen
# by using locator(2) on a graph made by plotScan(ctdRaw).
trimByIndex <- function(data, parameters) {
  parameters[1] < data$scan & data$scan < parameters[2]
}
trimmed <- ctdTrim(ctdRaw, trimByIndex, parameters=c(130, 380))
plot(trimmed)

Run the code above in your browser using DataLab