Create an Exponential Basis
Create an exponential basis object defining a set of exponential functions with rate constants in argument ratevec.
create.exponential.basis(rangeval=c(0,1), nbasis=NULL, ratevec=NULL, dropind=NULL, quadvals=NULL, values=NULL, basisvalues=NULL, names='exp', axes=NULL)
rangeval |
a vector of length 2 containing the initial and final values of the interval over which the functional data object can be evaluated. |
nbasis |
the number of basis functions. Default = |
ratevec |
a vector of length |
dropind |
a vector of integers specifiying the basis functions to be dropped, if any. For example, if it is required that a function be zero at the left boundary, this is achieved by dropping the first basis function, the only one that is nonzero at that point. |
quadvals |
a matrix with two columns and a number of rows equal to the number
of quadrature points for numerical evaluation of the penalty
integral. The first column of |
values |
a list of matrices with one row for each row of |
basisvalues |
A list of lists, allocated by code such as vector("list",1). This
field is designed to avoid evaluation of a basis system repeatedly
at a set of argument values. Each list within the vector
corresponds to a specific set of argument values, and must have at
least two components, which may be tagged as you wish. 'The first
component in an element of the list vector contains the argument
values. The second component in an element of the list vector
contains a matrix of values of the basis functions evaluated at the
arguments in the first component. The third and subsequent
components, if present, contain matrices of values their derivatives
up to a maximum derivative order. Whenever function getbasismatrix
is called, it checks the first list in each row to see, first, if
the number of argument values corresponds to the size of the first
dimension, and if this test succeeds, checks that all of the
argument values match. This takes time, of course, but is much
faster than re-evaluation of the basis system. Even this time can
be avoided by direct retrieval of the desired array. For example,
you might set up a vector of argument values called "evalargs" along
with a matrix of basis function values for these argument values
called "basismat". You might want too use names like "args" and
"values", respectively for these. You would then assign them to
basisobj\$basisvalues <- vector("list",1) basisobj\$basisvalues[[1]] <- list(args=evalargs, values=basismat) |
names |
either a character vector of the same length as the number of basis functions or a simple stem used to construct such a vector. For |
axes |
an optional list used by selected |
Exponential functions are of the type $exp(bx)$ where $b$ is the rate constant. If $b = 0$, the constant function is defined.
a basis object with the type expon
.
# Create an exponential basis over interval [0,5] # with basis functions 1, exp(-t) and exp(-5t) basisobj <- create.exponential.basis(c(0,5),3,c(0,-1,-5)) # plot the basis plot(basisobj)
Please choose more modern alternatives, such as Google Chrome or Mozilla Firefox.