Write a specifications file for the AgeingError package
Source:R/write_specs_file.R
write_specs_file.Rd
The resulting file has the format required by the load_specs()
function.
In the future, this step could be bypassed by creating the list output
from load_specs()
directly.
This function is based on a subset of the RunFn() function in the older ADMB
version of this package.
Usage
write_specs_file(
dir = getwd(),
file_name = "data.spc",
nreaders,
biasopt = NULL,
sigopt = NULL,
knotages = NULL
)
Arguments
- dir
Directory where the specifications file will be saved.
- file_name
Name of the specifications file.
- nreaders
An integer, specifying the number of readers.
- biasopt
A vector with one entry for each reader specifying the type of bias specific to each reader. Positive values lead to estimated parameters and negative values are used for shared parameters between readers. Parameter sharing (mirroring) is common when there is more than one reader in a lab working together to refine their methods such that they have matching techniques. If NULL is passed, the default is
rep(0, nreaders)
which specifies that all readers are unbiased.Possible entries include the following:
- -[0-9]+
Mirror the bias of another reader, where the negative integer corresponds to the column of the reader that is being mirrored minus one, e.g.,
-1
causes it to mirror reader 1. Only lower-numbered readers can be mirrored.- 0
Unbiased, where at least one reader has to be unbiased.
- 1
Constant coefficient of variation, i.e., a 1-parameter linear relationship of bias with true age.
- 2
Curvilinear, i.e., a 2-parameter Hollings-form relationship of bias with true age.
An example entry for the situation where you have seven readers and you assume that the first reader is unbiased, readers 2-7 have a curvilinear bias, reader 3 shares parameters with reader 2, reader 5 shares parameters with reader 4, and reader 7 shares parameters with reader 6 would look like
c(0, 2, -2, 2, -4, 2, -6)
.- sigopt
A vector with one entry for each reader. Each entry specifies the functional form of reading error as a function of true age. Positive values lead to estimated parameters and negative values are used for shared parameters between readers. If NULL is passed, the default is
c(1, rep(-1, nreaders - 1))
which specifies a constant CV in ageing error which is shared among all readers.Possible entries include the following:
- -0-9+
Mirror the standard deviation of another reader, where the negative integer corresponds to the column of the reader that is being mirrored minus one, e.g.,
-1
causes it to mirror reader 1, for which data is stored in the second column ofData
. This number must be lower than -1 times the current position in the vector.- 0
No error. But, there could be potential bias.
- 1
Constant coefficient of variation, i.e., a 1-parameter linear relationship of the standard deviation with the true age.
- 2
Curvilinear standard deviation, i.e., a 3-parameter Hollings-form relationship of standard deviation with true age.
- 3
Curvilinear coefficient of variation, i.e., a 3-parameter Hollings-form relationship of coefficient of variation with true age.
- 5
Spline with estimated slope at beginning and end where the number of parameters is 2 + number of knots.
- 6
Linear interpolation with a first knot of 1 and a last knot of the maximum age, i.e.,
MaxAge
.
- knotages
Ages associated with each knot. This is a necessary input for
sigopt = 5
orsigopt = 6
. Not implemented in this function yet.
See also
write_files()
, write_specs_file()
, load_specs()
Examples
data_test <- data.frame(
reader1 = c(7, 10, 7, 6, 6, 10, 7, 9, 8, 10, 10, 5, 6, 7, 9, 7, 7, 5, 8, 5),
reader2 = c(8, 10, 7, 6, 6, 10, 7, 9, 8, 10, 10, 5, 6, 7, 9, 7, 7, NA, NA, NA),
reader3 = c(7, 10, 7, 6, 6, 8, 7, 9, 8, 10, 10, 5, 6, 7, NA, NA, NA, 5, 8, 5)
)
data_file <- write_data_file(data_test, dir = tempdir(), file_name = "test.dat")
#> ℹ Input 'dat' doesn't contain a column called 'count'; adding one via tally_repeats()
#> ℹ Total observations: 20
#> ℹ Aggregated unique combinations: 12
#> ℹ Range of observed ages in the data: 5 - 10
#> ℹ Number of readers: 3
#> ℹ Max age not specified; using 15 which is the multiple of 5 which is >120% of the observed maximum
#> ℹ Minus group set to the minimum observed age 5
#> ℹ Plus group set to the maximum observed age 10
#> ℹ Reference age not specified; using 7 = floor(median(c(minusage, plusage)))
#> ℹ Writing data file to /tmp/Rtmpk1RUGZ/test.dat
specs_file <- write_specs_file(dir = tempdir(), nreaders = 3, file_name = "test.spc")
#> ℹ 'biasopt' not specified; settings all readers to unbiased
#> ℹ 'sigopt' not specified; settings all readers to share a constant CV parameter
#> ℹ Writing specifications file to /tmp/Rtmpk1RUGZ/test.spc
data <- load_data(DataFile = data_file)
#>
#> ! There are some missing data; the effective sample size calculation may be dubious
#> Structure of the data set
#> Data set # Entries Reader boolean
#> ℹ Number of rows in NrowStruc 3 = 3
#> [1] "ReaderStruc"
#> [,1] [,2] [,3] [,4] [,5]
#> [1,] 1 3 1 0 3
#> [2,] 1 14 1 2 3
#> [3,] 1 3 1 2 0
#> 1 3 1 0 3
#> 1 14 1 2 3
#> 1 3 1 2 0
#> [1] "ReaderSumm"
#> [,1] [,2] [,3]
#> [1,] 0 0 3
#> ReaderSumm
#> 1 2 3
#> [1] "ReaderSumm"
#> [,1] [,2] [,3]
#> [1,] 1 2 3
#> Number of reads by data set: 3
#> Minimum and Maximum Ages: 5 10
#>
#> total cells 256
specs <- load_specs(SpecsFile = specs_file, DataSpecs = data)