Create a copy of an object in which some element of its
data
slot has been altered, or added.
Arguments
- object
an oce object.
- name
String indicating the name of the
data
item to be set.- value
Value for the item.
- unit
An optional indication of the units for the item. This has three possible forms (see “Details”).
- originalName
Optional character string giving an 'original' name (e.g. as stored in the header of a data file).
- note
Either empty (the default), a character string, or
NULL
, to control additions made to the processing log of the return value. Ifnote=""
then the an entry is created based on deparsing the function call. Ifnote
is a non-empty string, then that string gets added added to the processing log. Finally, ifnote=NULL
, then nothing is added to the processing log. This last form is useful in cases whereoceSetData
is to be called many times in succession, resulting in an overly verbose processing log; in such cases, it might help to add a note by e.g.processingLog(a) <- "QC (memo dek-2018-01/31)"
Value
An oce object, the data
slot of which has
been altered either by adding a new item or modifying an existing
item.
Details
The trickiest argument to set is the unit
. There are three
possibilities for this:
unit
is a named or unnamedlist()
that contains two items. If the list is named, the names must beunit
andscale
. If the list is unnamed, the stated names are assigned to the items, in the stated order. Either way, theunit
item must be anexpression()
that specifies the unit, and thescale
item must be a string that describes the scale. For example, modern temperatures haveunit=list(unit=expression(degree*C), scale="ITS-90")
.unit
is anexpression()
giving the unit as above. In this case, the scale will be set to""
.unit
is a character string that is converted into an expression with parse(text=unit)
, and the scale set to""
.
See also
Other things related to the data slot:
oceDeleteData()
,
oceGetData()
,
oceRenameData()
Examples
data(ctd)
Tf <- swTFreeze(ctd)
ctd <- oceSetData(ctd, "freezing", Tf,
unit = list(unit = expression(degree * C), scale = "ITS-90")
)
plotProfile(ctd, "freezing")