Package Kernlab': R Topics Documented
Package Kernlab': R Topics Documented
Package Kernlab': R Topics Documented
August 8, 2011
Version 0.9-13
Date 2011-08-08
Title Kernel-based Machine Learning Lab
Author Alexandros Karatzoglou, Alex Smola, Kurt Hornik
Maintainer Alexandros Karatzoglou <alexis@ci.tuwien.ac.at>
Description Kernel-based machine learning methods for classification,regression, clustering, nov-
elty detection, quantile regression and dimensionality reduction. Among other methods kernlab
includes Support Vector Machines, Spectral Clustering, Kernel PCA and a QP solver.
Depends R (>= 2.10), methods
LazyLoad Yes
License GPL-2
Repository CRAN
Date/Publication 2011-08-08 06:16:17
R topics documented:
as.kernelMatrix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
couple . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
csi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
csi-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
dots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
gausspr . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
gausspr-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
inchol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
inchol-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
income . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
inlearn . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
ipop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
ipop-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
1
2 R topics documented:
kcca . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
kcca-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
kernel-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
kernelMatrix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
kfa . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
kfa-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
kha . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
kha-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
kkmeans . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
kmmd . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
kmmd-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
kpca . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
kpca-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
kqr . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
kqr-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
ksvm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
ksvm-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
lssvm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
lssvm-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
musk . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68
onlearn . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
onlearn-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70
plot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
prc-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
predict.gausspr . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74
predict.kqr . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
predict.ksvm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
promotergene . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
ranking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
ranking-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
reuters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
rvm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
rvm-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86
sigest . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
spam . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
specc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90
specc-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 93
spirals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94
stringdot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
ticdata . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
vm-class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
Index 101
as.kernelMatrix 3
Description
as.kernelMatrix in package kernlab can be used to coerce the kernelMatrix class to matrix
objects representing a kernel matrix. These matrices can then be used with the kernelMatrix inter-
faces which most of the functions in kernlab support.
Usage
## S4 method for signature 'matrix'
as.kernelMatrix(x, center = FALSE)
Arguments
x matrix to be assigned the kernelMatrix class
center center the kernel matrix in feature space (default: FALSE)
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
kernelMatrix, dots
Examples
## Create toy data
x <- rbind(matrix(rnorm(10),,2),matrix(rnorm(10,mean=3),,2))
y <- matrix(c(rep(1,5),rep(-1,5)))
K <- as.kernelMatrix(crossprod(t(x)))
svp2
4 couple
Description
couple is used to link class-probability estimates produced by pairwise coupling in multi-class
classification problems.
Usage
couple(probin, coupler = "minpair")
Arguments
probin The pairwise coupled class-probability estimates
coupler The type of coupler to use. Currently minpar and pkpd and vote are sup-
ported (see reference for more details). If vote is selected the returned value is
a primitive estimate passed on given votes.
Details
As binary classification problems are much easier to solve many techniques exist to decompose
multi-class classification problems into many binary classification problems (voting, error codes,
etc.). Pairwise coupling (one against one) constructs a rule for discriminating between every pair
of classes and then selecting the class with the most winning two-class decisions. By using Platt’s
probabilities output for SVM one can get a class probability for each of the k(k − 1)/2 models
created in the pairwise classification. The couple method implements various techniques to combine
these probabilities.
Value
A matrix with the resulting probability estimates.
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Ting-Fan Wu, Chih-Jen Lin, ruby C. Weng
Probability Estimates for Multi-class Classification by Pairwise Coupling
Neural Information Processing Symposium 2003
http://books.nips.cc/papers/files/nips16/NIPS2003_0538.pdf
See Also
predict.ksvm, ksvm
csi 5
Examples
## create artificial pairwise probabilities
pairs <- matrix(c(0.82,0.12,0.76,0.1,0.9,0.05),2)
couple(pairs)
couple(pairs, coupler="pkpd")
Description
The csi function in kernlab is an implementation of an incomplete Cholesky decomposition algo-
rithm which exploits side information (e.g., classification labels, regression responses) to compute
a low rank decomposition of a kernel matrix from the data.
Usage
## S4 method for signature 'matrix'
csi(x, y, kernel="rbfdot", kpar=list(sigma=0.1), rank,
centering = TRUE, kappa = 0.99 ,delta = 40 ,tol = 1e-5)
Arguments
x The data matrix indexed by row
y the classification labels or regression responses. In classification y is a m × n
matrix where m the number of data and n the number of classes y and yi is 1 if
the corresponding x belongs to class i.
kernel the kernel function used in training and predicting. This parameter can be set
to any function, of class kernel, which computes the inner product in feature
space between two vector arguments. kernlab provides the most popular kernel
functions which can be used by setting the kernel parameter to the following
strings:
• rbfdot Radial Basis kernel function "Gaussian"
• polydot Polynomial kernel function
• vanilladot Linear kernel function
• tanhdot Hyperbolic tangent kernel function
• laplacedot Laplacian kernel function
• besseldot Bessel kernel function
• anovadot ANOVA RBF kernel function
• splinedot Spline kernel
• stringdot String kernel
6 csi
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains
the parameters to be used with the kernel function. Valid parameters for existing
kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well.
rank maximal rank of the computed kernel matrix
centering if TRUE centering is performed (default: TRUE)
kappa trade-off between approximation of K and prediction of Y (default: 0.99)
delta number of columns of cholesky performed in advance (default: 40)
tol minimum gain at each iteration (default: 1e-4)
Details
An incomplete cholesky decomposition calculates Z where K = ZZ ! K being the kernel matrix.
Since the rank of a kernel matrix is usually low, Z tends to be smaller then the complete kernel
matrix. The decomposed matrix can be used to create memory efficient kernel-based algorithms
without the need to compute and store a complete kernel matrix in memory.
csi uses the class labels, or regression responses to compute a more appropriate approximation for
the problem at hand considering the additional information from the response variable.
Value
An S4 object of class "csi" which is an extension of the class "matrix". The object is the decomposed
kernel matrix along with the slots :
slots can be accessed either by object@slot or by accessor functions with the same name (e.g.,
pivots(object))
csi-class 7
Author(s)
Alexandros Karatzoglou (based on Matlab code by Francis Bach)
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Francis R. Bach, Michael I. Jordan
Predictive low-rank decomposition for kernel methods.
Proceedings of the Twenty-second International Conference on Machine Learning (ICML) 2005
http://cmm.ensmp.fr/~bach/bach_jordan_csi.pdf
See Also
inchol, chol, csi-class
Examples
data(iris)
Description
The reduced Cholesky decomposition object
Slots
.Data: Object of class "matrix" contains the decomposed matrix
pivots: Object of class "vector" contains the pivots performed
diagresidues: Object of class "vector" contains the diagonial residues
maxresiduals: Object of class "vector" contains the maximum residues
predgain Object of class "vector" contains the predicted gain before adding each column
truegain Object of class "vector" contains the actual gain after adding each column
Q Object of class "matrix" contains Q from the QR decomposition of the kernel matrix
R Object of class "matrix" contains R from the QR decomposition of the kernel matrix
Extends
Class "matrix", directly.
Methods
diagresidues signature(object = "csi"): returns the diagonial residues
maxresiduals signature(object = "csi"): returns the maximum residues
pivots signature(object = "csi"): returns the pivots performed
predgain signature(object = "csi"): returns the predicted gain before adding each col-
umn
truegain signature(object = "csi"): returns the actual gain after adding each column
Q signature(object = "csi"): returns Q from the QR decomposition of the kernel ma-
trix
R signature(object = "csi"): returns R from the QR decomposition of the kernel ma-
trix
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
csi, inchol-class
Examples
data(iris)
Description
The kernel generating functions provided in kernlab.
The Gaussian RBF kernel k(x, x! ) = exp(−σ#x − x! #2 )
The Polynomial kernel k(x, x! ) = (scale < x, x! > +of f set)degree
The Linear kernel k(x, x! ) =< x, x! >
The Hyperbolic tangent kernel k(x, x! ) = tanh(scale < x, x! > +of f set)
The Laplacian kernel k(x, x! ) = exp(−σ#x − x! #)
The Bessel kernel k(x, x! ) = (−Bessel(ν+1)
n
σ#x − x! #2 )
! "D
The ANOVA RBF kernel k(x, x! ) = 1≤i1 ...<iD ≤N d=1 k(xid , x! id ) where k(x,x) is a Gaussian
RBF kernel. "D x +x min(xi ,xj )3
The Spline kernel d=1 1 + xi xj + xi xj min(xi , xj ) − i 2 j min(xi , xj )2 + 3 \ The
String kernels (see stringdot.
Usage
rbfdot(sigma = 1)
tanhdot(scale = 1, offset = 1)
vanilladot()
laplacedot(sigma = 1)
anovadot(sigma = 1, degree = 1)
splinedot()
10 dots
Arguments
sigma The inverse kernel width used by the Gaussian the Laplacian, the Bessel and the
ANOVA kernel
degree The degree of the polynomial, bessel or ANOVA kernel function. This has to be
an positive integer.
scale The scaling parameter of the polynomial and tangent kernel is a convenient way
of normalizing patterns without the need to modify the data itself
offset The offset used in a polynomial or hyperbolic tangent kernel
order The order of the Bessel function to be used as a kernel
Details
The kernel generating functions are used to initialize a kernel function which calculates the dot
(inner) product between two feature vectors in a Hilbert Space. These functions can be passed as a
kernel argument on almost all functions in kernlab(e.g., ksvm, kpca etc).
Although using one of the existing kernel functions as a kernel argument in various functions in
kernlab has the advantage that optimized code is used to calculate various kernel expressions, any
other function implementing a dot product of class kernel can also be used as a kernel argument.
This allows the user to use, test and develop special kernels for a given data set or algorithm. For
details on the string kernels see stringdot.
Value
Return an S4 object of class kernel which extents the function class. The resulting function
implements the given kernel calculating the inner (dot) product between two vectors.
Note
If the offset in the Polynomial kernel is set to $0$, we obtain homogeneous polynomial kernels, for
positive values, we have inhomogeneous kernels. Note that for negative values the kernel does not
satisfy Mercer’s condition and thus the optimizers may fail.
In the Hyperbolic tangent kernel if the offset is negative the likelihood of obtaining a kernel matrix
that is not positive definite is much higher (since then even some diagonal elements may be nega-
tive), hence if this kernel has to be used, the offset should always be positive. Note, however, that
this is no guarantee that the kernel will be positive.
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
gausspr 11
See Also
stringdot, kernelMatrix , kernelMult, kernelPol
Examples
rbfkernel <- rbfdot(sigma = 0.1)
rbfkernel
kpar(rbfkernel)
Description
gausspr is an implementation of Gaussian processes for classification and regression.
Usage
Arguments
x a symbolic description of the model to be fit or a matrix or vector when a formula
interface is not used. When not using a formula x is a matrix or vector containing
the variables in the model
data an optional data frame containing the variables in the model. By default the
variables are taken from the environment which ‘gausspr’ is called from.
12 gausspr
y a response vector with one label for each row/component of x. Can be either a
factor (for classification tasks) or a numeric vector (for regression).
type Type of problem. Either "classification" or "regression". Depending on whether
y is a factor or not, the default setting for type is classification or
regression, respectively, but can be overwritten by setting an explicit value.
subset An index vector specifying the cases to be used in the training sample. (NOTE:
If given, this argument must be named.)
na.action A function to specify the action to be taken if NAs are found. The default action
is na.omit, which leads to rejection of cases with missing values on any re-
quired variable. An alternative is na.fail, which causes an error if NA cases
are found. (NOTE: If given, this argument must be named.)
... additional parameters
Details
A Gaussian process is specified by a mean and a covariance function. The mean is a function of
x (which is often the zero function), and the covariance is a function C(x, x! ) which expresses the
expected covariance between the value of the function y at the points x and x! . The actual function
y(x) in any data modeling problem is assumed to be a single sample from this Gaussian distribution.
Laplace approximation is used for the parameter estimation in gaussian processes for classification.
The predict function can return class probabilities for classification problems by setting the type
parameter to "probabilities".
Value
An S4 object of class "gausspr" containing the fitted model along with information. Accessor
functions can be used to access the slots of the object which include :
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
C. K. I. Williams and D. Barber
Bayesian classification with Gaussian processes.
IEEE Transactions on Pattern Analysis and Machine Intelligence, 20(12):1342-1351, 1998
http://www.dai.ed.ac.uk/homes/ckiw/postscript/pami_final.ps.gz
See Also
predict.gausspr, rvm, ksvm, gausspr-class, lssvm
Examples
# train model
data(iris)
test <- gausspr(Species~.,data=iris,var=2)
test
14 gausspr-class
alpha(test)
Description
The Gaussian Processes object class
Slots
tol: Object of class "numeric" contains tolerance of termination criteria
kernelf: Object of class "kfunction" contains the kernel function used
kpar: Object of class "list" contains the kernel parameter used
kcall: Object of class "list" contains the used function call
type: Object of class "character" contains type of problem
terms: Object of class "ANY" contains the terms representation of the symbolic model used
(when using a formula)
xmatrix: Object of class "input" containing the data matrix used
ymatrix: Object of class "output" containing the response matrix
fitted: Object of class "output" containing the fitted values
lev: Object of class "vector" containing the levels of the response (in case of classification)
nclass: Object of class "numeric" containing the number of classes (in case of classification)
gausspr-class 15
Methods
alpha signature(object = "gausspr"): returns the alpha vector
cross signature(object = "gausspr"): returns the cross validation error
error signature(object = "gausspr"): returns the training error
fitted signature(object = "vm"): returns the fitted values
kcall signature(object = "gausspr"): returns the call performed
kernelf signature(object = "gausspr"): returns the kernel function used
kpar signature(object = "gausspr"): returns the kernel parameter used
lev signature(object = "gausspr"): returns the response levels (in classification)
type signature(object = "gausspr"): returns the type of problem
xmatrix signature(object = "gausspr"): returns the data matrix used
ymatrix signature(object = "gausspr"): returns the response matrix used
scaling signature(object = "gausspr"): returns the scaling coefficients of the data
(when scaled = TRUE is used)
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
gausspr, ksvm-class, vm-class
Examples
# train model
data(iris)
test <- gausspr(Species~.,data=iris,var=2)
test
alpha(test)
error(test)
lev(test)
16 inchol
Description
inchol computes the incomplete Cholesky decomposition of the kernel matrix from a data matrix.
Usage
inchol(x, kernel="rbfdot", kpar=list(sigma=0.1), tol = 0.001,
maxiter = dim(x)[1], blocksize = 50, verbose = 0)
Arguments
x The data matrix indexed by row
kernel the kernel function used in training and predicting. This parameter can be set
to any function, of class kernel, which computes the inner product in feature
space between two vector arguments. kernlab provides the most popular kernel
functions which can be used by setting the kernel parameter to the following
strings:
• rbfdot Radial Basis kernel function "Gaussian"
• polydot Polynomial kernel function
• vanilladot Linear kernel function
• tanhdot Hyperbolic tangent kernel function
• laplacedot Laplacian kernel function
• besseldot Bessel kernel function
• anovadot ANOVA RBF kernel function
• splinedot Spline kernel
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains
the parameters to be used with the kernel function. Valid parameters for existing
kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well.
tol algorithm stops when remaining pivots bring less accuracy then tol (default:
0.001)
inchol 17
Details
An incomplete cholesky decomposition calculates Z where K = ZZ ! K being the kernel matrix.
Since the rank of a kernel matrix is usually low, Z tends to be smaller then the complete kernel
matrix. The decomposed matrix can be used to create memory efficient kernel-based algorithms
without the need to compute and store a complete kernel matrix in memory.
Value
An S4 object of class "inchol" which is an extension of the class "matrix". The object is the decom-
posed kernel matrix along with the slots :
slots can be accessed either by object@slot or by accessor functions with the same name (e.g.,
pivots(object))
Author(s)
Alexandros Karatzoglou (based on Matlab code by S.V.N. (Vishy) Vishwanathan and Alex Smola)
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Francis R. Bach, Michael I. Jordan
Kernel Independent Component Analysis
Journal of Machine Learning Research 3, 1-48
http://www.jmlr.org/papers/volume3/bach02a/bach02a.pdf
See Also
csi, inchol-class, chol
Examples
data(iris)
datamatrix <- as.matrix(iris[,-5])
# initialize kernel function
rbf <- rbfdot(sigma=0.1)
rbf
Z <- inchol(datamatrix,kernel=rbf)
dim(Z)
pivots(Z)
18 inchol-class
Description
The reduced Cholesky decomposition object
Slots
.Data: Object of class "matrix" contains the decomposed matrix
pivots: Object of class "vector" contains the pivots performed
diagresidues: Object of class "vector" contains the diagonial residues
maxresiduals: Object of class "vector" contains the maximum residues
Extends
Class "matrix", directly.
Methods
diagresidues signature(object = "inchol"): returns the diagonial residues
maxresiduals signature(object = "inchol"): returns the maximum residues
pivots signature(object = "inchol"): returns the pivots performed
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
inchol, csi-class, csi
income 19
Examples
data(iris)
datamatrix <- as.matrix(iris[,-5])
# initialize kernel function
rbf <- rbfdot(sigma=0.1)
rbf
Z <- inchol(datamatrix,kernel=rbf)
dim(Z)
pivots(Z)
diagresidues(Z)
maxresiduals(Z)
Description
Customer Income Data from a marketing survey.
Usage
data(income)
Format
A data frame with 14 categorical variables (8993 observations).
Explanation of the variable names:
Details
A total of N=9409 questionnaires containing 502 questions were filled out by shopping mall cus-
tomers in the San Francisco Bay area. The dataset is an extract from this survey. It consists of 14
demographic attributes. The dataset is a mixture of nominal and ordinal variables with a lot of miss-
ing data. The goal is to predict the Anual Income of Household from the other 13 demographics
attributes.
Source
Impact Resources, Inc., Columbus, OH (1987).
Description
Online Kernel Algorithm object onlearn initialization function.
Usage
Arguments
d the dimensionality of the data to be learned
kernel the kernel function used in training and predicting. This parameter can be set to
any function, of class kernel, which computes a dot product between two vector
arguments. kernlab provides the most popular kernel functions which can be
used by setting the kernel parameter to the following strings:
• rbfdot Radial Basis kernel function "Gaussian"
• polydot Polynomial kernel function
• vanilladot Linear kernel function
• tanhdot Hyperbolic tangent kernel function
• laplacedot Laplacian kernel function
• besseldot Bessel kernel function
• anovadot ANOVA RBF kernel function
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains the
parameters to be used with the kernel function. For valid parameters for existing
kernels are :
inlearn 21
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well.
type the type of problem to be learned by the online algorithm : classification,
regression, novelty
buffersize the size of the buffer to be used
Details
The inlearn is used to initialize a blank onlearn object.
Value
The function returns an S4 object of class onlearn that can be used by the onlearn function.
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
onlearn, onlearn-class
Examples
sign(predict(on,x))
22 ipop
Description
ipop solves the quadratic programming problem :
min(c! ∗ x + 1/2 ∗ x! ∗ H ∗ x)
subject to:
b <= A ∗ x <= b + r
l <= x <= u
Usage
ipop(c, H, A, b, l, u, r, sigf = 7, maxiter = 40, margin = 0.05, bound = 10,
verb = 0)
Arguments
c Vector or one column matrix appearing in the quadratic function
H square matrix appearing in the quadratic function, or the decomposed form Z of
the H matrix where Z is a nxm matrix with n > m and ZZ ! = H.
A Matrix defining the constrains under which we minimize the quadratic function
b Vector or one column matrix defining the constrains
l Lower bound vector or one column matrix
u Upper bound vector or one column matrix
r Vector or one column matrix defining constrains
sigf Precision (default: 7 significant figures)
maxiter Maximum number of iterations
margin how close we get to the constrains
bound Clipping bound for the variables
verb Display convergence information during runtime
Details
ipop uses an interior point method to solve the quadratic programming problem.
The H matrix can also be provided in the decomposed form Z where ZZ ! = H in that case the
Sherman Morrison Woodbury formula is used internally.
Value
An S4 object with the following slots
primal Vector containing the primal solution of the quadratic problem
dual The dual solution of the problem
how Character string describing the type of convergence
all slots can be accessed through accessor functions (see example)
ipop-class 23
Author(s)
Alexandros Karatzoglou (based on Matlab code by Alex Smola)
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
R. J. Vanderbei
LOQO: An interior point code for quadratic programming
Optimization Methods and Software 11, 451-484, 1999
http://www.sor.princeton.edu/~rvdb/ps/loqo3.ps.gz
See Also
solve.QP, inchol, csi
Examples
## solve the Support Vector Machine optimization problem
data(spam)
sv <- ipop(c,H,A,b,l,u,r)
sv
dual(sv)
Description
The quadratic problem solver class
Slots
primal: Object of class "vector" the primal solution of the problem
dual: Object of class "numeric" the dual of the problem
how: Object of class "character" convergence information
Methods
primal Object of class ipopReturn the primal of the problem
dual Object of class ipopReturn the dual of the problem
how Object of class ipopReturn information on convergence
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
ipop
Examples
## solve the Support Vector Machine optimization problem
data(spam)
l <- matrix(rep(0,m))
u <- matrix(rep(C,m))
r <- 0
sv <- ipop(c,H,A,b,l,u,r)
primal(sv)
dual(sv)
how(sv)
Description
Computes the canonical correlation analysis in feature space.
Usage
## S4 method for signature 'matrix'
kcca(x, y, kernel="rbfdot", kpar=list(sigma=0.1),
gamma = 0.1, ncomps = 10, ...)
Arguments
x a matrix containing data index by row
y a matrix containing data index by row
kernel the kernel function used in training and predicting. This parameter can be set to
any function, of class kernel, which computes a inner product in feature space
between two vector arguments. kernlab provides the most popular kernel func-
tions which can be used by setting the kernel parameter to the following strings:
• rbfdot Radial Basis kernel function "Gaussian"
• polydot Polynomial kernel function
• vanilladot Linear kernel function
• tanhdot Hyperbolic tangent kernel function
• laplacedot Laplacian kernel function
• besseldot Bessel kernel function
• anovadot ANOVA RBF kernel function
• splinedot Spline kernel
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains
the parameters to be used with the kernel function. Valid parameters for existing
kernels are :
26 kcca
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well.
gamma regularization parameter (default : 0.1)
ncomps number of canonical components (default : 10)
... additional parameters for the kpca function
Details
The kernel version of canonical correlation analysis. Kernel Canonical Correlation Analysis (KCCA)
is a non-linear extension of CCA. Given two random variables, KCCA aims at extracting the infor-
mation which is shared by the two random variables. More precisely given x and y the purpose of
KCCA is to provide nonlinear mappings f (x) and g(y) such that their correlation is maximized.
Value
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
See Also
Examples
## dummy data
x <- matrix(rnorm(30),15)
y <- matrix(rnorm(30),15)
kcca(x,y,ncomps=2)
Description
Objects can be created by calls of the form new("kcca", ...). or by the calling the kcca
function.
Slots
Methods
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
kcca, kpca-class
28 kernel-class
Examples
## dummy data
x <- matrix(rnorm(30),15)
y <- matrix(rnorm(30),15)
kcca(x,y,ncomps=2)
Description
The built-in kernel classes in kernlab
Slots
.Data: Object of class "function" containing the kernel function
kpar: Object of class "list" containing the kernel parameters
Extends
Class "kernel", directly. Class "function", by class "kernel".
Methods
kernelMatrix signature(kernel = "rbfkernel", x = "matrix"): computes the
kernel matrix
kernelMult signature(kernel = "rbfkernel", x = "matrix"): computes the quadratic
kernel expression
kernelPol signature(kernel = "rbfkernel", x = "matrix"): computes the ker-
nel expansion
kernelFast signature(kernel = "rbfkernel", x = "matrix"),,a: computes parts
or the full kernel matrix, mainly used in kernel algorithms where columns of the kernel matrix
are computed per invocation
kernelMatrix 29
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
dots
Examples
Description
Usage
Arguments
kernel the kernel function to be used to calculate the kernel matrix. This has to be a
function of class kernel, i.e. which can be generated either one of the build
in kernel generating functions (e.g., rbfdot etc.) or a user defined function of
class kernel taking two vector arguments and returning a scalar.
x a data matrix to be used to calculate the kernel matrix, or a list of vector when a
stringkernel is used
y second data matrix to calculate the kernel matrix, or a list of vector when a
stringkernel is used
z a suitable vector or matrix
k a suitable vector or matrix
a the squared norm of x, e.g., rowSums(x^2)
blocksize the kernel expansion computations are done block wise to avoid storing the ker-
nel matrix into memory. blocksize defines the size of the computational
blocks.
Details
Common functions used during kernel based computations.
The kernel parameter can be set to any function, of class kernel, which computes the inner
product in feature space between two vector arguments. kernlab provides the most popular kernel
functions which can be initialized by using the following functions:
(see example.)
kernelFast is mainly used in situations where columns of the kernel matrix are computed per
invocation. In these cases, evaluating the norm of each row-entry over and over again would cause
significant computational overhead.
Value
kernelMatrix returns a symmetric diagonal semi-definite matrix.
kernelPol returns a matrix.
kernelMult usually returns a one-column matrix.
kfa 31
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
rbfdot, polydot, tanhdot, vanilladot
Examples
## use the spam data
data(spam)
dt <- as.matrix(spam[c(10:20,3000:3010),-58])
yt <- as.matrix(as.integer(spam[c(10:20,3000:3010),58]))
yt[yt==2] <- -1
Description
The Kernel Feature Analysis algorithm is an algorithm for extracting structure from possibly high-
dimensional data sets. Similar to kpca a new basis for the data is found. The data can then be
projected on the new basis.
Usage
## S4 method for signature 'formula'
kfa(x, data = NULL, na.action = na.omit, ...)
Arguments
x The data matrix indexed by row or a formula describing the model. Note, that
an intercept is always included, whether given in the formula or not.
data an optional data frame containing the variables in the model (when using a for-
mula).
kernel the kernel function used in training and predicting. This parameter can be set
to any function, of class kernel, which computes an inner product in feature
space between two vector arguments. kernlab provides the most popular kernel
functions which can be used by setting the kernel parameter to the following
strings:
• rbfdot Radial Basis kernel function "Gaussian"
• polydot Polynomial kernel function
• vanilladot Linear kernel function
• tanhdot Hyperbolic tangent kernel function
• laplacedot Laplacian kernel function
• besseldot Bessel kernel function
• anovadot ANOVA RBF kernel function
• splinedot Spline kernel
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains
the parameters to be used with the kernel function. Valid parameters for existing
kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well.
features Number of features (principal components) to return. (default: 0 , all)
subset the number of features sampled (used) from the data set
normalize normalize the feature selected (default: TRUE)
na.action A function to specify the action to be taken if NAs are found. The default action
is na.omit, which leads to rejection of cases with missing values on any re-
quired variable. An alternative is na.fail, which causes an error if NA cases
are found. (NOTE: If given, this argument must be named.)
... additional parameters
kfa-class 33
Details
Kernel Feature analysis is similar to Kernel PCA, but instead of extracting eigenvectors of the
training dataset in feature space, it approximates the eigenvectors by selecting training patterns
which are good basis vectors for the training set. It works by choosing a fixed size subset of the
data set and scaling it to unit length (under the kernel). It then chooses the features that maximize
the value of the inner product (kernel function) with the rest of the patterns.
Value
kfa returns an object of class kfa containing the features selected by the algorithm.
xmatrix contains the features selected
alpha contains the sparse alpha vector
The predict function can be used to embed new data points into to the selected feature base.
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Alex J. Smola, Olvi L. Mangasarian and Bernhard Schoelkopf
Sparse Kernel Feature Analysis
Data Mining Institute Technical Report 99-04, October 1999
ftp://ftp.cs.wisc.edu/pub/dmi/tech-reports/99-04.ps
See Also
kpca, kfa-class
Examples
data(promotergene)
f <- kfa(~.,data=promotergene,features=2,kernel="rbfdot",kpar=list(sigma=0.01))
plot(predict(f,promotergene),col=as.numeric(promotergene[,1]))
Description
The class of the object returned by the Kernel Feature Analysis kfa function
Slots
alpha: Object of class "matrix" containing the alpha values
alphaindex: Object of class "vector" containing the indexes of the selected feature
kernelf: Object of class "kfunction" containing the kernel function used
xmatrix: Object of class "matrix" containing the selected features
kcall: Object of class "call" containing the kfa function call
terms: Object of class "ANY" containing the formula terms
Methods
alpha signature(object = "kfa"): returns the alpha values
alphaindex signature(object = "kfa"): returns the index of the selected features
kcall signature(object = "kfa"): returns the function call
kernelf signature(object = "kfa"): returns the kernel function used
predict signature(object = "kfa"): used to embed more data points to the feature base
xmatrix signature(object = "kfa"): returns the selected features.
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
kfa, kpca-class
Examples
data(promotergene)
f <- kfa(~.,data=promotergene)
Description
Kernel Hebbian Algorithm is a nonlinear iterative algorithm for principal component analysis.
Usage
## S4 method for signature 'formula'
kha(x, data = NULL, na.action, ...)
Arguments
x The data matrix indexed by row or a formula describing the model. Note, that
an intercept is always included, whether given in the formula or not.
data an optional data frame containing the variables in the model (when using a for-
mula).
kernel the kernel function used in training and predicting. This parameter can be set
to any function, of class kernel, which computes the inner product in feature
space between two vector arguments (see kernels). kernlab provides the
most popular kernel functions which can be used by setting the kernel parameter
to the following strings:
• rbfdot Radial Basis kernel function "Gaussian"
• polydot Polynomial kernel function
• vanilladot Linear kernel function
• tanhdot Hyperbolic tangent kernel function
• laplacedot Laplacian kernel function
• besseldot Bessel kernel function
• anovadot ANOVA RBF kernel function
• splinedot Spline kernel
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains
the parameters to be used with the kernel function. Valid parameters for existing
kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well.
features Number of features (principal components) to return. (default: 5)
eta The hebbian learning rate (default : 0.005)
th the smallest value of the convergence step (default : 0.0001)
maxiter the maximum number of iterations.
verbose print convergence every 100 iterations. (default : FALSE)
na.action A function to specify the action to be taken if NAs are found. The default action
is na.omit, which leads to rejection of cases with missing values on any re-
quired variable. An alternative is na.fail, which causes an error if NA cases
are found. (NOTE: If given, this argument must be named.)
... additional parameters
36 kha
Details
The original form of KPCA can only be used on small data sets since it requires the estimation of
the eigenvectors of a full kernel matrix. The Kernel Hebbian Algorithm iteratively estimates the
Kernel Principal Components with only linear order memory complexity. (see ref. for more details)
Value
An S4 object containing the principal component vectors along with the corresponding normaliza-
tion values.
pcv a matrix containing the principal component vectors (column wise)
eig The normalization values
xmatrix The original data matrix
all the slots of the object can be accessed by accessor functions.
Note
The predict function can be used to embed new data on the new space
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Kwang In Kim, M.O. Franz and B. Schölkopf
Kernel Hebbian Algorithm for Iterative Kernel Principal Component Analysis
Max-Planck-Institut für biologische Kybernetik, Tübingen (109)
http://www.kyb.tuebingen.mpg.de/publications/pdfs/pdf2302.pdf
See Also
kpca, kfa, kcca, pca
Examples
# another example using the iris
data(iris)
test <- sample(1:150,20)
Description
The Kernel Hebbian Algorithm class
Slots
pcv: Object of class "matrix" containing the principal component vectors
eig: Object of class "vector" containing the corresponding normalization values
eskm: Object of class "vector" containing the kernel sum
kernelf: Object of class "kfunction" containing the kernel function used
kpar: Object of class "list" containing the kernel parameters used
xmatrix: Object of class "matrix" containing the data matrix used
kcall: Object of class "ANY" containing the function call
n.action: Object of class "ANY" containing the action performed on NA
Methods
eig signature(object = "kha"): returns the normalization values
kcall signature(object = "kha"): returns the performed call
kernelf signature(object = "kha"): returns the used kernel function
pcv signature(object = "kha"): returns the principal component vectors
eskm signature(object = "kha"): returns the kernel sum
predict signature(object = "kha"): embeds new data
xmatrix signature(object = "kha"): returns the used data matrix
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
kha, ksvm-class, kcca-class
38 kkmeans
Examples
# another example using the iris
data(iris)
test <- sample(1:50,20)
Description
A weighted kernel version of the famous k-means algorithm.
Usage
Arguments
x the matrix of data to be clustered, or a symbolic description of the model to be
fit, or a kernel Matrix of class kernelMatrix, or a list of character vectors.
data an optional data frame containing the variables in the model. By default the
variables are taken from the environment which ‘kkmeans’ is called from.
centers Either the number of clusters or a matrix of initial cluster centers. If the first a
random initial partitioning is used.
kkmeans 39
kernel the kernel function used in training and predicting. This parameter can be set to
any function, of class kernel, which computes a inner product in feature space
between two vector arguments (see link{kernels}). kernlab provides the
most popular kernel functions which can be used by setting the kernel parameter
to the following strings:
• rbfdot Radial Basis kernel "Gaussian"
• polydot Polynomial kernel
• vanilladot Linear kernel
• tanhdot Hyperbolic tangent kernel
• laplacedot Laplacian kernel
• besseldot Bessel kernel
• anovadot ANOVA RBF kernel
• splinedot Spline kernel
• stringdot String kernel
Setting the kernel parameter to "matrix" treats x as a kernel matrix calling the
kernelMatrix interface.
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar a character string or the list of hyper-parameters (kernel parameters). The de-
fault character string "automatic" uses a heuristic the determine a suitable
value for the width parameter of the RBF kernel.
A list can also be used containing the parameters to be used with the kernel
function. Valid parameters for existing kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
• length, lambda, normalized for the "stringdot" kernel where length
is the length of the strings considered, lambda the decay factor and normal-
ized a logical parameter determining if the kernel evaluations should be
normalized.
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well.
alg the algorithm to use. Options currently include kkmeans and kerninghan.
p a parameter used to keep the affinity matrix positive semidefinite
na.action The action to perform on NA
... additional parameters
40 kkmeans
Details
kernel k-means uses the ’kernel trick’ (i.e. implicitly projecting all data into a non-linear fea-
ture space with the use of a kernel) in order to deal with one of the major drawbacks of k-means
that is that it cannot capture clusters that are not linearly separable in input space.
The algorithm is implemented using the triangle inequality to avoid unnecessary and computational
expensive distance calculations. This leads to significant speedup particularly on large data sets
with a high number of clusters.
With a particular choice of weights this algorithm becomes equivalent to Kernighan-Lin, and the
norm-cut graph partitioning algorithms.
The function also support input in the form of a kernel matrix or a list of characters for text cluster-
ing.
The data can be passed to the kkmeans function in a matrix or a data.frame, in addition
kkmeans also supports input in the form of a kernel matrix of class kernelMatrix or as a list
of character vectors where a string kernel has to be used.
Value
An S4 object of class specc which extends the class vector containing integers indicating the
cluster to which each point is allocated. The following slots contain useful information
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Inderjit Dhillon, Yuqiang Guan, Brian Kulis
A Unified view of Kernel k-means, Spectral Clustering and Graph Partitioning
UTCS Technical Report
http://www.cs.utexas.edu/users/kulis/pubs/spectral_techreport.pdf
See Also
specc, kpca, kcca
Examples
## Cluster the iris data set.
data(iris)
sc
kmmd 41
centers(sc)
size(sc)
withinss(sc)
Description
The Kernel Maximum Mean Discrepancy kmmd performs a non-parametric distribution test.
Usage
Arguments
x data values, in a matrix, list, or kernelMatrix
y data values, in a matrix, list, or kernelMatrix
Kxy kernlMatrix between x and y values (only for the kernelMatrix interface)
kernel the kernel function used in training and predicting. This parameter can be set to
any function, of class kernel, which computes a dot product between two vector
arguments. kernlab provides the most popular kernel functions which can be
used by setting the kernel parameter to the following strings:
• rbfdot Radial Basis kernel function "Gaussian"
• polydot Polynomial kernel function
• vanilladot Linear kernel function
• tanhdot Hyperbolic tangent kernel function
• laplacedot Laplacian kernel function
• besseldot Bessel kernel function
• anovadot ANOVA RBF kernel function
• splinedot Spline kernel
• stringdot String kernel
42 kmmd
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains
the parameters to be used with the kernel function. Valid parameters for existing
kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
• lenght, lambda, normalized for the "stringdot" kernel where length
is the length of the strings considered, lambda the decay factor and normal-
ized a logical parameter determining if the kernel evaluations should be
normalized.
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well. In the case of a Radial Basis kernel function (Gaussian) kpar
can also be set to the string "automatic" which uses the heuristics in ’sigest’ to
calculate a good ’sigma’ value for the Gaussian RBF or Laplace kernel, from
the data. (default = "automatic").
alpha the confidence level of the test (default: 0.05)
asymptotic calculate the bounds asymptotically (suitable for smaller datasets) (default: FALSE)
replace use replace when sampling for computing the asymptotic bounds (default : TRUE)
ntimes number of times repeating the sampling procedure (default : 150)
frac fraction of points to sample (frac : 1)
... additional parameters.
Details
kmmd calculates the kernel maximum mean discrepancy for samples from two distributions and
conducts a test as to whether the samples are from different distributions with level alpha.
Value
An S4 object of class kmmd containing the results of whether the H0 hypothesis is rejected or
not. H0 being that the samples x and y come from the same distribution. The object contains the
following slots :
H0 is H0 rejected (logical)
AsympH0 is H0 rejected according to the asymptotic bound (logical)
kernelf the kernel function used.
mmdstats the test statistics (vector of two)
Radbound the Rademacher bound
Asymbound the asymptotic bound
see kmmd-class for more details.
kmmd-class 43
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Gretton, A., K. Borgwardt, M. Rasch, B. Schoelkopf and A. Smola
A Kernel Method for the Two-Sample-Problem
Neural Information Processing Systems 2006, Vancouver
http://www.kyb.mpg.de/publications/attachments/mmd_final_4193[1].pdf
See Also
ksvm
Examples
# create data
x <- matrix(runif(300),100)
y <- matrix(runif(300)+1,100)
mmdo
Description
The Kernel Maximum Mean Discrepancy object class
Slots
kernelf: Object of class "kfunction" contains the kernel function used
xmatrix: Object of class "kernelMatrix" containing the data used
H0 Object of class "logical" contains value of : is H0 rejected (logical)
AsympH0 Object of class "logical" contains value : is H0 rejected according to the asymptotic
bound (logical)
mmdstats Object of class "vector" contains the test statistics (vector of two)
Radbound Object of class "numeric" contains the Rademacher bound
Asymbound Object of class "numeric" contains the asymptotic bound
44 kpca
Methods
kernelf signature(object = "kmmd"): returns the kernel function used
H0 signature(object = "kmmd"): returns the value of H0 being rejected
AsympH0 signature(object = "kmmd"): returns the value of H0 being rejected accord-
ing to the asymptotic bound
mmdstats signature(object = "kmmd"): returns the values of the mmd statistics
Radbound signature(object = "kmmd"): returns the value of the Rademacher bound
Asymbound signature(object = "kmmd"): returns the value of the asymptotic bound
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
kmmd,
Examples
# create data
x <- matrix(runif(300),100)
y <- matrix(runif(300)+1,100)
H0(mmdo)
Description
Kernel Principal Components Analysis is a nonlinear form of principal component analysis.
Usage
## S4 method for signature 'formula'
kpca(x, data = NULL, na.action, ...)
Arguments
x the data matrix indexed by row or a formula describing the model, or a kernel
Matrix of class kernelMatrix, or a list of character vectors
data an optional data frame containing the variables in the model (when using a for-
mula).
kernel the kernel function used in training and predicting. This parameter can be set to
any function, of class kernel, which computes a dot product between two vector
arguments. kernlab provides the most popular kernel functions which can be
used by setting the kernel parameter to the following strings:
• rbfdot Radial Basis kernel function "Gaussian"
• polydot Polynomial kernel function
• vanilladot Linear kernel function
• tanhdot Hyperbolic tangent kernel function
• laplacedot Laplacian kernel function
• besseldot Bessel kernel function
• anovadot ANOVA RBF kernel function
• splinedot Spline kernel
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains
the parameters to be used with the kernel function. Valid parameters for existing
kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well.
features Number of features (principal components) to return. (default: 0 , all)
th the value of the eigenvalue under which principal components are ignored (only
valid when features = 0). (default : 0.0001)
na.action A function to specify the action to be taken if NAs are found. The default action
is na.omit, which leads to rejection of cases with missing values on any re-
quired variable. An alternative is na.fail, which causes an error if NA cases
are found. (NOTE: If given, this argument must be named.)
... additional parameters
46 kpca
Details
Using kernel functions one can efficiently compute principal components in high-dimensional fea-
ture spaces, related to input space by some non-linear map.
The data can be passed to the kpca function in a matrix or a data.frame, in addition kpca
also supports input in the form of a kernel matrix of class kernelMatrix or as a list of character
vectors where a string kernel has to be used.
Value
An S4 object containing the principal component vectors along with the corresponding eigenvalues.
Note
The predict function can be used to embed new data on the new space
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Schoelkopf B., A. Smola, K.-R. Mueller :
Nonlinear component analysis as a kernel eigenvalue problem
Neural Computation 10, 1299-1319
http://mlg.anu.edu.au/~smola/papers/SchSmoMul98.pdf
See Also
kcca, pca
Examples
# another example using the iris
data(iris)
test <- sample(1:150,20)
Description
The Kernel Principal Components Analysis class
Slots
pcv: Object of class "matrix" containing the principal component vectors
eig: Object of class "vector" containing the corresponding eigenvalues
rotated: Object of class "matrix" containing the projection of the data on the principal com-
ponents
kernelf: Object of class "function" containing the kernel function used
kpar: Object of class "list" containing the kernel parameters used
xmatrix: Object of class "matrix" containing the data matrix used
kcall: Object of class "ANY" containing the function call
n.action: Object of class "ANY" containing the action performed on NA
Methods
eig signature(object = "kpca"): returns the eigenvalues
kcall signature(object = "kpca"): returns the performed call
kernelf signature(object = "kpca"): returns the used kernel function
pcv signature(object = "kpca"): returns the principal component vectors
predict signature(object = "kpca"): embeds new data
rotated signature(object = "kpca"): returns the projected data
xmatrix signature(object = "kpca"): returns the used data matrix
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
48 kqr
See Also
ksvm-class, kcca-class
Examples
# another example using the iris
data(iris)
test <- sample(1:50,20)
Description
The Kernel Quantile Regression algorithm kqr performs non-parametric Quantile Regression.
Usage
## S4 method for signature 'formula'
kqr(x, data=NULL, ..., subset, na.action = na.omit, scaled = TRUE)
Arguments
x e data or a symbolic description of the model to be fit. When not using a formula
x can be a matrix or vector containing the training data or a kernel matrix of class
kernelMatrix of the training data or a list of character vectors (for use with
kqr 49
the string kernel). Note, that the intercept is always excluded, whether given in
the formula or not.
data an optional data frame containing the variables in the model. By default the
variables are taken from the environment which kqr is called from.
y a numeric vector or a column matrix containing the response.
scaled A logical vector indicating the variables to be scaled. If scaled is of length 1,
the value is recycled as many times as needed and all non-binary variables are
scaled. Per default, data are scaled internally (both x and y variables) to zero
mean and unit variance. The center and scale values are returned and used for
later predictions. (default: TRUE)
tau the quantile to be estimated, this is generally a number strictly between 0 and 1.
For 0.5 the median is calculated. (default: 0.5)
C the cost regularization parameter. This parameter controls the smoothness of
the fitted function, essentially higher values for C lead to less smooth func-
tions.(default: 1)
kernel the kernel function used in training and predicting. This parameter can be set to
any function, of class kernel, which computes a dot product between two vector
arguments. kernlab provides the most popular kernel functions which can be
used by setting the kernel parameter to the following strings:
• rbfdot Radial Basis kernel function "Gaussian"
• polydot Polynomial kernel function
• vanilladot Linear kernel function
• tanhdot Hyperbolic tangent kernel function
• laplacedot Laplacian kernel function
• besseldot Bessel kernel function
• anovadot ANOVA RBF kernel function
• splinedot Spline kernel
• stringdot String kernel
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains
the parameters to be used with the kernel function. Valid parameters for existing
kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
• lenght, lambda, normalized for the "stringdot" kernel where length
is the length of the strings considered, lambda the decay factor and normal-
ized a logical parameter determining if the kernel evaluations should be
normalized.
50 kqr
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well. In the case of a Radial Basis kernel function (Gaussian) kpar
can also be set to the string "automatic" which uses the heuristics in ’sigest’ to
calculate a good ’sigma’ value for the Gaussian RBF or Laplace kernel, from
the data. (default = "automatic").
reduced use an incomplete cholesky decomposition to calculate a decomposed form Z
of the kernel Matrix K (where K = ZZ ! ) and perform the calculations with Z.
This might be useful when using kqr with large datasets since normally an n
times n kernel matrix would be computed. Setting reduced to TRUE makes
use of csi to compute a decomposed form instead and thus only a n×m matrix
where m < n and n the sample size is stored in memory (default: FALSE)
rank the rank m of the decomposed matrix calculated when using an incomplete
cholesky decomposition. This parameter is only taken into account when reduced
is TRUE(default : dim(x)[1]/6)
fit indicates whether the fitted values should be computed and included in the
model or not (default: ’TRUE’)
cross if a integer value k>0 is specified, a k-fold cross validation on the training data is
performed to assess the quality of the model: the Pinball loss and the for quantile
regression
subset An index vector specifying the cases to be used in the training sample. (NOTE:
If given, this argument must be named.)
na.action A function to specify the action to be taken if NAs are found. The default action
is na.omit, which leads to rejection of cases with missing values on any re-
quired variable. An alternative is na.fail, which causes an error if NA cases
are found. (NOTE: If given, this argument must be named.)
... additional parameters.
Details
In quantile regression a function is fitted to the data so that it satisfies the property that a portion
tau of the data y|n is below the estimate. While the error bars of many regression problems can
be viewed as such estimates quantile regression estimates this quantity directly. Kernel quantile
regression is similar to nu-Support Vector Regression in that it minimizes a regularized loss function
in RKHS. The difference between nu-SVR and kernel quantile regression is in the type of loss
function used which in the case of quantile regression is the pinball loss (see reference for details.).
Minimizing the regularized loss boils down to a quadratic problem which is solved using an interior
point QP solver ipop implemented in kernlab.
Value
An S4 object of class kqr containing the fitted model along with information.Accessor functions
can be used to access the slots of the object which include :
alpha The resulting model parameters which can be also accessed by coef.
kernelf the kernel function used.
error Training error (if fit == TRUE)
see kqr-class for more details.
kqr-class 51
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Ichiro Takeuchi, Quoc V. Le, Timothy D. Sears, Alexander J. Smola
Nonparametric Quantile Estimation
Journal of Machine Learning Research 7,2006,1231-1264
http://www.jmlr.org/papers/volume7/takeuchi06a/takeuchi06a.pdf
See Also
predict.kqr, kqr-class, ipop, rvm, ksvm
Examples
# create data
x <- sort(runif(300))
y <- sin(pi*x) + rnorm(300,0,sd=exp(sin(2*pi*x)))
Description
The Kernel Quantile Regression object class
52 kqr-class
Slots
kernelf: Object of class "kfunction" contains the kernel function used
kpar: Object of class "list" contains the kernel parameter used
coef: Object of class "ANY" containing the model parameters
param: Object of class "list" contains the cost parameter C and tau parameter used
kcall: Object of class "list" contains the used function call
terms: Object of class "ANY" contains the terms representation of the symbolic model used
(when using a formula)
xmatrix: Object of class "input" containing the data matrix used
ymatrix: Object of class "output" containing the response matrix
fitted: Object of class "output" containing the fitted values
alpha: Object of class "listI" containing the computes alpha values
b: Object of class "numeric" containing the offset of the model.
scaling Object of class "ANY" containing the scaling coefficients of the data (when case scaled
= TRUE is used).
error: Object of class "numeric" containing the training error
cross: Object of class "numeric" containing the cross validation error
n.action: Object of class "ANY" containing the action performed in NA
nclass: Inherited from class vm, not used in kqr
lev: Inherited from class vm, not used in kqr
type: Inherited from class vm, not used in kqr
Methods
coef signature(object = "kqr"): returns the coefficients (alpha) of the model
alpha signature(object = "kqr"): returns the alpha vector (identical to coef)
b signature(object = "kqr"): returns the offset beta of the model.
cross signature(object = "kqr"): returns the cross validation error
error signature(object = "kqr"): returns the training error
fitted signature(object = "vm"): returns the fitted values
kcall signature(object = "kqr"): returns the call performed
kernelf signature(object = "kqr"): returns the kernel function used
kpar signature(object = "kqr"): returns the kernel parameter used
param signature(object = "kqr"): returns the cost regularization parameter C and tau
used
xmatrix signature(object = "kqr"): returns the data matrix used
ymatrix signature(object = "kqr"): returns the response matrix used
scaling signature(object = "kqr"): returns the scaling coefficients of the data (when
scaled = TRUE is used)
ksvm 53
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
Examples
# create data
x <- sort(runif(300))
y <- sin(pi*x) + rnorm(300,0,sd=exp(sin(2*pi*x)))
Description
Support Vector Machines are an excellent tool for classification, novelty detection, and regres-
sion. ksvm supports the well known C-svc, nu-svc, (classification) one-class-svc (novelty) eps-svr,
nu-svr (regression) formulations along with native multi-class classification formulations and the
bound-constraint SVM formulations.
ksvm also supports class-probabilities output and confidence intervals for regression.
54 ksvm
Usage
## S4 method for signature 'formula'
ksvm(x, data = NULL, ..., subset, na.action = na.omit, scaled = TRUE)
Arguments
x a symbolic description of the model to be fit. When not using a formula x can
be a matrix or vector containing the training data or a kernel matrix of class
kernelMatrix of the training data or a list of character vectors (for use with
the string kernel). Note, that the intercept is always excluded, whether given in
the formula or not.
data an optional data frame containing the training data, when using a formula. By
default the data is taken from the environment which ‘ksvm’ is called from.
y a response vector with one label for each row/component of x. Can be either a
factor (for classification tasks) or a numeric vector (for regression).
scaled A logical vector indicating the variables to be scaled. If scaled is of length 1,
the value is recycled as many times as needed and all non-binary variables are
scaled. Per default, data are scaled internally (both x and y variables) to zero
mean and unit variance. The center and scale values are returned and used for
later predictions.
type ksvm can be used for classification , for regression, or for novelty detection.
Depending on whether y is a factor or not, the default setting for type is C-
svc or eps-svr, respectively, but can be overwritten by setting an explicit
value.
Valid options are:
ksvm 55
• C-svc C classification
• nu-svc nu classification
• C-bsvc bound-constraint svm classification
• spoc-svc Crammer, Singer native multi-class
• kbb-svc Weston, Watkins native multi-class
• one-svc novelty detection
• eps-svr epsilon regression
• nu-svr nu regression
• eps-bsvr bound-constraint svm regression
kernel the kernel function used in training and predicting. This parameter can be set to
any function, of class kernel, which computes the inner product in feature space
between two vector arguments (see kernels).
kernlab provides the most popular kernel functions which can be used by setting
the kernel parameter to the following strings:
• rbfdot Radial Basis kernel "Gaussian"
• polydot Polynomial kernel
• vanilladot Linear kernel
• tanhdot Hyperbolic tangent kernel
• laplacedot Laplacian kernel
• besseldot Bessel kernel
• anovadot ANOVA RBF kernel
• splinedot Spline kernel
• stringdot String kernel
Setting the kernel parameter to "matrix" treats x as a kernel matrix calling the
kernelMatrix interface.
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains the
parameters to be used with the kernel function. For valid parameters for existing
kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
• length, lambda, normalized for the "stringdot" kernel where length
is the length of the strings considered, lambda the decay factor and normal-
ized a logical parameter determining if the kernel evaluations should be
normalized.
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well. In the case of a Radial Basis kernel function (Gaussian) kpar
56 ksvm
can also be set to the string "automatic" which uses the heuristics in sigest
to calculate a good sigma value for the Gaussian RBF or Laplace kernel, from
the data. (default = "automatic").
C cost of constraints violation (default: 1) this is the ‘C’-constant of the regular-
ization term in the Lagrange formulation.
nu parameter needed for nu-svc, one-svc, and nu-svr. The nu parameter
sets the upper bound on the training error and the lower bound on the fraction of
data points to become Support Vectors (default: 0.2).
epsilon epsilon in the insensitive-loss function used for eps-svr, nu-svr and eps-
bsvm (default: 0.1)
prob.model if set to TRUE builds a model for calculating class probabilities or in case of re-
gression, calculates the scaling parameter of the Laplacian distribution fitted on
the residuals. Fitting is done on output data created by performing a 3-fold cross-
validation on the training data. For details see references. (default: FALSE)
class.weights
a named vector of weights for the different classes, used for asymmetric class
sizes. Not all factor levels have to be supplied (default weight: 1). All compo-
nents have to be named.
cache cache memory in MB (default 40)
tol tolerance of termination criterion (default: 0.001)
shrinking option whether to use the shrinking-heuristics (default: TRUE)
cross if a integer value k>0 is specified, a k-fold cross validation on the training data is
performed to assess the quality of the model: the accuracy rate for classification
and the Mean Squared Error for regression
fit indicates whether the fitted values should be computed and included in the
model or not (default: TRUE)
... additional parameters for the low level fitting function
subset An index vector specifying the cases to be used in the training sample. (NOTE:
If given, this argument must be named.)
na.action A function to specify the action to be taken if NAs are found. The default action
is na.omit, which leads to rejection of cases with missing values on any re-
quired variable. An alternative is na.fail, which causes an error if NA cases
are found. (NOTE: If given, this argument must be named.)
Details
ksvm uses John Platt’s SMO algorithm for solving the SVM QP problem an most SVM formula-
tions. On the spoc-svc, kbb-svc, C-bsvc and eps-bsvr formulations a chunking algorithm
based on the TRON QP solver is used.
For multiclass-classification with k classes, k > 2, ksvm uses the ‘one-against-one’-approach, in
which k(k − 1)/2 binary classifiers are trained; the appropriate class is found by a voting scheme,
The spoc-svc and the kbb-svc formulations deal with the multiclass-classification problems
by solving a single quadratic problem involving all the classes.
If the predictor variables include factors, the formula interface must be used to get a correct model
matrix.
ksvm 57
In classification when prob.model is TRUE a 3-fold cross validation is performed on the data
and a sigmoid function is fitted on the resulting decision values f . The data can be passed to the
ksvm function in a matrix or a data.frame, in addition ksvm also supports input in the form
of a kernel matrix of class kernelMatrix or as a list of character vectors where a string kernel
has to be used.
The plot function for binary classification ksvm objects displays a contour plot of the decision
values with the corresponding support vectors highlighted.
The predict function can return class probabilities for classification problems by setting the type
parameter to "probabilities".
The problem of model selection is partially addressed by an empirical observation for the RBF
kernels (Gaussian , Laplace) where the optimal values of the sigma width parameter are shown to
lie in between the 0.1 and 0.9 quantile of the #x − x! # statistics. When using an RBF kernel and
setting kpar to "automatic", ksvm uses the sigest function to estimate the quantiles and uses
the median of the values.
Value
An S4 object of class "ksvm" containing the fitted model, Accessor functions can be used to access
the slots of the object (see examples) which include:
Note
Author(s)
Alexandros Karatzoglou (SMO optimizers in C++ by Chih-Chung Chang & Chih-Jen Lin)
<alexandros.karatzoglou@ci.tuwien.ac.at>
58 ksvm
References
• Chang Chih-Chung, Lin Chih-Jen
LIBSVM: a library for Support Vector Machines
http://www.csie.ntu.edu.tw/~cjlin/libsvm
• Chih-Wei Hsu, Chih-Jen Lin
BSVM http://www.csie.ntu.edu.tw/~cjlin/bsvm/
• J. Platt
Probabilistic outputs for support vector machines and comparison to regularized likelihood
methods
Advances in Large Margin Classifiers, A. Smola, P. Bartlett, B. Schoelkopf and D. Schuur-
mans, Eds. Cambridge, MA: MIT Press, 2000.
http://citeseer.nj.nec.com/platt99probabilistic.html
• H.-T. Lin, C.-J. Lin and R. C. Weng
A note on Platt’s probabilistic outputs for support vector machines
http://www.csie.ntu.edu.tw/~cjlin/papers/plattprob.ps
• C.-W. Hsu and C.-J. Lin
A comparison on methods for multi-class support vector machines
IEEE Transactions on Neural Networks, 13(2002) 415-425.
http://www.csie.ntu.edu.tw/~cjlin/papers/multisvm.ps.gz
• K. Crammer, Y. Singer
On the learnability and design of output codes for multiclass prolems
Computational Learning Theory, 35-46, 2000.
http://www.cs.huji.ac.il/~kobics/publications/mlj01.ps.gz
• J. Weston, C. Watkins
Multi-class support vector machines
In M. Verleysen, Proceedings of ESANN99 Brussels, 1999
http://citeseer.ist.psu.edu/8884.html
See Also
predict.ksvm, ksvm-class, couple
Examples
## Check results
table(mailtype,spamtest[,58])
irismodel
svp2
data(promotergene)
gene
60 ksvm-class
## regression
# create data
x <- seq(-20,20,0.1)
y <- sin(x)/x + rnorm(401,sd=0.03)
Description
An S4 class containing the output (model) of the ksvm Support Vector Machines function
Slots
type: Object of class "character" containing the support vector machine type ("C-svc", "nu-
svc", "C-bsvc", "spoc-svc", "one-svc", "eps-svr", "nu-svr", "eps-bsvr")
param: Object of class "list" containing the Support Vector Machine parameters (C, nu, ep-
silon)
kernelf: Object of class "function" containing the kernel function
kpar: Object of class "list" containing the kernel function parameters (hyperparameters)
kcall: Object of class "ANY" containing the ksvm function call
scaling: Object of class "ANY" containing the scaling information performed on the data
terms: Object of class "ANY" containing the terms representation of the symbolic model used
(when using a formula)
xmatrix: Object of class "input" ("list" for multiclass problems or "matrix" for binary
classification and regression problems) containing the support vectors calculated from the
data matrix used during computations (possibly scaled and without NA). In the case of multi-
class classification each list entry contains the support vectors from each binary classification
problem from the one-against-one method.
ksvm-class 61
Methods
SVindex signature(object = "ksvm"): return the indexes of support vectors
alpha signature(object = "ksvm"): returns the complete 5 alpha vector (wit zero val-
ues)
alphaindex signature(object = "ksvm"): returns the indexes of non-zero alphas (sup-
port vectors)
cross signature(object = "ksvm"): returns the cross-validation error
error signature(object = "ksvm"): returns the training error
obj signature(object = "ksvm"): returns the value of the objective function
fitted signature(object = "vm"): returns the fitted values (predict on training set)
kernelf signature(object = "ksvm"): returns the kernel function
kpar signature(object = "ksvm"): returns the kernel parameters (hyperparameters)
lev signature(object = "ksvm"): returns the levels in case of classification
prob.model signature(object="ksvm"): returns class prob. model values
param signature(object="ksvm"): returns the parameters of the SVM in a list (C, ep-
silon, nu etc.)
prior signature(object="ksvm"): returns the prior of the training set
kcall signature(object="ksvm"): returns the ksvm function call
62 lssvm
Author(s)
Alexandros Karatzoglou
<alexandros.karatzolgou@ci.tuwien.ac.at>
See Also
ksvm, rvm-class, gausspr-class
Examples
## simple example using the promotergene data set
data(promotergene)
Description
The lssvm function is an implementation of the Least Squares SVM. lssvm includes a reduced
version of Least Squares SVM using a decomposition of the kernel matrix which is calculated by
the csi function.
lssvm 63
Usage
Arguments
x a symbolic description of the model to be fit, a matrix or vector containing the
training data when a formula interface is not used or a kernelMatrix or a
list of character vectors.
data an optional data frame containing the variables in the model. By default the
variables are taken from the environment which ‘lssvm’ is called from.
y a response vector with one label for each row/component of x. Can be either a
factor (for classification tasks) or a numeric vector (for classification or regres-
sion - currently nor supported -).
scaled A logical vector indicating the variables to be scaled. If scaled is of length 1,
the value is recycled as many times as needed and all non-binary variables are
scaled. Per default, data are scaled internally to zero mean and unit variance.
The center and scale values are returned and used for later predictions.
type Type of problem. Either "classification" or "regression". Depending on whether
y is a factor or not, the default setting for type is "classification" or "regression"
respectively, but can be overwritten by setting an explicit value. (regression is
currently not supported)
kernel the kernel function used in training and predicting. This parameter can be set to
any function, of class kernel, which computes a dot product between two vector
arguments. kernlab provides the most popular kernel functions which can be
used by setting the kernel parameter to the following strings:
64 lssvm
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains the
parameters to be used with the kernel function. For valid parameters for existing
kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
• length, lambda, normalized for the "stringdot" kernel where length
is the length of the strings considered, lambda the decay factor and normal-
ized a logical parameter determining if the kernel evaluations should be
normalized.
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well.
kpar can also be set to the string "automatic" which uses the heuristics in
sigest to calculate a good sigma value for the Gaussian RBF or Laplace
kernel, from the data. (default = "automatic").
tau the regularization parameter (default 0.01)
reduced if set to FALSE the full linear problem of the lssvm is solved, when TRUE a
reduced method using csi is used.
rank the maximal rank of the decomposed kernel matrix, see csi
delta number of columns of cholesky performed in advance, see csi (default 40)
tol tolerance of termination criterion for the csi function, lower tolerance leads to
more precise approximation but may increase the training time and the decom-
posed matrix size (default: 0.0001)
fit indicates whether the fitted values should be computed and included in the
model or not (default: ’TRUE’)
lssvm 65
cross if a integer value k>0 is specified, a k-fold cross validation on the training data
is performed to assess the quality of the model: the Mean Squared Error for
regression
subset An index vector specifying the cases to be used in the training sample. (NOTE:
If given, this argument must be named.)
na.action A function to specify the action to be taken if NAs are found. The default action
is na.omit, which leads to rejection of cases with missing values on any re-
quired variable. An alternative is na.fail, which causes an error if NA cases
are found. (NOTE: If given, this argument must be named.)
... additional parameters
Details
Least Squares Support Vector Machines are reformulation to the standard SVMs that lead to solv-
ing linear KKT systems. The algorithm is based on the minimization of a classical penalized least-
squares cost function. The current implementation approximates the kernel matrix by an incomplete
Cholesky factorization obtained by the csi function, thus the solution is an approximation to the
exact solution of the lssvm optimization problem. The quality of the solution depends on the ap-
proximation and can be influenced by the "rank" , "delta", and "tol" parameters.
Value
An S4 object of class "lssvm" containing the fitted model, Accessor functions can be used to
access the slots of the object (see examples) which include:
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
See Also
Examples
## simple example
data(iris)
lir
lirr
klir
Description
The Gaussian Processes object
Slots
kernelf: Object of class "kfunction" contains the kernel function used
kpar: Object of class "list" contains the kernel parameter used
param: Object of class "list" contains the regularization parameter used.
kcall: Object of class "call" contains the used function call
type: Object of class "character" contains type of problem
coef: Object of class "ANY" contains the model parameter
lssvm-class 67
terms: Object of class "ANY" contains the terms representation of the symbolic model used
(when using a formula)
xmatrix: Object of class "matrix" containing the data matrix used
ymatrix: Object of class "output" containing the response matrix
fitted: Object of class "output" containing the fitted values
b: Object of class "numeric" containing the offset
lev: Object of class "vector" containing the levels of the response (in case of classification)
scaling: Object of class "ANY" containing the scaling information performed on the data
nclass: Object of class "numeric" containing the number of classes (in case of classification)
alpha: Object of class "listI" containing the computes alpha values
alphaindex Object of class "list" containing the indexes for the alphas in various classes (in
multi-class problems).
error: Object of class "numeric" containing the training error
cross: Object of class "numeric" containing the cross validation error
n.action: Object of class "ANY" containing the action performed in NA
nSV: Object of class "numeric" containing the number of model parameters
Methods
alpha signature(object = "lssvm"): returns the alpha vector
cross signature(object = "lssvm"): returns the cross validation error
error signature(object = "lssvm"): returns the training error
fitted signature(object = "vm"): returns the fitted values
kcall signature(object = "lssvm"): returns the call performed
kernelf signature(object = "lssvm"): returns the kernel function used
kpar signature(object = "lssvm"): returns the kernel parameter used
param signature(object = "lssvm"): returns the regularization parameter used
lev signature(object = "lssvm"): returns the response levels (in classification)
type signature(object = "lssvm"): returns the type of problem
scaling signature(object = "ksvm"): returns the scaling values
xmatrix signature(object = "lssvm"): returns the data matrix used
ymatrix signature(object = "lssvm"): returns the response matrix used
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
lssvm, ksvm-class
68 musk
Examples
# train model
data(iris)
test <- lssvm(Species~.,data=iris,var=2)
test
alpha(test)
error(test)
lev(test)
Description
This dataset describes a set of 92 molecules of which 47 are judged by human experts to be musks
and the remaining 45 molecules are judged to be non-musks.
Usage
data(musk)
Format
Source
Examples
data(musk)
muskm
Description
Online Kernel-based Learning algorithms for classification, novelty detection, and regression.
Usage
## S4 method for signature 'onlearn'
onlearn(obj, x, y = NULL, nu = 0.2, lambda = 1e-04)
Arguments
obj obj an object of class onlearn created by the initialization function inlearn
containing the kernel to be used during learning and the parameters of the learned
model
x vector or matrix containing the data. Factors have to be numerically coded. If x
is a matrix the code is run internally one sample at the time.
y the class label in case of classification. Only binary classification is supported
and class labels have to be -1 or +1.
nu the parameter similarly to the nu parameter in SVM bounds the training error.
lambda the learning rate
Details
The online algorithms are based on a simple stochastic gradient descent method in feature space.
The state of the algorithm is stored in an object of class onlearn and has to be passed to the
function at each iteration.
Value
The function returns an S4 object of class onlearn containing the model parameters and the last
fitted value which can be retrieved by the accessor method fit. The value returned in the clas-
sification and novelty detection problem is the decision function value phi. The accessor methods
alpha returns the model parameters.
70 onlearn-class
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Kivinen J. Smola A.J. Williamson R.C.
Online Learning with Kernels
IEEE Transactions on Signal Processing vol. 52, Issue 8, 2004
http://mlg.anu.edu.au/~smola/papers/KivSmoWil03.pdf
See Also
inlearn
Examples
sign(predict(on,x))
Description
The class of objects used by the Kernel-based Online learning algorithms
Slots
kernelf: Object of class "function" containing the used kernel function
buffer: Object of class "numeric" containing the size of the buffer
kpar: Object of class "list" containing the hyperparameters of the kernel function.
xmatrix: Object of class "matrix" containing the data points (similar to support vectors)
fit: Object of class "numeric" containing the decision function value of the last data point
onstart: Object of class "numeric" used for indexing
onstop: Object of class "numeric" used for indexing
alpha: Object of class "ANY" containing the model parameters
rho: Object of class "numeric" containing model parameter
b: Object of class "numeric" containing the offset
pattern: Object of class "factor" used for dealing with factors
type: Object of class "character" containing the problem type (classification, regression, or
novelty
Methods
alpha signature(object = "onlearn"): returns the model parameters
b signature(object = "onlearn"): returns the offset
buffer signature(object = "onlearn"): returns the buffer size
fit signature(object = "onlearn"): returns the last decision function value
kernelf signature(object = "onlearn"): return the kernel function used
kpar signature(object = "onlearn"): returns the hyper-parameters used
onlearn signature(obj = "onlearn"): the learning function
predict signature(object = "onlearn"): the predict function
rho signature(object = "onlearn"): returns model parameter
show signature(object = "onlearn"): show function
type signature(object = "onlearn"): returns the type of problem
xmatrix signature(object = "onlearn"): returns the stored data points
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
onlearn, inlearn
72 plot
Examples
sign(predict(on,x))
Description
Plot a binary classification support vector machine object. The plot function returns a contour
plot of the decision values.
Usage
## S4 method for signature 'ksvm'
plot(object, data=NULL, grid = 50, slice = list())
Arguments
object a ksvm classification object created by the ksvm function
data a data frame or matrix containing data to be plotted
grid granularity for the contour plot.
slice a list of named numeric values for the dimensions held constant (only needed if
more than two variables are used). Dimensions not specified are fixed at 0.
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
ksvm
prc-class 73
Examples
## Demo of the plot function
x <- rbind(matrix(rnorm(120),,2),matrix(rnorm(120,mean=3),,2))
y <- matrix(c(rep(1,60),rep(-1,60)))
Description
Principal Components Class
Slots
pcv: Object of class "matrix" containing the principal component vectors
eig: Object of class "vector" containing the corresponding eigenvalues
kernelf: Object of class "kfunction" containing the kernel function used
kpar: Object of class "list" containing the kernel parameters used
xmatrix: Object of class "input" containing the data matrix used
kcall: Object of class "ANY" containing the function call
n.action: Object of class "ANY" containing the action performed on NA
Methods
eig signature(object = "prc"): returns the eigenvalues
kcall signature(object = "prc"): returns the performed call
kernelf signature(object = "prc"): returns the used kernel function
pcv signature(object = "prc"): returns the principal component vectors
predict signature(object = "prc"): embeds new data
xmatrix signature(object = "prc"): returns the used data matrix
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
kpca-class,kha-class, kfa-class
74 predict.gausspr
Description
Prediction of test data using Gaussian Processes
Usage
## S4 method for signature 'gausspr'
predict(object, newdata, type = "response", coupler = "minpair")
Arguments
object an S4 object of class gausspr created by the gausspr function
newdata a data frame or matrix containing new data
type one of response, probabilities indicating the type of output: predicted
values or matrix of class probabilities
coupler Coupling method used in the multiclass case, can be one of minpair or pkpd
(see reference for more details).
Value
response predicted classes (the classes with majority vote) or the response value in regres-
sion.
probabilities
matrix of class probabilities (one column for each class and one row for each
input).
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
• C. K. I. Williams and D. Barber
Bayesian classification with Gaussian processes.
IEEE Transactions on Pattern Analysis and Machine Intelligence, 20(12):1342-1351, 1998
http://www.dai.ed.ac.uk/homes/ckiw/postscript/pami_final.ps.gz
• T.F. Wu, C.J. Lin, R.C. Weng.
Probability estimates for Multi-class Classification by Pairwise Coupling
http://www.csie.ntu.edu.tw/~cjlin/papers/svmprob/svmprob.pdf
predict.kqr 75
Examples
Description
Usage
Arguments
Value
The value of the quantile given by the computed kqr model in a vector of length equal to the the
rows of newdata.
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
76 predict.ksvm
Examples
# create data
x <- sort(runif(300))
y <- sin(pi*x) + rnorm(300,0,sd=exp(sin(2*pi*x)))
Description
Prediction of test data using support vector machines
Usage
## S4 method for signature 'ksvm'
predict(object, newdata, type = "response", coupler = "minpair")
Arguments
object an S4 object of class ksvm created by the ksvm function
newdata a data frame or matrix containing new data
type one of response, probabilities ,votes, decision indicating the
type of output: predicted values, matrix of class probabilities, matrix of vote
counts, or matrix of decision values.
coupler Coupling method used in the multiclass case, can be one of minpair or pkpd
(see reference for more details).
Value
If type(object) is C-svc, nu-svc, C-bsvm or spoc-svc the vector returned depends on
the argument type:
probabilities
matrix of class probabilities (one column for each class and one row for each
input).
votes matrix of vote counts (one column for each class and one row for each new
input)
If type(object) is eps-svr, eps-bsvr or nu-svr a vector of predicted values is returned.
If type(object) is one-classification a vector of logical values is returned.
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
• T.F. Wu, C.J. Lin, R.C. Weng.
Probability estimates for Multi-class Classification by Pairwise Coupling
http://www.csie.ntu.edu.tw/~cjlin/papers/svmprob/svmprob.pdf
• H.T. Lin, C.J. Lin, R.C. Weng
A note on Platt’s probabilistic outputs for support vector machines
http://www.csie.ntu.edu.tw/~cjlin/papers/plattprob.ps
Examples
Description
Promoters have a region where a protein (RNA polymerase) must make contact and the helical DNA
sequence must have a valid conformation so that the two pieces of the contact region spatially align.
The data contains DNA sequences of promoters and non-promoters.
78 ranking
Usage
data(promotergene)
Format
A data frame with 106 observations and 58 variables. The first variable Class is a factor with levels
+ for a promoter gene and - for a non-promoter gene. The remaining 57 variables V2 to V58
are factors describing the sequence. The DNA bases are coded as follows: a adenine c cytosine g
guanine t thymine
Source
References
Examples
data(promotergene)
ranking Ranking
Description
A universal ranking algorithm which assigns importance/ranking to data points given a query.
ranking 79
Usage
## S4 method for signature 'matrix'
ranking(x, y, kernel ="rbfdot", kpar = list(sigma = 1),
scale = FALSE, alpha = 0.99, iterations = 600,
edgegraph = FALSE, convergence = FALSE ,...)
Arguments
x a matrix containing the data to be ranked, or the kernel matrix of data to be
ranked or a list of character vectors
y The index of the query point in the data matrix or a vector of length equal to the
rows of the data matrix having a one at the index of the query points index and
zero at all the other points.
kernel the kernel function used in training and predicting. This parameter can be set to
any function, of class kernel, which computes a dot product between two vector
arguments. kernlab provides the most popular kernel functions which can be
used by setting the kernel parameter to the following strings:
• rbfdot Radial Basis kernel function "Gaussian"
• polydot Polynomial kernel function
• vanilladot Linear kernel function
• tanhdot Hyperbolic tangent kernel function
• laplacedot Laplacian kernel function
• besseldot Bessel kernel function
• anovadot ANOVA RBF kernel function
• splinedot Spline kernel
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar the list of hyper-parameters (kernel parameters). This is a list which contains the
parameters to be used with the kernel function. For valid parameters for existing
kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
80 ranking
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well.
scale If TRUE the data matrix columns are scaled to zero mean and unit variance.
alpha The alpha parameter takes values between 0 and 1 and is used to control the
authoritative scores received from the unlabeled points. For 0 no global structure
is found the algorithm ranks the points similarly to the original distance metric.
iterations Maximum number of iterations
edgegraph Construct edgegraph (only supported with the RBF kernel)
convergence Include convergence matrix in results
... Additional arguments
Details
A simple universal ranking algorithm which exploits the intrinsic global geometric structure of the
data. In many real world applications this should be superior to a local method in which the data
are simply ranked by pairwise Euclidean distances. Firstly a weighted network is defined on the
data and an authoritative score is assigned to each query. The query points act as source nodes
that continually pump their authoritative scores to the remaining points via the weighted network
and the remaining points further spread the scores they received to their neighbors. This spreading
process is repeated until convergence and the points are ranked according to their score at the end
of the iterations.
Value
An S4 object of class ranking which extends the matrix class. The first column of the returned
matrix contains the original index of the points in the data matrix the second column contains the
final score received by each point and the third column the ranking of the point. The object contains
the following slots :
edgegraph Containing the edgegraph of the data points.
convergence Containing the convergence matrix
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
D. Zhou, J. Weston, A. Gretton, O. Bousquet, B. Schoelkopf
Ranking on Data Manifolds
Advances in Neural Information Processing Systems 16.
MIT Press Cambridge Mass. 2004
http://www.kyb.mpg.de/publications/pdfs/pdf2334.pdf
See Also
ranking-class, specc
ranking-class 81
Examples
data(spirals)
Description
Object of the class "ranking" are created from the ranking function and extend the class
matrix
Slots
.Data: Object of class "matrix" containing the data ranking and scores
convergence: Object of class "matrix" containing the convergence matrix
edgegraph: Object of class "matrix" containing the edgegraph
Extends
Class "matrix", directly.
Methods
show signature(object = "ranking"): displays the ranking score matrix
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
82 reuters
See Also
ranking
Examples
data(spirals)
ranked
edgegraph(ranked)[1:10,1:10]
Description
Usage
data(reuters)
Format
A list of 40 text documents along with the labels. reuters contains the text documents and
rlabels the labels in a vector.
Details
This dataset contains a list of 40 text documents along with the labels. The data consist out of 20
documents from the acq category and 20 documents from the crude category. The labels are stored
in rlabels
Source
Reuters
rvm 83
Description
The Relevance Vector Machine is a Bayesian model for regression and classification of identical
functional form to the support vector machine. The rvm function currently supports only regression.
Usage
## S4 method for signature 'formula'
rvm(x, data=NULL, ..., subset, na.action = na.omit)
Arguments
x a symbolic description of the model to be fit. When not using a formula x can
be a matrix or vector containing the training data or a kernel matrix of class
kernelMatrix of the training data or a list of character vectors (for use with
the string kernel). Note, that the intercept is always excluded, whether given in
the formula or not.
data an optional data frame containing the variables in the model. By default the
variables are taken from the environment which ‘rvm’ is called from.
y a response vector with one label for each row/component of x. Can be either a
factor (for classification tasks) or a numeric vector (for regression).
type rvm can only be used for regression at the moment.
kernel the kernel function used in training and predicting. This parameter can be set to
any function, of class kernel, which computes a dot product between two vector
arguments. kernlab provides the most popular kernel functions which can be
used by setting the kernel parameter to the following strings:
• rbfdot Radial Basis kernel "Gaussian"
84 rvm
subset An index vector specifying the cases to be used in the training sample. (NOTE:
If given, this argument must be named.)
na.action A function to specify the action to be taken if NAs are found. The default action
is na.omit, which leads to rejection of cases with missing values on any re-
quired variable. An alternative is na.fail, which causes an error if NA cases
are found. (NOTE: If given, this argument must be named.)
... additional parameters
Details
The Relevance Vector Machine typically leads to sparser models then the SVM. It also performs
better in many cases (specially in regression).
Value
An S4 object of class "rvm" containing the fitted model. Accessor functions can be used to access
the slots of the object which include :
...
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Tipping, M. E.
Sparse Bayesian learning and the relevance vector machine
Journal of Machine Learning Research 1, 211-244
http://www.jmlr.org/papers/volume1/tipping01a/tipping01a.pdf
See Also
ksvm
Examples
# create data
x <- seq(-20,20,0.1)
y <- sin(x)/x + rnorm(401,sd=0.05)
Description
Relevance Vector Machine Class
Slots
tol: Object of class "numeric" contains tolerance of termination criteria used.
kernelf: Object of class "kfunction" contains the kernel function used
kpar: Object of class "list" contains the hyperparameter used
kcall: Object of class "call" contains the function call
type: Object of class "character" contains type of problem
terms: Object of class "ANY" containing the terms representation of the symbolic model used
(when using a formula interface)
xmatrix: Object of class "matrix" contains the data matrix used during computation
ymatrix: Object of class "output" contains the response matrix
fitted: Object of class "output" with the fitted values, (predict on training set).
lev: Object of class "vector" contains the levels of the response (in classification)
nclass: Object of class "numeric" contains the number of classes (in classification)
alpha: Object of class "listI" containing the the resulting alpha vector
coef: Object of class "ANY" containing the the resulting model parameters
nvar: Object of class "numeric" containing the calculated variance (in case of regression)
mlike: Object of class "numeric" containing the computed maximum likelihood
RVindex: Object of class "vector" containing the indexes of the resulting relevance vectors
nRV: Object of class "numeric" containing the number of relevance vectors
cross: Object of class "numeric" containing the resulting cross validation error
error: Object of class "numeric" containing the training error
n.action: Object of class "ANY" containing the action performed on NA
rvm-class 87
Methods
RVindex signature(object = "rvm"): returns the index of the relevance vectors
alpha signature(object = "rvm"): returns the resulting alpha vector
cross signature(object = "rvm"): returns the resulting cross validation error
error signature(object = "rvm"): returns the training error
fitted signature(object = "vm"): returns the fitted values
kcall signature(object = "rvm"): returns the function call
kernelf signature(object = "rvm"): returns the used kernel function
kpar signature(object = "rvm"): returns the parameters of the kernel function
lev signature(object = "rvm"): returns the levels of the response (in classification)
mlike signature(object = "rvm"): returns the estimated maximum likelihood
nvar signature(object = "rvm"): returns the calculated variance (in regression)
type signature(object = "rvm"): returns the type of problem
xmatrix signature(object = "rvm"): returns the data matrix used during computation
ymatrix signature(object = "rvm"): returns the used response
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
rvm, ksvm-class
Examples
# create data
x <- seq(-20,20,0.1)
y <- sin(x)/x + rnorm(401,sd=0.05)
alpha(foo)
RVindex(foo)
fitted(foo)
kernelf(foo)
nvar(foo)
## show slots
slotNames(foo)
88 sigest
Description
Given a range of values for the "sigma" inverse width parameter in the Gaussian Radial Basis kernel
for use with Support Vector Machines. The estimation is based on the data to be used.
Usage
Arguments
x a symbolic description of the model upon the estimation is based. When not
using a formula x is a matrix or vector containing the data
data an optional data frame containing the variables in the model. By default the
variables are taken from the environment which ‘ksvm’ is called from.
frac Fraction of data to use for estimation. By default a quarter of the data is used to
estimate the range of the sigma hyperparameter.
scaled A logical vector indicating the variables to be scaled. If scaled is of length
1, the value is recycled as many times as needed and all non-binary variables
are scaled. Per default, data are scaled internally to zero mean and unit variance
(since this the default action in ksvm as well). The center and scale values are
returned and used for later predictions.
na.action A function to specify the action to be taken if NAs are found. The default action
is na.omit, which leads to rejection of cases with missing values on any re-
quired variable. An alternative is na.fail, which causes an error if NA cases
are found. (NOTE: If given, this argument must be named.)
Details
sigest estimates the range of values for the sigma parameter which would return good results
when used with a Support Vector Machine (ksvm). The estimation is based upon the 0.1 and 0.9
quantile of #x − x! #2 . Basically any value in between those two bounds will produce good results.
Value
Returns a vector of length 3 defining the range (0.1 quantile, median and 0.9 quantile) of the sigma
hyperparameter.
spam 89
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
B. Caputo, K. Sim, F. Furesjo, A. Smola,
Appearance-based object recognition using SVMs: which kernel should I use?
Proc of NIPS workshop on Statitsical methods for computational experiments in visual processing
and computer vision, Whistler, 2002.
See Also
ksvm
Examples
s <- srange[2]
s
## create test and training set
ind <- sample(1:dim(promotergene)[1],20)
genetrain <- promotergene[-ind, ]
genetest <- promotergene[ind, ]
## Check results
table(promoter,genetest[,1])
Description
A data set collected at Hewlett-Packard Labs, that classifies 4601 e-mails as spam or non-spam.
In addition to this class label there are 57 variables indicating the frequency of certain words and
characters in the e-mail.
90 specc
Usage
data(spam)
Format
A data frame with 4601 observations and 58 variables.
The first 48 variables contain the frequency of the variable name (e.g., business) in the e-mail. If
the variable name starts with num (e.g., num650) the it indicates the frequency of the corresponding
number (e.g., 650). The variables 49-54 indicate the frequency of the characters ‘;’, ‘(’, ‘[’, ‘!’, ‘\$’,
and ‘\#’. The variables 55-57 contain the average, longest and total run-length of capital letters.
Variable 58 indicates the type of the mail and is either "nonspam" or "spam", i.e. unsolicited
commercial e-mail.
Details
The data set contains 2788 e-mails classified as "nonspam" and 1813 classified as "spam".
The “spam” concept is diverse: advertisements for products/web sites, make money fast schemes,
chain letters, pornography... This collection of spam e-mails came from the collectors’ postmaster
and individuals who had filed spam. The collection of non-spam e-mails came from filed work and
personal e-mails, and hence the word ’george’ and the area code ’650’ are indicators of non-spam.
These are useful when constructing a personalized spam filter. One would either have to blind such
non-spam indicators or get a very wide collection of non-spam to generate a general purpose spam
filter.
Source
• Creators: Mark Hopkins, Erik Reeber, George Forman, Jaap Suermondt at Hewlett-Packard
Labs, 1501 Page Mill Rd., Palo Alto, CA 94304
• Donor: George Forman (gforman at nospam hpl.hp.com) 650-857-7835
These data have been taken from the UCI Repository Of Machine Learning Databases at http:
//www.ics.uci.edu/~mlearn/MLRepository.html
References
T. Hastie, R. Tibshirani, J.H. Friedman. The Elements of Statistical Learning. Springer, 2001.
Description
A spectral clustering algorithm. Clustering is performed by embedding the data into the subspace
of the eigenvectors of an affinity matrix.
specc 91
Usage
## S4 method for signature 'formula'
specc(x, data = NULL, na.action = na.omit, ...)
Arguments
x the matrix of data to be clustered, or a symbolic description of the model to be
fit, or a kernel Matrix of class kernelMatrix, or a list of character vectors.
data an optional data frame containing the variables in the model. By default the
variables are taken from the environment which ‘specc’ is called from.
centers Either the number of clusters or a set of initial cluster centers. If the first, a
random set of rows in the eigenvectors matrix are chosen as the initial centers.
kernel the kernel function used in computing the affinity matrix. This parameter can be
set to any function, of class kernel, which computes a dot product between two
vector arguments. kernlab provides the most popular kernel functions which can
be used by setting the kernel parameter to the following strings:
• rbfdot Radial Basis kernel function "Gaussian"
• polydot Polynomial kernel function
• vanilladot Linear kernel function
• tanhdot Hyperbolic tangent kernel function
• laplacedot Laplacian kernel function
• besseldot Bessel kernel function
• anovadot ANOVA RBF kernel function
• splinedot Spline kernel
• stringdot String kernel
The kernel parameter can also be set to a user defined function of class kernel
by passing the function name as an argument.
kpar a character string or the list of hyper-parameters (kernel parameters). The de-
fault character string "automatic" uses a heuristic to determine a suitable
value for the width parameter of the RBF kernel. The second option "local"
(local scaling) uses a more advanced heuristic and sets a width parameter for
every point in the data set. This is particularly useful when the data incorporates
92 specc
multiple scales. A list can also be used containing the parameters to be used
with the kernel function. Valid parameters for existing kernels are :
• sigma inverse kernel width for the Radial Basis kernel function "rbfdot"
and the Laplacian kernel "laplacedot".
• degree, scale, offset for the Polynomial kernel "polydot"
• scale, offset for the Hyperbolic tangent kernel function "tanhdot"
• sigma, order, degree for the Bessel kernel "besseldot".
• sigma, degree for the ANOVA kernel "anovadot".
• length, lambda, normalized for the "stringdot" kernel where length
is the length of the strings considered, lambda the decay factor and normal-
ized a logical parameter determining if the kernel evaluations should be
normalized.
Hyper-parameters for user defined kernels can be passed through the kpar pa-
rameter as well.
nystrom.red use nystrom method to calculate eigenvectors. When TRUE a sample of the
dataset is used to calculate the eigenvalues, thus only a nxm matrix where n the
sample size is stored in memory (default: FALSE
nystrom.sample
number of data points to use for estimating the eigenvalues when using the nys-
trom method. (default : dim(x)[1]/6)
mod.sample proportion of data to use when estimating sigma (default: 0.75)
iterations the maximum number of iterations allowed.
na.action the action to perform on NA
... additional parameters
Details
Spectral clustering works by embedding the data points of the partitioning problem into the sub-
space of the k largest eigenvectors of a normalized affinity/kernel matrix. Using a simple clustering
method like kmeans on the embedded points usually leads to good performance. It can be shown
that spectral clustering methods boil down to graph partitioning.
The data can be passed to the specc function in a matrix or a data.frame, in addition specc
also supports input in the form of a kernel matrix of class kernelMatrix or as a list of character
vectors where a string kernel has to be used.
Value
An S4 object of class specc which extends the class vector containing integers indicating the
cluster to which each point is allocated. The following slots contain useful information
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
References
Andrew Y. Ng, Michael I. Jordan, Yair Weiss
On Spectral Clustering: Analysis and an Algorithm
Neural Information Processing Symposium 2001
http://www.nips.cc/NIPS2001/papers/psgz/AA35.ps.gz
See Also
kkmeans, kpca, kcca
Examples
## Cluster the spirals data set.
data(spirals)
sc
centers(sc)
size(sc)
withinss(sc)
plot(spirals, col=sc)
Description
The Spectral Clustering Class
Slots
.Data: Object of class "vector" containing the cluster assignments
centers: Object of class "matrix" containing the cluster centers
size: Object of class "vector" containing the number of points in each cluster
94 spirals
withinss: Object of class "vector" containing the within-cluster sum of squares for each
cluster
kernelf Object of class kernel containing the used kernel function.
Methods
centers signature(object = "specc"): returns the cluster centers
withinss signature(object = "specc"): returns the within-cluster sum of squares for
each cluster
size signature(object = "specc"): returns the number of points in each cluster
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
specc, kpca-class
Examples
## Cluster the spirals data set.
data(spirals)
centers(sc)
size(sc)
Description
A toy data set representing two spirals with Gaussian noise. The data was created with the mlbench.spirals
function in mlbench.
Usage
data(spirals)
Format
A matrix with 300 observations and 2 variables.
Examples
data(spirals)
plot(spirals)
stringdot 95
Description
String kernels.
Usage
stringdot(length = 4, lambda = 1.1, type = "spectrum", normalized = TRUE)
Arguments
length The length of the substrings considered
lambda The decay factor
type Type of string kernel, currently the following kernels are supported :
constant The kernel considers all matching substrings and assigns constant
weight (e.g. 1) to each of them. This constant kernel does not require any
additional parameter.
Details
The kernel generating functions are used to initialize a kernel function which calculates the dot
(inner) product between two feature vectors in a Hilbert Space. These functions or their function
generating names can be passed as a kernel argument on almost all functions in kernlab(e.g.,
ksvm, kpca etc.).
96 ticdata
The string kernels calculate similarities between two strings (e.g. texts or sequences) by matching
the common substring in the strings. Different types of string kernel exists and are mainly distin-
guished by how the matching is performed i.e. some string kernels count the exact matchings of n
characters (spectrum kernel) between the strings, others allow gaps (mismatch kernel) etc.
Value
Returns an S4 object of class stringkernel which extents the function class. The resulting
function implements the given kernel calculating the inner (dot) product between two character
vectors.
kpar a list containing the kernel parameters (hyperparameters) used.
The kernel parameters can be accessed by the kpar function.
Note
The spectrum and boundrange kernel are faster and more efficient implementations of the
string and fullstring kernels which will be still included in kernlab for the next two
versions.
Author(s)
Alexandros Karatzoglou
<alexandros.karatzoglou@ci.tuwien.ac.at>
See Also
dots , kernelMatrix , kernelMult, kernelPol
Examples
sk
Description
This data set used in the CoIL 2000 Challenge contains information on customers of an insurance
company. The data consists of 86 variables and includes product usage data and socio-demographic
data derived from zip area codes. The data was collected to answer the following question: Can you
predict who would be interested in buying a caravan insurance policy and give an explanation why
?
ticdata 97
Usage
data(ticdata)
Format
ticdata: Dataset to train and validate prediction models and build a description (9822 customer
records). Each record consists of 86 attributes, containing sociodemographic data (attribute 1-43)
and product ownership (attributes 44-86). The sociodemographic data is derived from zip codes.
All customers living in areas with the same zip code have the same sociodemographic attributes.
Attribute 86, CARAVAN:Number of mobile home policies, is the target variable.
Data Format
Note: All the variables starting with M are zipcode variables. They give information on the distri-
bution of that variable, e.g., Rented house, in the zipcode area of the customer.
Details
Information about the insurance company customers consists of 86 variables and includes product
usage data and socio-demographic data derived from zip area codes. The data was supplied by
the Dutch data mining company Sentient Machine Research and is based on a real world business
problem. The training set contains over 5000 descriptions of customers, including the information
of whether or not they have a caravan insurance policy. The test set contains 4000 customers. The
test and data set are merged in the ticdata set. More information about the data set and the CoIL
2000 Challenge along with publications based on the data set can be found at http://www.
liacs.nl/~putten/library/cc2000/.
Source
• UCI KDD Archive:http://kdd.ics.uci.edu
• Donor: Sentient Machine Research
Peter van der Putten
Sentient Machine Research
Baarsjesweg 224
1058 AA Amsterdam
The Netherlands
+31 20 6186927
pvdputten@hotmail.com, putten@liacs.nl
References
Peter van der Putten, Michel de Ruiter, Maarten van Someren CoIL Challenge 2000 Tasks and
Results: Predicting and Explaining Caravan Policy Ownership
http://www.liacs.nl/~putten/library/cc2000/
Description
An S4 VIRTUAL class used as a base for the various vector machine classes in kernlab
Slots
alpha: Object of class "listI" containing the resulting alpha vector (list in case of multiclass
classification) (support vectors)
type: Object of class "character" containing the vector machine type e.g., ("C-svc", "nu-
svc", "C-bsvc", "spoc-svc", "one-svc", "eps-svr", "nu-svr", "eps-bsvr")
kernelf: Object of class "function" containing the kernel function
kpar: Object of class "list" containing the kernel function parameters (hyperparameters)
kcall: Object of class "call" containing the function call
terms: Object of class "ANY" containing the terms representation of the symbolic model used
(when using a formula)
xmatrix: Object of class "input" the data matrix used during computations (support vectors)
(possibly scaled and without NA)
ymatrix: Object of class "output" the response matrix/vector
fitted: Object of class "output" with the fitted values, predictions using the training set.
lev: Object of class "vector" with the levels of the response (in the case of classification)
nclass: Object of class "numeric" containing the number of classes (in the case of classifica-
tion)
error: Object of class "vector" containing the training error
cross: Object of class "vector" containing the cross-validation error
n.action: Object of class "ANY" containing the action performed for NA
Methods
alpha signature(object = "vm"): returns the complete alpha vector (wit zero values)
cross signature(object = "vm"): returns the cross-validation error
error signature(object = "vm"): returns the training error
fitted signature(object = "vm"): returns the fitted values (predict on training set)
kernelf signature(object = "vm"): returns the kernel function
kpar signature(object = "vm"): returns the kernel parameters (hyperparameters)
lev signature(object = "vm"): returns the levels in case of classification
kcall signature(object="vm"): returns the function call
type signature(object = "vm"): returns the problem type
xmatrix signature(object = "vm"): returns the data matrix used(support vectors)
ymatrix signature(object = "vm"): returns the response vector
Author(s)
Alexandros Karatzoglou
<alexandros.karatzolgou@ci.tuwien.ac.at>
See Also
ksvm-class, rvm-class, gausspr-class
Index
101
102 INDEX
kqr, 48 alphaindex,lssvm-method
ksvm, 53 (lssvm-class), 66
lssvm, 62 anovadot (dots), 9
rvm, 83 anovakernel-class (kernel-class),
∗Topic nonparametric 28
kmmd, 41 as.kernelMatrix, 3
∗Topic optimize as.kernelMatrix,matrix-method
ipop, 22 (as.kernelMatrix), 3
∗Topic regression as.kernelMatrix-methods
gausspr, 11 (as.kernelMatrix), 3
inlearn, 20 Asymbound (kmmd), 41
kqr, 48 Asymbound,kmmd-method
ksvm, 53 (kmmd-class), 43
onlearn, 69 AsympH0 (kmmd), 41
plot, 72 AsympH0,kmmd-method (kmmd-class),
predict.gausspr, 74 43
predict.kqr, 75
predict.ksvm, 76 b (ksvm-class), 60
b,kqr-method (kqr-class), 51
rvm, 83
b,ksvm-method (ksvm-class), 60
sigest, 88
b,lssvm-method (lssvm-class), 66
∗Topic symbolmath
b,onlearn-method (onlearn-class),
dots, 9
70
stringdot, 95
besseldot (dots), 9
∗Topic ts
besselkernel-class
inlearn, 20
(kernel-class), 28
onlearn, 69
buffer (onlearn-class), 70
buffer,onlearn-method
alpha (vm-class), 99 (onlearn-class), 70
alpha,gausspr-method
(gausspr-class), 14 cancor, 26
alpha,kfa-method (kfa-class), 33 centers (specc-class), 93
alpha,kqr-method (kqr-class), 51 centers,specc-method
alpha,ksvm-method (ksvm-class), 60 (specc-class), 93
alpha,lssvm-method (lssvm-class), chol, 7, 17
66 coef,gausspr-method (gausspr), 11
alpha,onlearn-method coef,kfa-method (kfa), 31
(onlearn-class), 70 coef,kqr-method (kqr), 48
alpha,rvm-method (rvm-class), 86 coef,ksvm-method (ksvm), 53
alpha,vm-method (vm-class), 99 coef,lssvm-method (lssvm), 62
alphaindex (ksvm-class), 60 coef,rvm-method (rvm), 83
alphaindex,gausspr-method coef,vm-method (ksvm-class), 60
(gausspr-class), 14 convergence (ranking-class), 81
alphaindex,kfa-method convergence,ranking-method
(kfa-class), 33 (ranking-class), 81
alphaindex,kqr-method couple, 4, 58
(kqr-class), 51 cross (vm-class), 99
alphaindex,ksvm-method cross,gausspr-method
(ksvm-class), 60 (gausspr-class), 14
INDEX 103
kernelPol,polykernel-method 66
(kernelMatrix), 29 kpar,onlearn-method
kernelPol,rbfkernel-method (onlearn-class), 70
(kernelMatrix), 29 kpar,rvm-method (rvm-class), 86
kernelPol,splinekernel-method kpar,vm-method (vm-class), 99
(kernelMatrix), 29 kpca, 26, 33, 36, 40, 44, 93
kernelPol,stringkernel-method kpca,formula-method (kpca), 44
(kernelMatrix), 29 kpca,kernelMatrix-method (kpca),
kernelPol,tanhkernel-method 44
(kernelMatrix), 29 kpca,list-method (kpca), 44
kernelPol,vanillakernel-method kpca,matrix-method (kpca), 44
(kernelMatrix), 29 kpca-class, 27, 34, 73, 94
kernels, 35, 55 kpca-class, 47
kernels (dots), 9 kqr, 48, 53
kfa, 26, 31, 34, 36 kqr,formula-method (kqr), 48
kfa,formula-method (kfa), 31 kqr,kernelMatrix-method (kqr), 48
kfa,matrix-method (kfa), 31 kqr,list-method (kqr), 48
kfa-class, 33, 73 kqr,matrix-method (kqr), 48
kfa-class, 33 kqr,vector-method (kqr), 48
kfunction (dots), 9 kqr-class, 51
kfunction-class (kernel-class), 28 kqr-class, 51
kha, 26, 34, 37 ksvm, 4, 13, 51, 53, 62, 65, 72, 85, 89
kha,formula-method (kha), 34 ksvm,formula-method (ksvm), 53
kha,matrix-method (kha), 34 ksvm,kernelMatrix-method (ksvm),
53
kha-class, 73
ksvm,list-method (ksvm), 53
kha-class, 37
ksvm,matrix-method (ksvm), 53
kkmeans, 38, 93
ksvm,vector-method (ksvm), 53
kkmeans,formula-method (kkmeans),
ksvm-class, 15, 37, 48, 53, 58, 67, 87, 100
38
ksvm-class, 60
kkmeans,kernelMatrix-method
(kkmeans), 38 laplacedot (dots), 9
kkmeans,list-method (kkmeans), 38 laplacekernel-class
kkmeans,matrix-method (kkmeans), (kernel-class), 28
38 lev (vm-class), 99
kmmd, 41, 44 lev,gausspr-method
kmmd,kernelMatrix-method (kmmd), (gausspr-class), 14
41 lev,ksvm-method (ksvm-class), 60
kmmd,list-method (kmmd), 41 lev,lssvm-method (lssvm-class), 66
kmmd,matrix-method (kmmd), 41 lev,rvm-method (rvm-class), 86
kmmd-class, 43 lev,vm-method (vm-class), 99
kpar (dots), 9 lssvm, 13, 62, 67
kpar,gausspr-method lssvm,formula-method (lssvm), 62
(gausspr-class), 14 lssvm,kernelMatrix-method
kpar,kernel-method (lssvm), 62
(kernel-class), 28 lssvm,list-method (lssvm), 62
kpar,kqr-method (kqr-class), 51 lssvm,matrix-method (lssvm), 62
kpar,ksvm-method (ksvm-class), 60 lssvm,vector-method (lssvm), 62
kpar,lssvm-method (lssvm-class), lssvm-class, 66
106 INDEX
xmatrix,gausspr-method
(gausspr-class), 14
xmatrix,kfa-method (kfa-class), 33
xmatrix,kha-method (kha-class), 37
xmatrix,kpca-method (kpca-class),
47
xmatrix,kqr-method (kqr-class), 51
xmatrix,ksvm-method (ksvm-class),
60
xmatrix,lssvm-method
(lssvm-class), 66
xmatrix,onlearn-method
(onlearn-class), 70
xmatrix,prc-method (prc-class), 73
xmatrix,rvm-method (rvm-class), 86
xmatrix,vm-method (vm-class), 99
xvar,kcca-method (kcca-class), 27
ycoef (kcca-class), 27
ycoef,kcca-method (kcca-class), 27
ymatrix (vm-class), 99
ymatrix,gausspr-method
(gausspr-class), 14
ymatrix,kqr-method (kqr-class), 51
ymatrix,ksvm-method (ksvm-class),
60
ymatrix,lssvm-method
(lssvm-class), 66
ymatrix,rvm-method (rvm-class), 86
ymatrix,vm-method (vm-class), 99
yvar,kcca-method (kcca-class), 27