Skip to contents

Create a dataset with indices from a functional dataset in one or multiple dimensions

Usage

generate_indices(
  curves,
  k,
  bs = "cr",
  indices = c("EI", "HI", "MEI", "MHI"),
  n_cores = 1,
  ...
)

Arguments

curves

matrix with dimension \(n \times p\) in the case of a one-dimensional functional dataset, or array of dimension \(n \times p \times q\) in the case of a multivariate functional dataset. \(n\) represents the number of curves, \(p\) the number of values along the curve, and in the second case, \(q\) is the number of dimensions.

k

Number of basis functions for the B-splines. If equals to 0, the number of basis functions will be automatically selected.

bs

A two letter character string indicating the (penalized) smoothing basis to use. See smooth.terms.

indices

Set of indices to be applied to the dataset. They should be any between EI, HI, MEI and MHI.

n_cores

Number of cores to do parallel computation. 1 by default, which mean no parallel execution. Must be an integer number greater than 1.

...

Additional arguments for tfb. See tfb.

Value

A dataframe containing the indices provided in indices for original data, first and second derivatives

Examples

# 3-dimensional array
x1 <- array(c(1, 2, 3, 3, 2, 1, 5, 2, 3, 9, 8, 7, -1, -5, -6, 2, 3, 0, -1, 0, 2, -1, -2, 0),
  dim = c(3, 4, 2)
)
generate_indices(x1, k = 4)
#> Warning: Fit captures <50% of input data variability for at least one function -- consider increasing no. of basis functions 'k' or decreasing penalization.
#>       dtaEI    ddtaEI   d2dtaEI     dtaHI    ddtaHI   d2dtaHI    dtaMEI
#> 1 0.6666667 0.6666667 0.6666667 0.3333333 0.3333333 0.3333333 0.6666667
#> 2 0.6666667 0.6666667 0.6666667 0.3333333 0.3333333 0.3333333 0.5000000
#> 3 0.6666667 0.6666667 0.6666667 0.3333333 0.3333333 0.3333333 0.5833333
#>     ddtaMEI  d2dtaMEI    dtaMHI   ddtaMHI d2dtaMHI
#> 1 0.6666667 0.6666667 0.4166667 0.3333333      0.5
#> 2 0.5000000 0.5000000 0.4166667 0.5000000      0.5
#> 3 0.5000000 0.3333333 0.4166667 0.5000000      0.5

# matrix
x2 <- matrix(c(1, 2, 3, 3, 2, 1, 5, 2, 3, 9, 8, 7), nrow = 3, ncol = 4)
generate_indices(x2, k = 4)
#>       dtaEI    ddtaEI   d2dtaEI     dtaHI    ddtaHI   d2dtaHI dtaMEI   ddtaMEI
#> 1 0.6666667 0.6666667 0.3333333 0.3333333 0.3333333 0.3333333   0.50 0.3333333
#> 2 0.6666667 0.6666667 0.6666667 0.3333333 0.3333333 0.6666667   0.25 0.3333333
#> 3 0.6666667 0.6666667 0.6666667 0.3333333 0.3333333 0.3333333   0.25 0.3333333
#>    d2dtaMEI    dtaMHI   ddtaMHI  d2dtaMHI
#> 1 0.1666667 0.8333333 0.6666667 0.5000000
#> 2 0.5000000 0.5833333 0.6666667 0.8333333
#> 3 0.3333333 0.5833333 0.6666667 0.6666667

# using additional parameter for tf::tfb
curves <- sim_model_ex1(n = 10)
generate_indices(
  curves = curves,
  k = 20,
  bs = "bs",
  m = c(3,2),        # additional parameter for tfb
  penalized = FALSE  # additional parameter for tfb
)
#>    dtaEI ddtaEI d2dtaEI dtaHI ddtaHI d2dtaHI    dtaMEI   ddtaMEI  d2dtaMEI
#> 1   0.70   0.95    0.95  0.05   0.05    0.05 0.1683333 0.4483333 0.4700000
#> 2   0.65   0.95    0.95  0.05   0.05    0.05 0.1583333 0.4733333 0.4800000
#> 3   0.85   0.95    0.95  0.05   0.05    0.05 0.1833333 0.5033333 0.5266667
#> 4   0.90   0.95    0.95  0.05   0.05    0.05 0.6466667 0.4183333 0.4666667
#> 5   0.90   0.95    0.95  0.10   0.05    0.05 0.4800000 0.4950000 0.4866667
#> 6   0.85   0.95    0.95  0.05   0.05    0.05 0.2300000 0.4766667 0.4366667
#> 7   0.60   0.95    0.95  0.05   0.05    0.05 0.1350000 0.4983333 0.5133333
#> 8   0.85   0.95    0.95  0.05   0.05    0.05 0.4466667 0.4133333 0.4600000
#> 9   0.85   0.95    0.95  0.05   0.05    0.05 0.4266667 0.4783333 0.4800000
#> 10  0.90   0.95    0.95  0.05   0.05    0.05 0.4616667 0.5183333 0.4466667
#> 11  0.95   0.95    0.95  0.10   0.05    0.05 0.4833333 0.4550000 0.4666667
#> 12  0.95   0.95    0.95  0.10   0.05    0.05 0.4683333 0.4766667 0.4766667
#> 13  0.95   0.95    0.95  0.20   0.05    0.05 0.4933333 0.5066667 0.5233333
#> 14  0.95   0.95    0.95  0.35   0.05    0.05 0.8583333 0.4250000 0.4633333
#> 15  0.95   0.95    0.95  0.30   0.05    0.05 0.7466667 0.5016667 0.4833333
#> 16  0.95   0.95    0.95  0.10   0.05    0.05 0.5350000 0.4800000 0.4333333
#> 17  0.90   0.95    0.95  0.10   0.05    0.05 0.4416667 0.5050000 0.5100000
#> 18  0.95   0.95    0.95  0.35   0.05    0.05 0.7416667 0.4166667 0.4566667
#> 19  0.95   0.95    0.95  0.15   0.05    0.05 0.6633333 0.4850000 0.4766667
#> 20  0.95   0.95    0.95  0.20   0.05    0.05 0.7316667 0.5250000 0.4433333
#>       dtaMHI   ddtaMHI  d2dtaMHI
#> 1  0.2183333 0.4983333 0.5200000
#> 2  0.2083333 0.5233333 0.5300000
#> 3  0.2333333 0.5533333 0.5766667
#> 4  0.6966667 0.4683333 0.5166667
#> 5  0.5300000 0.5450000 0.5366667
#> 6  0.2800000 0.5266667 0.4866667
#> 7  0.1850000 0.5483333 0.5633333
#> 8  0.4966667 0.4633333 0.5100000
#> 9  0.4766667 0.5283333 0.5300000
#> 10 0.5116667 0.5683333 0.4966667
#> 11 0.5333333 0.5050000 0.5166667
#> 12 0.5183333 0.5266667 0.5266667
#> 13 0.5433333 0.5566667 0.5733333
#> 14 0.9083333 0.4750000 0.5133333
#> 15 0.7966667 0.5516667 0.5333333
#> 16 0.5850000 0.5300000 0.4833333
#> 17 0.4916667 0.5550000 0.5600000
#> 18 0.7916667 0.4666667 0.5066667
#> 19 0.7133333 0.5350000 0.5266667
#> 20 0.7816667 0.5750000 0.4933333