Title: | Classification and Visualization |
---|---|
Description: | Miscellaneous functions for classification and visualization, e.g. regularized discriminant analysis, sknn() kernel-density naive Bayes, an interface to 'svmlight' and stepclass() wrapper variable selection for supervised classification, partimat() visualization of classification rules and shardsplot() of cluster results as well as kmodes() clustering for categorical data, corclust() variable clustering, variable extraction from different variable clustering models and weight of evidence preprocessing. |
Authors: | Christian Roever, Nils Raabe, Karsten Luebke, Uwe Ligges, Gero Szepannek, Marc Zentgraf, David Meyer |
Maintainer: | Uwe Ligges <[email protected]> |
License: | GPL-2 | GPL-3 |
Version: | 1.7-3 |
Built: | 2025-01-07 06:40:20 UTC |
Source: | CRAN |
Calculates the scaling parameter for betascale
.
b.scal(member, grouping, dis = FALSE, eps = 1e-04)
b.scal(member, grouping, dis = FALSE, eps = 1e-04)
member |
Membership values of an argmax classification method.
Eg. posterior probabilities of |
grouping |
Class vector. |
dis |
Logical, whether to optimize the dispersion parameter in |
eps |
Minimum variation of membership values. If variance is smaller than |
With betascale
and b.scal
, membership values of an argmax classifier
are scaled in such a way, that the mean membership value of those values which are assigned
to each class reflect the mean correctness rate of that values.
This is done via qbeta
and pbeta
with the appropriate shape parameters.
If dis
is TRUE
, it is tried that the variation of membership values
is optimal for the accuracy relative to the correctness rate.
If the variation of the membership values is less than eps
,
they are treated as one point and shifted towards the correctness rate.
A list containing
model |
Estimated parameters for |
eps |
Value of |
member |
Scaled membership values. |
Karsten Luebke ([email protected]), Uwe Ligges
Garczarek, Ursula Maria (2002): Classification rules in standardized partition spaces. Dissertation, University of Dortmund. URL http://hdl.handle.net/2003/2789
library(MASS) data(B3) pB3 <- predict(lda(PHASEN ~ ., data = B3))$posterior pbB3 <- b.scal(pB3, B3$PHASEN, dis = TRUE) ucpm(pB3, B3$PHASEN) ucpm(pbB3$member, B3$PHASEN)
library(MASS) data(B3) pB3 <- predict(lda(PHASEN ~ ., data = B3))$posterior pbB3 <- b.scal(pB3, B3$PHASEN, dis = TRUE) ucpm(pB3, B3$PHASEN) ucpm(pbB3$member, B3$PHASEN)
West German Business Cycles 1955-1994
data(B3)
data(B3)
A data frame with 157 observations on the following 14 variables.
a factor with levels 1
(upswing),
2
(upper turning points), 3
(downswing), and 4
(lower turning points).
GNP (y)
Private Consumption (y)
Government deficit (percent of GNP)
Wage and salary earners (y)
Net exports as (percent of GNP)
Money supply M1 (y)
Investment in equipment (y)
Investment in construction (y)
Unit labor cost (y)
GNP price deflator (y)
Consumer price index (y)
Short term interest rate (nominal)
Long term interest rate (real)
where (y) stands for “yearly growth rates”.
Note that years and corresponding year quarters are given in the row names of the data frame, e.g. “1988,3” for the third quarter in 1988.
The West German Business Cycles data (1955-1994) is analyzed by the project B3 of the SFB475 (Collaborative Research Centre “Reduction of Complexity for Multivariate Data Structures”), supported by the Deutsche Forschungsgemeinschaft.
RWI (Rheinisch Westfälisches Institut für Wirtschaftsforschung), Essen, Germany.
Heilemann, U. and Münch, H.J. (1996): West German Business Cycles 1963-1994: A Multivariate Discriminant Analysis. CIRET–Conference in Singapore, CIRET–Studien 50.
For benchmarking on this data see also benchB3
data(B3) summary(B3)
data(B3) summary(B3)
Evaluates the performance of a classification method on the B3
data.
benchB3(method, prior = rep(1/4, 4), sv = "4", scale = FALSE, ...)
benchB3(method, prior = rep(1/4, 4), sv = "4", scale = FALSE, ...)
method |
classification method to use |
prior |
prior probabilities of classes |
sv |
class of the start of a business cycle |
scale |
logical, whether to use |
... |
furhter arguments passed to |
The performance of classification methods on cyclic data can be measured by a special form of cross-validation: Leave-One-Cycle-Out. That means that a complete cycle is used as test data and the others are used as training data. This is repeated for all complete cycles in the data.
A list with elements
MODEL |
list with the model returned by |
error |
vector of test error rates in cycles |
l1co.error |
leave-one-cycle-out error rate |
Karsten Luebke, [email protected]
perLDA <- benchB3("lda") ## Not run: ## due to parameter optimization rda takes a while perRDA <- benchB3("rda") library(rpart) ## rpart will not work with prior argument: perRpart <- benchB3("rpart", prior = NULL) ## End(Not run)
perLDA <- benchB3("lda") ## Not run: ## due to parameter optimization rda takes a while perRDA <- benchB3("rda") library(rpart) ## rpart will not work with prior argument: perRpart <- benchB3("rpart", prior = NULL) ## End(Not run)
Performs the scaling for beta scaling learned by b.scal
.
betascale(betaobj, member)
betascale(betaobj, member)
betaobj |
A model learned by |
member |
Membership values to be scaled. |
See b.scal
.
A matrix with the scaled membership values.
library(MASS) data(B3) pB3 <- predict(lda(PHASEN ~ ., data = B3))$posterior pbB3 <- b.scal(pB3, B3$PHASEN) betascale(pbB3)
library(MASS) data(B3) pB3 <- predict(lda(PHASEN ~ ., data = B3))$posterior pbB3 <- b.scal(pB3, B3$PHASEN) betascale(pbB3)
Function to estimate the probabilities of a time series to stay or change the state.
calc.trans(x)
calc.trans(x)
x |
(factor) vector of states |
To estimate the transition probabilities the empirical frequencies are counted.
The transition probabilities matrix.
x[i,j]
is the probability to change from state i
to state j
.
Karsten Luebke, [email protected]
data(B3) calc.trans(B3$PHASEN)
data(B3) calc.trans(B3$PHASEN)
Function which constructs the lines from the borders between
two classes to the center. To be used in connection with
triplot
and quadplot
.
centerlines(n)
centerlines(n)
n |
number of classes. Meaningful are |
a matrix with n
-columns.
Karsten Luebke, [email protected]
centerlines(3) centerlines(4)
centerlines(3) centerlines(4)
Function to plot a scatterplot matrix with a classification result.
classscatter(formula, data, method, col.correct = "black", col.wrong = "red", gs = NULL, ...)
classscatter(formula, data, method, col.correct = "black", col.wrong = "red", gs = NULL, ...)
formula |
formula of the form |
data |
Data frame from which variables specified in formula are preferentially to be taken. |
method |
character, name of classification function
(e.g. “ |
col.correct |
color to use for correct classified objects. |
col.wrong |
color to use for missclassified objects. |
gs |
group symbol (plot character), must have the same length as the data.
If |
... |
further arguments passed to the underlying classification method or plot functions. |
The actual error rate.
Karsten Luebke, [email protected]
data(B3) library(MASS) classscatter(PHASEN ~ BSP91JW + EWAJW + LSTKJW, data = B3, method = "lda")
data(B3) library(MASS) classscatter(PHASEN ~ BSP91JW + EWAJW + LSTKJW, data = B3, method = "lda")
Diagnosis of collinearity in X
cond.index(formula, data, ...)
cond.index(formula, data, ...)
formula |
formula of the form ‘ |
data |
data frame (or matrix) containing the explanatory variables |
... |
further arguments to be passed to |
Collinearities can inflate the variance of the estimated regression coefficients and numerical stability. The condition indices are calculated by the eigenvalues of the crossproduct matrix of the scaled but uncentered explanatory variables. Indices > 30 may indicate collinearity.
A vector of the condition indices.
Andrea Preusser, Karsten Luebke ([email protected])
Belsley, D. , Kuh, E. and Welsch, R. E. (1979), Regression Diagnostics: Identifying Influential Data and Sources of Collinearity, John Wiley (New York)
data(Boston) condition_medv <- cond.index(medv ~ ., data = Boston) condition_medv
data(Boston) condition_medv <- cond.index(medv ~ ., data = Boston) condition_medv
A hierarchical clustering of variables using hclust
is performed using
1 - the absolute correlation as a distance measure between tow variables.
corclust(x, cl = NULL, method = "complete") ## S3 method for class 'corclust' plot(x, selection = "both", mincor = NULL, ...)
corclust(x, cl = NULL, method = "complete") ## S3 method for class 'corclust' plot(x, selection = "both", mincor = NULL, ...)
x |
Either a data frame or a matrix consisting of numerical attributes. |
cl |
Optional vector of ty factor indicating class levels, if class specific correlations should to be considered. |
method |
Linkage to be used for clustering. Default is |
selection |
If |
mincor |
Adds a horizontal line for this correlation. |
... |
passed to underlying plot functions. |
Each cluster consists of a set of correlated variables according to the chosen clustering criterion.
The default criterion is ‘complete
’. This choice is meaningful as it represents the
minimum absolute correlation between all variables of a cluster.
The data set is split into numerics and factors two separate clustering models are built, depending on the variable type.
For factors distances are computed based on 1-Cramer's V statistic using chisq.test
.
For a large number of factor variables this might take some time.
The resulting trees can be plotted using plot
.
Further proceeding would consist in chosing one variable of each cluster to obtain a
subset of rather uncorrelated variables for further analysis.
An automatic variable selection can be done using cvtree
and xtractvars
.
If an additional class vector cl
is given to the function for any two variables their minimum correlation over all classes is used.
Object of class corclust
.
cor |
Correlation matrix of numeric variables. |
crv |
Matrix of Cramer's V for factor variables. |
cluster.numerics |
Resulting hierarchical |
cluster.factors |
Resulting hierarchical |
id.numerics |
Variable IDs of numeric variables in |
id.factors |
Variable IDs of factor variables |
Gero Szepannek
Roever, C. and Szepannek, G. (2005): Application of a genetic algorithm to variable selection in fuzzy clustering. In C. Weihs and W. Gaul (eds), Classification - The Ubiquitous Challenge, 674-681, Springer.
plot.corclust
and hclust
for details on the clustering algorithm, and
cvtree
, xtractvars
for postprocessing.
data(iris) classes <- iris$Species variables <- iris[,1:4] ccres <- corclust(variables, classes) plot(ccres, mincor = 0.6)
data(iris) classes <- iris$Species variables <- iris[,1:4] ccres <- corclust(variables, classes) plot(ccres, mincor = 0.6)
Socioeconomic data for the most populous countries.
data(countries)
data(countries)
A data frame with 42 observations on the following 7 variables.
name of the country.
population.
population density.
GDP per inhabitant.
mean life expectation
infant mortality
illiteracy rate
CIA World Factbook https://www.cia.gov/the-world-factbook/
data(countries) summary(countries)
data(countries) summary(countries)
Extracts cluster IDs for variables according to a dendrogram from object of class cvtree
.
cvtree(object, k = 2, mincor = NULL, ...)
cvtree(object, k = 2, mincor = NULL, ...)
object |
Object of class |
k |
Number of clusters to be extracted from dendrogram. |
mincor |
Minimum within cluster correlation. Can be specified alternatively to |
... |
Currently not used. |
Like in corclust
for correlation comparison numerics and factors are considered separately.
For factors Cramer's V statistic is used.
Object of class cvtree
with elements:
cluster |
Vector of cluster IDs. |
correlations |
Matrix of average within cluster correlations and average corrleation to all variables of the closest cluster as well as the ID of the closest cluster. For factor variables Cramer's V is computed. |
Gero Szepannek
Roever, C. and Szepannek, G. (2005): Application of a genetic algorithm to variable selection in fuzzy clustering. In C. Weihs and W. Gaul (eds), Classification - The Ubiquitous Challenge, 674-681, Springer.
See also corclust
, plot.corclust
and hclust
for details on the clustering algorithm.
data(B3) ccres <- corclust(B3) plot(ccres) cvtree(ccres, k = 3)
data(B3) ccres <- corclust(B3) plot(ccres) cvtree(ccres, k = 3)
Given an estimated kernel density this function estimates the density of a new vector.
dkernel(x, kernel = density(x), interpolate = FALSE, ...)
dkernel(x, kernel = density(x), interpolate = FALSE, ...)
x |
vector of which the density should be estimated |
kernel |
object of |
interpolate |
Interpolate or use |
... |
currently not used. |
Denstiy of x
in kernel
.
Karsten Luebke, [email protected]
kern <- density(rnorm(50)) x <- seq(-3, 3, len = 100) y <- dkernel(x, kern) plot(x, y, type = "l")
kern <- density(rnorm(50)) x <- seq(-3, 3, len = 100) y <- dkernel(x, kern) plot(x, y, type = "l")
Plot showing the classification of observations based on
classification methods (e.g. lda
, qda
) for two variables.
Moreover, the classification borders are displayed and the apparent error rates are given in each title.
drawparti(grouping, x, y, method = "lda", prec = 100, xlab = NULL, ylab = NULL, col.correct = "black", col.wrong = "red", col.mean = "black", col.contour = "darkgrey", gs = as.character(grouping), pch.mean = 19, cex.mean = 1.3, print.err = 0.7, legend.err = FALSE, legend.bg = "white", imageplot = TRUE, image.colors = cm.colors(nc), plot.control = list(), ...)
drawparti(grouping, x, y, method = "lda", prec = 100, xlab = NULL, ylab = NULL, col.correct = "black", col.wrong = "red", col.mean = "black", col.contour = "darkgrey", gs = as.character(grouping), pch.mean = 19, cex.mean = 1.3, print.err = 0.7, legend.err = FALSE, legend.bg = "white", imageplot = TRUE, image.colors = cm.colors(nc), plot.control = list(), ...)
grouping |
factor specifying the class for each observation. |
x |
first explanatory vector. |
y |
second explanatory vector. |
method |
the method the classification is based on, currently supported are:
|
.
prec |
precision used to draw the classification borders (the higher the more precise; default: 100). |
xlab |
a title for the x axis. |
ylab |
a title for the y axis. |
col.correct |
color for correct classified objects. |
col.wrong |
color for wrong classified objects. |
col.mean |
color for class means (only for methods |
col.contour |
color of the contour lines (if |
gs |
group symbol (plot character), must have the same length as |
pch.mean |
plot character for class means (only for methods |
cex.mean |
character expansion for class means (only for methods |
print.err |
character expansion for text specifying the apparent error rate.
If |
legend.err |
logical; whether to plot the apparent error rate above the plot (if |
legend.bg |
Backgound colour to use for the legend. |
imageplot |
|
image.colors |
colors used for the |
plot.control |
A list containing further arguments passed to the underlying plot functions. |
... |
Further arguments passed to the classification |
Karsten Luebke, [email protected], Uwe Ligges, Irina Czogiel
Calculates the e- or softmax scaled membership values of an argmax based classification rule.
e.scal(x, k = 1, tc = NULL)
e.scal(x, k = 1, tc = NULL)
x |
matrix of membership values |
k |
parameter for e-scaling (1 for softmax) |
tc |
vector of true classes (required if |
For any membership vector y is calculated.
If
k=1
, the classical softmax scaling is used. If the true classes are given, k
is optimized
so that the apparent error rate is minimized.
A list containing elements
sv |
Scaled values |
k |
Optimal |
Karsten Luebke, [email protected]
Garczarek, Ursula Maria (2002): Classification rules in standardized partition spaces. Dissertation, University of Dortmund. URL http://hdl.handle.net/2003/2789
library(MASS) data(iris) ldaobj <- lda(Species ~ ., data = iris) ldapred <- predict(ldaobj)$posterior e.scal(ldapred) e.scal(ldapred, tc = iris$Species)
library(MASS) data(iris) ldaobj <- lda(Species ~ ., data = iris) ldapred <- predict(ldaobj)$posterior e.scal(ldapred) e.scal(ldapred, tc = iris$Species)
Produces an object of class EDAM
which is a two dimensional representation
of data in a rectangular, equally spaced
grid as known from Self-Organizing Maps.
EDAM(EV0, nzx = 0, iter.max = 10, random = TRUE, standardize = FALSE, wghts = 0, classes = 0, sa = TRUE, temp.in = 0.5, temp.fin = 1e-07, temp.gamma = 0)
EDAM(EV0, nzx = 0, iter.max = 10, random = TRUE, standardize = FALSE, wghts = 0, classes = 0, sa = TRUE, temp.in = 0.5, temp.fin = 1e-07, temp.gamma = 0)
EV0 |
either a symmetric dissimilarity matrix or a matrix of arbitrary dimensions whose n rows correspond to cases and whose k columns correspond to variables. |
nzx |
an integer specifying the number of vertical bars in the grid. By default,
|
iter.max |
an integer giving the maxmimum number of iterations to perform for the same neighborhood size. |
random |
logical. If |
standardize |
logical. If |
wghts |
an optional vector of length k giving relative weights of the variables in
computing Euclidean distances. Meaningless if |
classes |
an optional vector of length n specifying the membership to classes for all objects. |
sa |
logical. If |
temp.in |
numeric giving the initial temperature, if |
temp.fin |
numeric giving the final temperature, if |
temp.gamma |
numeric giving the relative change of the temperature from one iteration to the other,
if |
The data given by EV0
is visualized by the EDAM-algorithm. This method approximates the best visualization where
goodness is measured by S
, a transformation of the criterion stress
as i.e.
known from sammon
.
The target space of the visualization is restricted to a grid so the problem has a discrete solution space.
Originally this restriction was made to make the results
comparable to those of Kohonen Self-Organizing Maps. But it turns out that also for reasons of a clear arrangement the
representation in a grid can be more favorable than in the hole plane.
During the computation of EDAM 3 values indicating its progress are given online. The first is the number of the actual
iteration, the second the maximum number of overall performed iterations. The latter may reduce during computation,
since the neighborhood reduces in case of convergence before the last iteration.
The last number gives the actual criterion S.
The default plot method plot.edam
for objects of class EDAM
is shardsplot
.
EDAM returns an object of class
EDAM
, which is a list containing the following components:
preimages |
the re-ordered data; the position of the i-th object is where |
Z |
a matrix representing the positions of the |
Z.old.terms |
a matrix representing the positions of the data in original order in the grid by their numbers. |
cl.ord |
a vector giving the re-ordered classes. All elements equal 1 if argument |
S |
the criterion of the map |
Nils Raabe
Raabe, N. (2003). Vergleich von Kohonen Self-Organizing-Maps mit einem nichtsimultanen Klassifikations- und Visualisierungsverfahren. Diploma Thesis, Department of Statistics, University of Dortmund.
# Compute an Eight Directions Arranged Map for a random sample # of the iris data. data(iris) set.seed(1234) iris.sample <- sample(150, 42) irisEDAM <- EDAM(iris[iris.sample, 1:4], classes = iris[iris.sample, 5], standardize = TRUE, iter.max = 3) plot(irisEDAM, vertices = FALSE) legend(3, 5, col = rainbow(3), legend = levels(iris[,5]), pch = 16) print(irisEDAM) # Construct clusters within the phases of the german business data # and visualize the centroids by EDAM. data(B3) phasemat <- lapply(1:4, function(x) B3[B3[,1] == x, 2:14]) subclasses <- lapply(phasemat, function(x) cutree(hclust(dist(x)), k = round(nrow(x) / 4.47))) centroids <- lapply(1:4, function(y) apply(phasemat[[y]], 2, function(x) by(x, subclasses[[y]], mean))) centmat <- matrix(unlist(sapply(centroids, t)), ncol = 13, byrow = TRUE, dimnames = list(NULL, colnames(centroids[[1]]))) centclasses <- unlist(lapply(1:4, function(x) rep(x, unlist(lapply(centroids, nrow))[x]))) B3EDAM <- EDAM(centmat, classes = centclasses, standardize = TRUE, iter.max = 6, rand = FALSE) plot(B3EDAM, standardize = TRUE) opar <- par(xpd = NA) legend(4, 5.1, col = rainbow(4), pch = 16, xjust = 0.5, yjust = 0, ncol = 2, legend = c("upswing", "upper turning point", "downswing", "lower turning point")) print(B3EDAM) par(opar)
# Compute an Eight Directions Arranged Map for a random sample # of the iris data. data(iris) set.seed(1234) iris.sample <- sample(150, 42) irisEDAM <- EDAM(iris[iris.sample, 1:4], classes = iris[iris.sample, 5], standardize = TRUE, iter.max = 3) plot(irisEDAM, vertices = FALSE) legend(3, 5, col = rainbow(3), legend = levels(iris[,5]), pch = 16) print(irisEDAM) # Construct clusters within the phases of the german business data # and visualize the centroids by EDAM. data(B3) phasemat <- lapply(1:4, function(x) B3[B3[,1] == x, 2:14]) subclasses <- lapply(phasemat, function(x) cutree(hclust(dist(x)), k = round(nrow(x) / 4.47))) centroids <- lapply(1:4, function(y) apply(phasemat[[y]], 2, function(x) by(x, subclasses[[y]], mean))) centmat <- matrix(unlist(sapply(centroids, t)), ncol = 13, byrow = TRUE, dimnames = list(NULL, colnames(centroids[[1]]))) centclasses <- unlist(lapply(1:4, function(x) rep(x, unlist(lapply(centroids, nrow))[x]))) B3EDAM <- EDAM(centmat, classes = centclasses, standardize = TRUE, iter.max = 6, rand = FALSE) plot(B3EDAM, standardize = TRUE) opar <- par(xpd = NA) legend(4, 5.1, col = rainbow(4), pch = 16, xjust = 0.5, yjust = 0, ncol = 2, legend = c("upswing", "upper turning point", "downswing", "lower turning point")) print(B3EDAM) par(opar)
Cross-tabulates true and predicted classes with the option to show relative frequencies.
errormatrix(true, predicted, relative = FALSE)
errormatrix(true, predicted, relative = FALSE)
true |
Vector of true classes. |
predicted |
Vector of predicted classes. |
relative |
Logical. If |
Given vectors of true and predicted classes, a (symmetric) table of misclassifications is constructed.
Element [i,j] shows the number of objects of class i that were classified as class j; so the main diagonal shows the correct classifications. The last row and column show the corresponding sums of misclassifications, the lower right element is the total sum of misclassifications.
If ‘relative
’ is TRUE
, the rows are
normalized so they show relative frequencies instead. The
lower right element now shows the total error rate, and the
remaining last row sums up to one, so it shows “where the
misclassifications went”.
A (named) matrix.
Concerning the case that ‘relative
’ is TRUE
:
If a prior distribution over the classes is given, the misclassification rate that is returned as the lower right element (which is only the fraction of misclassified data) is not an estimator for the expected misclassification rate.
In that case you have to multiply the individual error rates for each class (returned in the last column) with the corresponding prior probabilities and sum these up (see example below).
Both error rate estimates are equal, if the fractions of classes in the data are equal to the prior probabilities.
Christian Röver, [email protected]
data(iris) library(MASS) x <- lda(Species ~ Sepal.Length + Sepal.Width, data=iris) y <- predict(x, iris) # absolute numbers: errormatrix(iris$Species, y$class) # relative frequencies: errormatrix(iris$Species, y$class, relative = TRUE) # percentages: round(100 * errormatrix(iris$Species, y$class, relative = TRUE), 0) # expected error rate in case of class prior: indiv.rates <- errormatrix(iris$Species, y$class, relative = TRUE)[1:3, 4] prior <- c("setosa" = 0.2, "versicolor" = 0.3, "virginica" = 0.5) total.rate <- t(indiv.rates) %*% prior total.rate
data(iris) library(MASS) x <- lda(Species ~ Sepal.Length + Sepal.Width, data=iris) y <- predict(x, iris) # absolute numbers: errormatrix(iris$Species, y$class) # relative frequencies: errormatrix(iris$Species, y$class, relative = TRUE) # percentages: round(100 * errormatrix(iris$Species, y$class, relative = TRUE), 0) # expected error rate in case of class prior: indiv.rates <- errormatrix(iris$Species, y$class, relative = TRUE)[1:3, 4] prior <- c("setosa" = 0.2, "versicolor" = 0.3, "virginica" = 0.5) total.rate <- t(indiv.rates) %*% prior total.rate
Function to generate 3-class classification benchmarking data as introduced by J.H. Friedman (1989)
friedman.data(setting = 1, p = 6, samplesize = 40, asmatrix = FALSE)
friedman.data(setting = 1, p = 6, samplesize = 40, asmatrix = FALSE)
setting |
the problem setting (integer 1,2,...,6). |
p |
number of variables (6, 10, 20 or 40). |
samplesize |
sample size (number of observations, >=6). |
asmatrix |
if |
When J.H. Friedman introduced the Regularized Discriminant Analysis
(rda
) in 1989, he used artificially generated data
to test the procedure and to examine its performance in comparison to
Linear and Quadratic Discriminant Analysis
(see also lda
and qda
).
6 different settings were considered to demonstrate potential strengths and weaknesses of the new method:
equal spherical covariance matrices,
unequal spherical covariance matrices,
equal, highly ellipsoidal covariance matrices with mean differences in low-variance subspace,
equal, highly ellipsoidal covariance matrices with mean differences in high-variance subspace,
unequal, highly ellipsoidal covariance matrices with zero mean differences and
unequal, highly ellipsoidal covariance matrices with nonzero mean differences.
For each of the 6 settings data was generated with 6, 10, 20 and 40 variables.
Classification performance was then measured by repeatedly creating training-datasets of 40 observations and estimating the misclassification rates by test sets of 100 observations.
The number of classes is always 3, class labels are assigned randomly (with equal probabilities) to observations, so the contributions of classes to the data differs from dataset to dataset. To make sure covariances can be estimated at all, there are always at least two observations from each class in a dataset.
Depending on asmatrix
either a data frame or a matrix with
samplesize
rows and p+1
columns, the first column containing
the class labels, the remaining columns being the variables.
Christian Röver, [email protected]
Friedman, J.H. (1989): Regularized Discriminant Analysis. In: Journal of the American Statistical Association 84, 165-175.
# Reproduce the 1st setting with 6 variables. # Error rate should be somewhat near 9 percent. training <- friedman.data(1, 6, 40) x <- rda(class ~ ., data = training, gamma = 0.74, lambda = 0.77) test <- friedman.data(1, 6, 100) y <- predict(x, test[,-1]) errormatrix(test[,1], y$class)
# Reproduce the 1st setting with 6 variables. # Error rate should be somewhat near 9 percent. training <- friedman.data(1, 6, 40) x <- rda(class ~ ., data = training, gamma = 0.74, lambda = 0.77) test <- friedman.data(1, 6, 100) y <- predict(x, test[,-1]) errormatrix(test[,1], y$class)
The dataset contains data of past credit applicants. The applicants are rated as good or bad. Models of this data can be used to determine if new applicants present a good or bad credit risk.
data("GermanCredit")
data("GermanCredit")
A data frame containing 1,000 observations on 21 variables.
factor variable indicating the status of the existing checking account, with levels ... < 100 DM
, 0 <= ... < 200 DM
, ... >= 200 DM/salary for at least 1 year
and no checking account
.
duration in months.
factor variable indicating credit history, with levels no credits taken/all credits paid back duly
, all credits at this bank paid back duly
, existing credits paid back duly till now
, delay in paying off in the past
and critical account/other credits existing
.
factor variable indicating the credit's purpose, with levels car (new)
, car (used)
, furniture/equipment
, radio/television
, domestic appliances
, repairs
, education
, retraining
, business
and others
.
credit amount.
factor. savings account/bonds, with levels ... < 100 DM
, 100 <= ... < 500 DM
, 500 <= ... < 1000 DM
, ... >= 1000 DM
and unknown/no savings account
.
ordered factor indicating the duration of the current employment, with levels unemployed
, ... < 1 year
, 1 <= ... < 4 years
, 4 <= ... < 7 years
and ... >= 7 years
.
installment rate in percentage of disposable income.
factor variable indicating personal status and sex, with levels
male:divorced/separated
, female:divorced/separated/married
,
male:single
, male:married/widowed
and female:single
.
factor. Other debtors, with levels none
, co-applicant
and guarantor
.
present residence since?
factor variable indicating the client's highest valued property, with levels real estate
, building society savings agreement/life insurance
, car or other
and unknown/no property
.
client's age.
factor variable indicating other installment plans, with levels bank
, stores
and none
.
factor variable indicating housing, with levels rent
, own
and for free
.
number of existing credits at this bank.
factor indicating employment status, with levels unemployed/unskilled - non-resident
, unskilled - resident
, skilled employee/official
and management/self-employed/highly qualified employee/officer
.
Number of people being liable to provide maintenance.
binary variable indicating if the customer has a registered telephone number.
binary variable indicating if the customer is a foreign worker.
binary variable indicating credit risk, with levels good
and bad
.
The original data was provided by:
Professor Dr. Hans Hofmann, Institut fuer Statistik und Oekonometrie, Universitaet Hamburg, FB Wirtschaftswissenschaften, Von-Melle-Park 5, 2000 Hamburg 13
The dataset has been taken from the UCI Repository Of Machine Learning Databases at http://archive.ics.uci.edu/ml/.
It was published this way in CRAN package evtree (maintainer: Thomas Grubinger) that has been archived from CRAN on May 31, 2014. Afterwards the exactly same data object has been copied from the evtree package to klaR.
Performs a stepwise forward variable/model selection using the Wilk's Lambda criterion.
greedy.wilks(X, ...) ## Default S3 method: greedy.wilks(X, grouping, niveau = 0.2, ...) ## S3 method for class 'formula' greedy.wilks(formula, data = NULL, ...)
greedy.wilks(X, ...) ## Default S3 method: greedy.wilks(X, grouping, niveau = 0.2, ...) ## S3 method for class 'formula' greedy.wilks(formula, data = NULL, ...)
X |
matrix or data frame (rows=cases, columns=variables) |
grouping |
class indicator vector |
formula |
formula of the form ‘ |
data |
data frame (or matrix) containing the explanatory variables |
niveau |
level for the approximate F-test decision |
... |
further arguments to be passed to the default method, e.g. |
A stepwise forward variable selection is performed. The initial model is defined by starting with the variable which separates the groups most. The model is then extended by including further variables depending on the Wilk's lambda criterion: Select the one which minimizes the Wilk's lambda of the model including the variable if its p-value still shows statistical significance.
A list of two components, a formula
of the form ‘response ~ list + of + selected + variables
’,
and a data.frame results
containing the following variables:
vars |
the names of the variables in the final model in the order of selection. |
Wilks.lambda |
the appropriate Wilks' lambda for the selected variables. |
F.statistics.overall |
the approximated F-statistic for the so far selected model. |
p.value.overall |
the appropriate p-value of the F-statistic. |
F.statistics.diff |
the approximated F-statistic of the partial Wilks's lambda (for comparing the model including the new variable with the model not including it). |
p.value.diff |
the appropriate p-value of the F-statistic of the partial Wilk's lambda. |
Andrea Preusser, Karsten Luebke ([email protected])
Mardia, K. V. , Kent, J. T. and Bibby, J. M. (1979), Multivariate analysis, Academic Press (New York; London)
data(B3) gw_obj <- greedy.wilks(PHASEN ~ ., data = B3, niveau = 0.1) gw_obj ## now you can say stuff like ## lda(gw_obj$formula, data = B3)
data(B3) gw_obj <- greedy.wilks(PHASEN ~ ., data = B3, niveau = 0.1) gw_obj ## now you can say stuff like ## lda(gw_obj$formula, data = B3)
A Hidden Markov Model for the classification of states in a time series.
Based on the transition probabilities and the so called emission probabilities
() the ‘prior probablilities’ of states (classes) in time period t
given all past information in time period t are calculated.
hmm.sop(sv, trans.matrix, prob.matrix)
hmm.sop(sv, trans.matrix, prob.matrix)
sv |
state at time 0 |
trans.matrix |
matrix of transition probabilities |
prob.matrix |
matrix of |
Returns the ‘prior probablilities’ of states.
Daniel Fischer, Reinald Oetsch
Garczarek, Ursula Maria (2002): Classification rules in standardized partition spaces. Dissertation, University of Dortmund. URL http://hdl.handle.net/2003/2789
library(MASS) data(B3) trans.matrix <- calc.trans(B3$PHASEN) # Calculate posterior prob. for the classes via lda prob.matrix <- predict(lda(PHASEN ~ ., data = B3))$post errormatrix(B3$PHASEN, apply(prob.matrix, 1, which.max)) prior.prob <- hmm.sop("2", trans.matrix, prob.matrix) errormatrix(B3$PHASEN, apply(prior.prob, 1, which.max))
library(MASS) data(B3) trans.matrix <- calc.trans(B3$PHASEN) # Calculate posterior prob. for the classes via lda prob.matrix <- predict(lda(PHASEN ~ ., data = B3))$post errormatrix(B3$PHASEN, apply(prob.matrix, 1, which.max)) prior.prob <- hmm.sop("2", trans.matrix, prob.matrix) errormatrix(B3$PHASEN, apply(prior.prob, 1, which.max))
Perform k-modes clustering on categorical data.
kmodes(data, modes, iter.max = 10, weighted = FALSE, fast = TRUE)
kmodes(data, modes, iter.max = 10, weighted = FALSE, fast = TRUE)
data |
A matrix or data frame of categorical data. Objects have to be in rows, variables in columns. |
modes |
Either the number of modes or a set of initial
(distinct) cluster modes. If a number, a random set of (distinct)
rows in |
iter.max |
The maximum number of iterations allowed. |
weighted |
Whether usual simple-matching distance between objects is used, or a weighted version of this distance. |
fast |
Logical Whether a fast version of the algorithm should be applied. |
The -modes algorithm (Huang, 1997) an extension of the k-means algorithm by MacQueen (1967).
The data given by data
is clustered by the -modes method (Huang, 1997)
which aims to partition the objects into
groups such that the
distance from objects to the assigned cluster modes is minimized.
By default simple-matching distance is used to determine the dissimilarity of two objects. It is computed by counting the number of mismatches in all variables. Alternative this distance is weighted by the frequencies of the categories in data (see Huang, 1997, for details).
If an initial matrix of modes is supplied, it is possible that no object will be closest to one or more modes. In this case less cluster than supplied modes will be returned and a warning is given.
If called using fast = TRUE
the reassignment of the data to clusters is done for the entire data set before recomputation of the modes is done. For computational reasons this option should be chosen unless moderate data sizes.
For clustering mixed type data it is referred to kproto
.
An object of class "kmodes"
which is a list with components:
cluster |
A vector of integers indicating the cluster to which each object is allocated. |
size |
The number of objects in each cluster. |
modes |
A matrix of cluster modes. |
withindiff |
The within-cluster simple-matching distance for each cluster. |
iterations |
The number of iterations the algorithm has run. |
weighted |
Whether weighted distances were used or not. |
Christian Neumann, [email protected], Gero Szepannek, [email protected]
Huang, Z. (1997) A Fast Clustering Algorithm to Cluster Very Large Categorical Data Sets in Data Mining. in KDD: Techniques and Applications (H. Lu, H. Motoda and H. Luu, Eds.), pp. 21-34, World Scientific, Singapore.
MacQueen, J. (1967) Some methods for classification and analysis of multivariate observations. In Proceedings of the Fifth Berkeley Symposium on Mathematical Statistics and Probability, eds L. M. Le Cam & J. Neyman, 1, pp. 281-297. Berkeley, CA: University of California Press.
### a 5-dimensional toy-example: ## generate data set with two groups of data: set.seed(1) x <- rbind(matrix(rbinom(250, 2, 0.25), ncol = 5), matrix(rbinom(250, 2, 0.75), ncol = 5)) colnames(x) <- c("a", "b", "c", "d", "e") ## run algorithm on x: (cl <- kmodes(x, 2)) ## and visualize with some jitter: plot(jitter(x), col = cl$cluster) points(cl$modes, col = 1:5, pch = 8)
### a 5-dimensional toy-example: ## generate data set with two groups of data: set.seed(1) x <- rbind(matrix(rbinom(250, 2, 0.25), ncol = 5), matrix(rbinom(250, 2, 0.75), ncol = 5)) colnames(x) <- c("a", "b", "c", "d", "e") ## run algorithm on x: (cl <- kmodes(x, 2)) ## and visualize with some jitter: plot(jitter(x), col = cl$cluster) points(cl$modes, col = 1:5, pch = 8)
A localized version of Linear Discriminant Analysis.
loclda(x, ...) ## S3 method for class 'formula' loclda(formula, data, ..., subset, na.action) ## Default S3 method: loclda(x, grouping, weight.func = function(x) 1/exp(x), k = nrow(x), weighted.apriori = TRUE, ...) ## S3 method for class 'data.frame' loclda(x, ...) ## S3 method for class 'matrix' loclda(x, grouping, ..., subset, na.action)
loclda(x, ...) ## S3 method for class 'formula' loclda(formula, data, ..., subset, na.action) ## Default S3 method: loclda(x, grouping, weight.func = function(x) 1/exp(x), k = nrow(x), weighted.apriori = TRUE, ...) ## S3 method for class 'data.frame' loclda(x, ...) ## S3 method for class 'matrix' loclda(x, grouping, ..., subset, na.action)
formula |
Formula of the form ‘ |
data |
Data frame from which variables specified in |
x |
Matrix or data frame containing the explanatory variables
(required, if |
grouping |
(required if no |
weight.func |
Function used to compute local weights. Must be finite over the interval [0,1]. See Details below. |
k |
Number of nearest neighbours used to construct localized classification rules. See Details below. |
weighted.apriori |
Logical: if |
subset |
An index vector specifying the cases to be used in the training sample. |
na.action |
A function to specify the action to be taken if |
... |
Further arguments to be passed to |
This is an approach to apply the concept of localization described by Tutz and Binder (2005)
to Linear Discriminant Analysis. The function loclda
generates an object of class loclda
(see Value below). As localization makes it necessary to build an
individual decision rule for each test observation,
this rule construction has to be handled by predict.loclda
.
For convenience, the rule building procedure is still described here.
To classify a test observation , only the
k
nearest neighbours of
within the train data are used. Each of these k train observations
, is assigned a weight
according to
where K is the weighting function given by weight.func
,
is the euclidian distance of
and
and
is the euclidian distance of
to its
-th nearest neighbour.
With these weights for each class
,
its weighted empirical mean
and weighted empirical
covariance matrix are computed. The estimated pooled (weighted) covariance matrix
is then calculated from the individual weighted
empirical class covariance matrices. If
weighted.apriori
is TRUE
(the default),
prior class probabilities are estimated according to:
where I is the indicator function. If FALSE
, equal priors for all classes are used.
In analogy to Linear Discriminant Analysis, the decision rule for is
where
If ,
is set to
for all
and the test observation
is simply assigned to the class whose weighted mean has the lowest
euclidian distance to
.
A list of class loclda
containing the following components:
call |
The (matched) function call. |
learn |
Matrix containing the values of the explanatory variables for all train observations. |
grouping |
Factor specifying the class for each train observation. |
weight.func |
Value of the argument |
k |
Value of the argument |
weighted.apriori |
Value of the argument |
Marc Zentgraf ([email protected]) and Karsten Luebke ([email protected])
Tutz, G. and Binder, H. (2005): Localized classification. Statistics and Computing 15, 155-166.
benchB3("lda")$l1co.error benchB3("loclda")$l1co.error
benchB3("lda")$l1co.error benchB3("loclda")$l1co.error
Performs pairwise variable selection on subclasses.
locpvs(x, subclasses, subclass.labels, prior=NULL, method="lda", vs.method = c("ks.test", "stepclass", "greedy.wilks"), niveau=0.05, fold=10, impr=0.1, direct="backward", out=FALSE, ...)
locpvs(x, subclasses, subclass.labels, prior=NULL, method="lda", vs.method = c("ks.test", "stepclass", "greedy.wilks"), niveau=0.05, fold=10, impr=0.1, direct="backward", out=FALSE, ...)
x |
matrix or data frame containing the explanatory variables. x must consist of numerical data only. |
subclasses |
vector indicating the subclasses (a factor) |
subclass.labels |
must be a matrix with 2 coloumns, where the first coloumn specifies the subclass and the second coloumn the according upper class |
prior |
prior probabilites for the classes. If not specified the prior probabilities will be set according to proportion in “subclasses”. If specified the order of prior probabilities must be the same as in “subclasses”. |
method |
character, name of classification function (e.g. “ |
vs.method |
character, name of variable selection method. Must be one of “ |
niveau |
used niveau for “ |
fold |
parameter for cross-validation, if “ |
impr |
least improvement of performance measure desired to include or exclude any variable (<=1), if “ |
direct |
direction of variable selection, if “ |
out |
indicator (logical) for textoutput during computation (slows down computation!), if “ |
... |
further parameters passed to classification function (‘ |
A call on pvs
is performed using “subclasses” as grouping variable. See pvs
for further details.
An object of class ‘locpvs
’ containing the following components:
pvs.result |
the complete output of the call to |
subclass.labels |
the subclass.labels as specified in function call |
Gero Szepannek, [email protected], Christian Neumann
Szepannek, G. and Weihs, C. (2006) Local Modelling in Classification on Different Feature Subspaces. In Advances in Data Mining., ed Perner, P., LNAI 4065, pp. 226-234. Springer, Heidelberg.
predict.locpvs
for predicting ‘locpvs
’ models and pvs
## this example might be a bit artificial, but it sufficiently shows how locpvs has to be used ## learn a locpvs-model on the Vehicle dataset library("mlbench") data("Vehicle") subclass <- Vehicle$Class # use four car-types in dataset as subclasses ## aggregate "bus" and "van" to upper-class "big" and "saab" and "opel" to upper-class "small" subclass_class <- matrix(c("bus","van","saab","opel","big","big","small","small"),ncol=2) ## learn now a locpvs-model for the subclasses: model <- locpvs(Vehicle[,1:18], subclass, subclass_class) model # short summary, showing the class-pairs of the submodels # together with the selected variables and the relation of sub- to upperclasses ## predict: pred <- predict(model, Vehicle[,1:18]) ## now you can look at the predicted classes: pred$class ## or at the posterior probabilities: pred$posterior ## or at the posterior probabilities for the subclasses: pred$subclass.posteriors
## this example might be a bit artificial, but it sufficiently shows how locpvs has to be used ## learn a locpvs-model on the Vehicle dataset library("mlbench") data("Vehicle") subclass <- Vehicle$Class # use four car-types in dataset as subclasses ## aggregate "bus" and "van" to upper-class "big" and "saab" and "opel" to upper-class "small" subclass_class <- matrix(c("bus","van","saab","opel","big","big","small","small"),ncol=2) ## learn now a locpvs-model for the subclasses: model <- locpvs(Vehicle[,1:18], subclass, subclass_class) model # short summary, showing the class-pairs of the submodels # together with the selected variables and the relation of sub- to upperclasses ## predict: pred <- predict(model, Vehicle[,1:18]) ## now you can look at the predicted classes: pred$class ## or at the posterior probabilities: pred$posterior ## or at the posterior probabilities for the subclasses: pred$subclass.posteriors
Computer intensive method for linear dimension reduction that minimizes the classification error directly.
meclight(x, ...) ## Default S3 method: meclight(x, grouping, r = 1, fold = 10, ...) ## S3 method for class 'formula' meclight(formula, data = NULL, ..., subset, na.action = na.fail) ## S3 method for class 'data.frame' meclight(x, ...) ## S3 method for class 'matrix' meclight(x, grouping, ..., subset, na.action = na.fail)
meclight(x, ...) ## Default S3 method: meclight(x, grouping, r = 1, fold = 10, ...) ## S3 method for class 'formula' meclight(formula, data = NULL, ..., subset, na.action = na.fail) ## S3 method for class 'data.frame' meclight(x, ...) ## S3 method for class 'matrix' meclight(x, grouping, ..., subset, na.action = na.fail)
x |
(required if no formula is given as the principal argument.) A matrix or data frame containing the explanatory variables. |
grouping |
(required if no formula principal argument is given.) A factor specifying the class for each observation. |
r |
Dimension of projected subspace. |
fold |
Number of Bootstrap samples. |
formula |
A formula of the form |
data |
Data frame from which variables specified in formula are preferentially to be taken. |
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 for the procedure to fail.
An alternative is |
... |
Further arguments passed to |
Computer intensive method for linear dimension reduction that minimizes the classification error in the projected
subspace directly. Classification is done by lda
. In contrast to the reference function minimization is
done by Nelder-Mead in optim
.
method.model |
An object of class ‘lda’. |
Proj.matrix |
Projection matrix. |
B.error |
Estimated bootstrap error rate. |
B.impro |
Improvement in |
Maria Eveslage, Karsten Luebke, [email protected]
Roehl, M.C., Weihs, C., and Theis, W. (2002): Direct Minimization in Multivariate Classification. Computational Statistics, 17, 29-46.
data(iris) meclight.obj <- meclight(Species ~ ., data = iris) meclight.obj
data(iris) meclight.obj <- meclight(Species ~ ., data = iris) meclight.obj
Computes the conditional a-posterior probabilities of a categorical class variable given independent predictor variables using the Bayes rule.
## S3 method for class 'formula' NaiveBayes(formula, data, ..., subset, na.action = na.pass) ## Default S3 method: NaiveBayes(x, grouping, prior, usekernel = FALSE, fL = 0, ...)
## S3 method for class 'formula' NaiveBayes(formula, data, ..., subset, na.action = na.pass) ## Default S3 method: NaiveBayes(x, grouping, prior, usekernel = FALSE, fL = 0, ...)
x |
a numeric matrix, or a data frame of categorical and/or numeric variables. |
grouping |
class vector (a factor). |
formula |
a formula of the form |
data |
a data frame of predictors (categorical and/or numeric). |
prior |
the prior probabilities of class membership. If unspecified, the class proportions for the training set are used. If present, the probabilities should be specified in the order of the factor levels. |
usekernel |
if |
fL |
Factor for Laplace correction, default factor is 0, i.e. no correction. |
... |
arguments passed to |
subset |
for data given in a data frame, 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 |
This implementation of Naive Bayes as well as this help is based on the code by
David Meyer in the package e1071 but extended for kernel estimated densities and user
specified prior
probabilities.
The standard naive Bayes classifier (at least this implementation)
assumes independence of the predictor
variables.
An object of class "NaiveBayes"
including components:
apriori |
Class distribution for the dependent variable. |
tables |
A list of tables, one for each predictor variable. For each
categorical variable a table giving, for each attribute level, the conditional
probabilities given the target class. For each numeric variable, a
table giving, for each target class, mean and standard deviation of
the (sub-)variable or a object of |
Karsten Luebke, [email protected]
predict.NaiveBayes
,plot.NaiveBayes
,naiveBayes
,qda
data(iris) m <- NaiveBayes(Species ~ ., data = iris)
data(iris) m <- NaiveBayes(Species ~ ., data = iris)
Function for nearest mean classification.
nm(x, ...) ## Default S3 method: nm(x, grouping, gamma = 0, ...) ## S3 method for class 'data.frame' nm(x, ...) ## S3 method for class 'matrix' nm(x, grouping, ..., subset, na.action = na.fail) ## S3 method for class 'formula' nm(formula, data = NULL, ..., subset, na.action = na.fail)
nm(x, ...) ## Default S3 method: nm(x, grouping, gamma = 0, ...) ## S3 method for class 'data.frame' nm(x, ...) ## S3 method for class 'matrix' nm(x, grouping, ..., subset, na.action = na.fail) ## S3 method for class 'formula' nm(formula, data = NULL, ..., subset, na.action = na.fail)
x |
matrix or data frame containing the explanatory variables
(required, if |
grouping |
factor specifying the class for each observation
(required, if |
formula |
formula of the form |
data |
Data frame from which variables specified in |
gamma |
gamma parameter for rbf weight of the distance to mean. If |
subset |
An index vector specifying the cases to be used in the training sample. (Note: If given, this argument must be named!) |
na.action |
specify the action to be taken if |
... |
further arguments passed to the underlying |
nm
is calling sknn
with the class means as observations.
If gamma>0
a gaussian like density is used to weight the distance to the class means
weight=exp(-gamma*distance)
. This is similar to an rbf kernel.
If the distances are large it may be useful to scale
the data first.
A list containing the function call and the class means (learn
)).
Karsten Luebke, [email protected]
data(B3) x <- nm(PHASEN ~ ., data = B3) x$learn x <- nm(PHASEN ~ ., data = B3, gamma = 0.1) predict(x)$post
data(B3) x <- nm(PHASEN ~ ., data = B3) x$learn x <- nm(PHASEN ~ ., data = B3, gamma = 0.1) predict(x)$post
Provides a multiple figure array which shows the classification of observations based on
classification methods (e.g. lda
, qda
) for every combination of two variables.
Moreover, the classification borders are displayed and the apparent error rates are given in each title.
partimat(x,...) ## Default S3 method: partimat(x, grouping, method = "lda", prec = 100, nplots.vert, nplots.hor, main = "Partition Plot", name, mar, plot.matrix = FALSE, plot.control = list(), ...) ## S3 method for class 'data.frame' partimat(x, ...) ## S3 method for class 'matrix' partimat(x, grouping, ..., subset, na.action = na.fail) ## S3 method for class 'formula' partimat(formula, data = NULL, ..., subset, na.action = na.fail)
partimat(x,...) ## Default S3 method: partimat(x, grouping, method = "lda", prec = 100, nplots.vert, nplots.hor, main = "Partition Plot", name, mar, plot.matrix = FALSE, plot.control = list(), ...) ## S3 method for class 'data.frame' partimat(x, ...) ## S3 method for class 'matrix' partimat(x, grouping, ..., subset, na.action = na.fail) ## S3 method for class 'formula' partimat(formula, data = NULL, ..., subset, na.action = na.fail)
x |
matrix or data frame containing the explanatory variables (required, if |
grouping |
factor specifying the class for each observation (required, if |
formula |
formula of the form |
method |
the method the classification is based on, currently supported are:
|
.
prec |
precision used to draw the classification borders (the higher the more precise; default: 100). |
data |
Data frame from which variables specified in formula are preferentially to be taken. |
nplots.vert |
number of rows in the multiple figure array |
nplots.hor |
number of columns in the multiple figure array |
subset |
index vector specifying the cases to be used in the training sample. (Note: If given, this argument must be named.) |
na.action |
specify the action to be taken if |
main |
title |
name |
Variable names to be printed at the axis / into the diagonal. |
mar |
numerical vector of the form |
plot.matrix |
logical; if |
plot.control |
A list containing further arguments passed to the underlying
plot functions (and to |
... |
Further arguments passed to the classification |
Warnings such as ‘parameter “xyz” couldn't be set in high-level plot function’ are expected,
if making use of ...
.
Karsten Luebke, [email protected], Uwe Ligges, Irina Czogiel
for much more fine tuning see drawparti
library(MASS) data(iris) partimat(Species ~ ., data = iris, method = "lda") ## Not run: partimat(Species ~ ., data = iris, method = "lda", plot.matrix = TRUE, imageplot = FALSE) # takes some time ... ## End(Not run)
library(MASS) data(iris) partimat(Species ~ ., data = iris, method = "lda") ## Not run: partimat(Species ~ ., data = iris, method = "lda", plot.matrix = TRUE, imageplot = FALSE) # takes some time ... ## End(Not run)
For a given variable the posteriori probabilities of the classes given by a classification method are plotted. The variable need not be used for the actual classifcation.
plineplot(formula, data, method, x, col.wrong = "red", ylim = c(0, 1), loo = FALSE, mfrow, ...)
plineplot(formula, data, method, x, col.wrong = "red", ylim = c(0, 1), loo = FALSE, mfrow, ...)
formula |
formula of the form |
data |
Data frame from which variables specified in formula are preferentially to be taken. |
method |
character, name of classification function
(e.g. “ |
x |
variable that should be plotted. See examples. |
col.wrong |
color to use for missclassified objects. |
ylim |
|
loo |
logical, whether leave-one-out estimate is used for prediction |
mfrow |
number of rows and columns in the graphics device, see |
... |
further arguments passed to the underlying classification method or plot functions. |
The actual error rate.
Karsten Luebke, [email protected]
library(MASS) # The name of the variable can be used for x data(B3) plineplot(PHASEN ~ ., data = B3, method = "lda", x = "EWAJW", xlab = "EWAJW") # The plotted variable need not be in the data data(iris) iris2 <- iris[ , c(1,3,5)] plineplot(Species ~ ., data = iris2, method = "lda", x = iris[ , 4], xlab = "Petal.Width")
library(MASS) # The name of the variable can be used for x data(B3) plineplot(PHASEN ~ ., data = B3, method = "lda", x = "EWAJW", xlab = "EWAJW") # The plotted variable need not be in the data data(iris) iris2 <- iris[ , c(1,3,5)] plineplot(Species ~ ., data = iris2, method = "lda", x = iris[ , 4], xlab = "Petal.Width")
Visualizes the marginal probabilities of predictor variables given the class.
## S3 method for class 'NaiveBayes' plot(x, vars, n = 1000, legendplot = TRUE, lty, col, ylab = "Density", main = "Naive Bayes Plot", ...)
## S3 method for class 'NaiveBayes' plot(x, vars, n = 1000, legendplot = TRUE, lty, col, ylab = "Density", main = "Naive Bayes Plot", ...)
x |
an object of class |
vars |
variables to be plotted. If missing, all predictor variables are plotted. |
n |
number of points used to plot the density line. |
legendplot |
logical, whether to print a |
lty |
line type for different classes, defaults to the first |
col |
color for different classes, defaults to |
ylab |
label for y-axis. |
main |
title of the plots. |
... |
furhter arguments passed to the underlying plot functions. |
For metric variables the estimated density is plotted. For categorial variables mosaicplot is called.
Karsten Luebke, [email protected]
data(iris) mN <- NaiveBayes(Species ~ ., data = iris) plot(mN) mK <- NaiveBayes(Species ~ ., data = iris, usekernel = TRUE) plot(mK)
data(iris) mN <- NaiveBayes(Species ~ ., data = iris) plot(mN) mK <- NaiveBayes(Species ~ ., data = iris, usekernel = TRUE) plot(mK)
Barplot of information values to compare dicriminator of the transformed variables.
## S3 method for class 'woe' plot(x, type = c("IV", "woes"), ...)
## S3 method for class 'woe' plot(x, type = c("IV", "woes"), ...)
x |
An object of class |
type |
Character to specify the plot type, see below. Either |
... |
Further arguments to be passed to the barplot function. |
For type=="IV"
a barplot of information values for all transformed variables.
A thumb rule of interpretation is that Values above 0.3 are considered as strongly discrimative where values below 0.02 are considered to characterize unpredictive variables.
For type=="woes"
for each variable the relative frequencies of all transformed levels are plotted.
No value is returned.
Gero Szepannek
Good, I. (1950): Probability and the Weighting of Evidences. Charles Griffin, London.
Kullback, S. (1959): Information Theory and Statistics. Wiley, New York.
# see examples in ?woe
# see examples in ?woe
Classifies new observations using parameters determined by
the loclda
-function.
## S3 method for class 'loclda' predict(object, newdata, ...)
## S3 method for class 'loclda' predict(object, newdata, ...)
object |
Object of class |
newdata |
Data frame of cases to be classified. |
... |
Further arguments are ignored. |
A list with components:
class |
Vector (of class |
posterior |
Posterior probabilities for the classes.
For details of computation see |
all.zero |
Vector (of class |
Marc Zentgraf ([email protected]) and Karsten Luebke ([email protected])
data(B3) x <- loclda(PHASEN ~ ., data = B3, subset = 1:80) predict(x, B3[-(1:80),])
data(B3) x <- loclda(PHASEN ~ ., data = B3, subset = 1:80) predict(x, B3[-(1:80),])
Prediction of class membership and posterior probabilities in local models using pairwise variable selection.
## S3 method for class 'locpvs' predict(object,newdata, quick = FALSE, return.subclass.prediction = TRUE, ...)
## S3 method for class 'locpvs' predict(object,newdata, quick = FALSE, return.subclass.prediction = TRUE, ...)
object |
an object of class ‘ |
newdata |
a data frame or matrix containing new data. If not given the same datas as used for training the ‘ |
quick |
indicator (logical), whether a quick, but less accurate computation of posterior probabalities should be used or not. |
return.subclass.prediction |
indicator (logical), whether the returned object includes posterior probabilities for each date in each subclass |
... |
Further arguments are passed to underlying |
Posterior probabilities are predicted as if object is a standard ‘pvs
’-model with the subclasses as classes. Then the posterior probabalities are summed over all subclasses for each class. The class with the highest value becomes the prediction.
If “quick=FALSE
” the posterior probabilites for each case are computed using the pairwise coupling algorithm presented by Hastie, Tibshirani (1998). If “quick=FALSE
” a much quicker solution is used, which leads to less accurate posterior probabalities. In almost all cases it doesn't has a negative effect on the classification result.
a list with components:
class |
the predicted (upper) classes |
posterior |
posterior probabilities for the (upper) classes |
subclass.posteriors |
(only if “ |
Gero Szepannek, [email protected], Christian Neumann
Szepannek, G. and Weihs, C. (2006) Local Modelling in Classification on Different Feature Subspaces. In Advances in Data Mining., ed Perner, P., LNAI 4065, pp. 226-234. Springer, Heidelberg.
locpvs
for learning ‘locpvs
’-models and examples for applying this predict method, pvs
for pairwise variable selection without modeling subclasses, predict.pvs
for predicting ‘pvs
’-models
Classify multivariate observations in conjunction with meclight
and
lda
.
## S3 method for class 'meclight' predict(object, newdata,...)
## S3 method for class 'meclight' predict(object, newdata,...)
object |
Object of class |
newdata |
Data frame of cases to be classified or, if object has a formula, a data frame with columns of the same names as the variables used. A vector will be interpreted as a row vector. |
... |
currently ignored |
Classify multivariate observations in conjunction with meclight
and
lda
.
class |
The estimated class ( |
posterior |
Posterior probabilities for the classes. |
Karsten Luebke, [email protected]
Roehl, M.C., Weihs, C., and Theis, W. (2002): Direct Minimization in Multivariate Classification. Computational Statistics, 17, 29-46.
data(iris) meclight.obj <- meclight(Species ~ ., data = iris) predict(meclight.obj, iris)
data(iris) meclight.obj <- meclight(Species ~ ., data = iris) predict(meclight.obj, iris)
Computes the conditional a-posterior probabilities of a categorical class variable given independent predictor variables using the Bayes rule.
## S3 method for class 'NaiveBayes' predict(object, newdata, threshold = 0.001, ...)
## S3 method for class 'NaiveBayes' predict(object, newdata, threshold = 0.001, ...)
object |
An object of class |
newdata |
A dataframe with new predictors. |
threshold |
Value replacing cells with 0 probabilities. |
... |
passed to |
This implementation of Naive Bayes as well as this help is based on the code by David Meyer in the package e1071 but extended for kernel estimated densities. The standard naive Bayes classifier (at least this implementation) assumes independence of the predictor variables. For attributes with missing values, the corresponding table entries are omitted for prediction.
A list with the conditional a-posterior probabilities for each class and the estimated class are returned.
Karsten Luebke, [email protected]
NaiveBayes
,dkernel
naiveBayes
,qda
data(iris) m <- NaiveBayes(Species ~ ., data = iris) predict(m)
data(iris) m <- NaiveBayes(Species ~ ., data = iris) predict(m)
Prediction of class membership and posterior probabilities using pairwise variable selection.
## S3 method for class 'pvs' predict(object, newdata, quick = FALSE, detail = FALSE, ...)
## S3 method for class 'pvs' predict(object, newdata, quick = FALSE, detail = FALSE, ...)
object |
an object of class ‘ |
newdata |
a data frame or matrix containing new data. If not given the same datas as used for training the ‘ |
quick |
indicator (logical), whether a quick, but less accurate computation of posterior probabalities should be used or not. |
detail |
indicator (logical), whether the returned object includes additional information about the posterior probabilities for each date in each submodel. |
... |
Further arguments are passed to underlying |
If “quick=FALSE
” the posterior probabilites for each case are computed using the pairwise coupling algorithm presented by Hastie, Tibshirani (1998).
If “quick=FALSE
” a much quicker solution is used, which leads to less accurate posterior probabalities.
In almost all cases it doesn't has a negative effect on the classification result.
a list with components:
class |
the predicted classes |
posterior |
posterior probabilities for the classes |
details |
(only if “ |
Gero Szepannek, [email protected], Christian Neumann
Szepannek, G. and Weihs, C. (2006) Variable Selection for Classification of More than Two Classes Where the Data are Sparse. In From Data and Information Analysis to Kwnowledge Engineering., eds Spiliopolou, M., Kruse, R., Borgelt, C., Nuernberger, A. and Gaul, W. pp. 700-708. Springer, Heidelberg.
For more details and examples how to use this predict method, see pvs
.
Classifies new observations using parameters determined by
the rda
-function.
## S3 method for class 'rda' predict(object, newdata, posterior = TRUE, aslist = TRUE, ...)
## S3 method for class 'rda' predict(object, newdata, posterior = TRUE, aslist = TRUE, ...)
object |
Object of class |
newdata |
Data frame (or matrix) of cases to be classified. |
posterior |
Logical; indicates whether a matrix of posterior probabilites over all classes for each observation shall be returned in addition to classifications. |
aslist |
Logical; if |
... |
currently unused |
Depends on the value of argument ‘aslist
’:
Either a vector (of class factor
) of classifications
that (optionally) has an attribute ‘posterior
’
containing the posterior probability matrix, or
A list with elements ‘class
’ and ‘posterior
’.
Christian Röver, [email protected]
data(iris) x <- rda(Species ~ ., data = iris, gamma = 0.05, lambda = 0.2) predict(x, iris[, 1:4])
data(iris) x <- rda(Species ~ ., data = iris, gamma = 0.05, lambda = 0.2) predict(x, iris[, 1:4])
Classifies new observations using the sknn learned by
the sknn
-function.
## S3 method for class 'sknn' predict(object, newdata,...)
## S3 method for class 'sknn' predict(object, newdata,...)
object |
Object of class |
newdata |
Data frame (or matrix) of cases to be classified. |
... |
... |
A list with elements ‘class
’ and ‘posterior
’.
Karsten Luebke, [email protected]
data(iris) x <- sknn(Species ~ ., data = iris) predict(x, iris) x <- sknn(Species ~ ., gamma = 10, kn = 10, data = iris) predict(x, iris)
data(iris) x <- sknn(Species ~ ., data = iris) predict(x, iris) x <- sknn(Species ~ ., gamma = 10, kn = 10, data = iris) predict(x, iris)
Predicts new observations using the SVM learned by
the svmlight
-function.
## S3 method for class 'svmlight' predict(object, newdata, scal = TRUE, ...)
## S3 method for class 'svmlight' predict(object, newdata, scal = TRUE, ...)
object |
Object of class |
newdata |
Data frame (or matrix) of cases to be predicted. |
scal |
Logical, whether to scale membership values via |
... |
... |
If a classification is learned (type="C"
) in svmlight
a
list with elements ‘class
’ and ‘posterior
’ (scaled, if scal = TRUE
).
If a Regression is learned (type="R"
) in svmlight
the predicted values.
Karsten Luebke, [email protected]
## Not run: data(iris) x <- svmlight(Species ~ ., data = iris) predict(x, iris) ## End(Not run)
## Not run: data(iris) x <- svmlight(Species ~ ., data = iris) predict(x, iris) ## End(Not run)
Applies weight of evidence transform of factor variables for binary classification based on a model of class woe
.
## S3 method for class 'woe' predict(object, newdata, replace = TRUE, ...)
## S3 method for class 'woe' predict(object, newdata, replace = TRUE, ...)
object |
Object resulting from a call of |
newdata |
A matrix or data frame where WOE transform should be applied of the same dimension as the data used for training the |
replace |
Logical flag specifying whether the original factor variables should be kept in the output. |
... |
Currently not used. |
Data frame including the transformed numeric woe
variables.
Gero Szepannek
Good, I. (1950): Probability and the Weighting of Evidences. Charles Griffin, London.
# see examples in ?woe
# see examples in ?woe
Pairwise variable selection for numerical data, allowing the use of different classifiers and different variable selection methods.
pvs(x, ...) ## Default S3 method: pvs(x, grouping, prior=NULL, method="lda", vs.method=c("ks.test","stepclass","greedy.wilks"), niveau=0.05, fold=10, impr=0.1, direct="backward", out=FALSE, ...) ## S3 method for class 'formula' pvs(formula, data = NULL, ...)
pvs(x, ...) ## Default S3 method: pvs(x, grouping, prior=NULL, method="lda", vs.method=c("ks.test","stepclass","greedy.wilks"), niveau=0.05, fold=10, impr=0.1, direct="backward", out=FALSE, ...) ## S3 method for class 'formula' pvs(formula, data = NULL, ...)
x |
matrix or data frame containing the explanatory variables
(required, if |
formula |
A formula of the form |
data |
data matrix (rows=cases, columns=variables) |
grouping |
class indicator vector (a factor) |
prior |
prior probabilites for the classes. If not specified the prior probabilities will be set according to proportion in “grouping”. If specified the order of prior probabilities must be the same as in “grouping”. |
method |
character, name of classification function (e.g. “ |
vs.method |
character, name of variable selection method. Must be one of “ |
niveau |
used niveau for “ |
fold |
parameter for cross-validation, if “ |
impr |
least improvement of performance measure desired to include or exclude any variable (<=1), if “ |
direct |
direction of variable selection, if “ |
out |
indicator (logical) for textoutput during computation (slows down computation!), if “ |
... |
further parameters passed to classification function (‘ |
The classification “method” (e.g. ‘lda
’) must have its own
‘predict
’ method (like ‘predict.lda
’ for ‘lda
’)
returns a list with an element ‘posterior
’ containing the posterior probabilties. It must be able to deal with matrices as in method(x, grouping, ...)
.
Examples of such classification methods are ‘lda
’, ‘qda
’, ‘rda
’,
‘NaiveBayes
’ or ‘sknn
’.\
For the classification methods “svm
” and “randomForest
” there are special routines implemented, to make them work with ‘pvs
’ method even though their ‘predict
’ methods don't provide the demanded posteriors. However those two classfiers can not be used together with variable selection method “stepclass
”.
‘pvs
’ performs a variable selection using the selection method chosen in ‘vs.method
’ for each pair of classes in ‘x
’.
Then for each pair of classes a submodel using ‘method
’ is trained (using only the earlier selected variables for this class-pair).
If ‘method
’ is “ks.test
”, then for each variable the empirical distribution functions of the cases of both classes are compared via “ks.test
”. Only variables with a p-values below ‘niveau
’ are used for training the submodel for this pair of classes.
If ‘method
’ is “stepclass
” the variable selection is performed using the “stepclass
” method.
If ‘method
’ is “greedy.wilks
” the variable selection is performed using Wilk's lambda criterion.
An object of class ‘pvs
’ containing the following components:
classes |
the classes in grouping |
prior |
used prior probabilities |
method |
name of used classification function |
vs.method |
name of used function for variable selection |
submodels |
containing a list of submodels. For each pair of classes there is a list element being another list of 3 containing the class-pair of this submodel, the selected variables for the subspace of classes and the result of the trained classification function. |
call |
the (matched) function call |
Gero Szepannek, [email protected], Christian Neumann
Szepannek, G. and Weihs, C. (2006) Variable Selection for Classification of More than Two Classes Where the Data are Sparse. In From Data and Information Analysis to Kwnowledge Engineering., eds Spiliopolou, M., Kruse, R., Borgelt, C., Nuernberger, A. and Gaul, W. pp. 700-708. Springer, Heidelberg.
Szepannek, G. (2008): Different Subspace Classification - Datenanalyse, -interpretation, -visualisierung und Vorhersage in hochdimensionalen Raeumen, ISBN 978-3-8364-6302-7, vdm, Saarbruecken.
predict.pvs
for predicting ‘pvs
’ models and locpvs
for pairwisevariable selection in local models of several subclasses
## Example 1: learn an "lda" model on the waveform data using pairwise variable ## selection (pvs) using "ks.test" and compare it to using lda without pvs library("mlbench") trainset <- mlbench.waveform(300) pvsmodel <- pvs(trainset$x, trainset$classes, niveau=0.05) # default: using method="lda" ## short summary, showing the class-pairs of the submodels and the selected variables pvsmodel testset <- mlbench.waveform(500) ## prediction of the test data set: prediction <- predict(pvsmodel, testset$x) ## calculating the test error rate 1-sum(testset$classes==prediction$class)/length(testset$classes) ## Bayes error is 0.149 ## comparison to performance of simple lda ldamodel <- lda(trainset$x, trainset$classes) LDAprediction <- predict(ldamodel, testset$x) ## test error rate 1-sum(testset$classes==LDAprediction$class)/length(testset$classes) ## Example 2: learn a "qda" model with pvs on half of the Satellite dataset, ## using "ks.test" library("mlbench") data("Satellite") ## takes few seconds as exact KS tests are calculated here: model <- pvs(classes ~ ., Satellite[1:3218,], method="qda", vs.method="ks.test") ## short summary, showing the class-pairs of the submodels and the selected variables model ## now predict on the rest of the data set: ## pred <- predict(model,Satellite[3219:6435,]) # takes some time pred <- predict(model,Satellite[3219:6435,], quick=TRUE) # that's much quicker ## now you can look at the predicted classes: pred$class ## or the posterior probabilities: pred$posterior
## Example 1: learn an "lda" model on the waveform data using pairwise variable ## selection (pvs) using "ks.test" and compare it to using lda without pvs library("mlbench") trainset <- mlbench.waveform(300) pvsmodel <- pvs(trainset$x, trainset$classes, niveau=0.05) # default: using method="lda" ## short summary, showing the class-pairs of the submodels and the selected variables pvsmodel testset <- mlbench.waveform(500) ## prediction of the test data set: prediction <- predict(pvsmodel, testset$x) ## calculating the test error rate 1-sum(testset$classes==prediction$class)/length(testset$classes) ## Bayes error is 0.149 ## comparison to performance of simple lda ldamodel <- lda(trainset$x, trainset$classes) LDAprediction <- predict(ldamodel, testset$x) ## test error rate 1-sum(testset$classes==LDAprediction$class)/length(testset$classes) ## Example 2: learn a "qda" model with pvs on half of the Satellite dataset, ## using "ks.test" library("mlbench") data("Satellite") ## takes few seconds as exact KS tests are calculated here: model <- pvs(classes ~ ., Satellite[1:3218,], method="qda", vs.method="ks.test") ## short summary, showing the class-pairs of the submodels and the selected variables model ## now predict on the rest of the data set: ## pred <- predict(model,Satellite[3219:6435,]) # takes some time pred <- predict(model,Satellite[3219:6435,], quick=TRUE) # that's much quicker ## now you can look at the predicted classes: pred$class ## or the posterior probabilities: pred$posterior
For a 4 class discrimination problem the membership values of each class are visualized in a 3 dimensional barycentric coordinate system.
quadplot(e = NULL, f = NULL, g = NULL, h = NULL, angle = 75, scale.y = 0.6, label = 1:4, labelcol = rainbow(4), labelpch = 19, labelcex = 1.5, main = "", s3d.control = list(), simplex.control = list(), legend.control = list(), ...)
quadplot(e = NULL, f = NULL, g = NULL, h = NULL, angle = 75, scale.y = 0.6, label = 1:4, labelcol = rainbow(4), labelpch = 19, labelcex = 1.5, main = "", s3d.control = list(), simplex.control = list(), legend.control = list(), ...)
e |
either a matrix with 4 columns represanting the membership values or a vector with the membership values of the first class |
f |
vector with the membership values of the second class |
g |
vector with the membership values of the third class |
h |
vector with the membership values of the forth class |
angle |
angle between x and y axis |
scale.y |
scale of y axis related to x- and z axis |
label |
label for the classes |
labelcol |
colors to use for the labels |
labelpch |
|
labelcex |
|
main |
main title of the plot |
s3d.control |
a list with further arguments passed to the underlying
|
simplex.control |
a list with further arguments passed to the underlying function call that draws the barycentric coordinate system |
legend.control |
a list with further arguments passed to the underlying
function call that adds the |
... |
further arguments passed to the underlying |
The membership values are calculated with quadtrafo
and plotted
with scatterplot3d
.
A scatterplot3d
object.
Karsten Luebke, [email protected], and Uwe Ligges
Garczarek, Ursula Maria (2002): Classification rules in standardized partition spaces. Dissertation, University of Dortmund. URL http://hdl.handle.net/2003/2789
library("MASS") data(B3) opar <- par(mfrow = c(1, 2), pty = "s") posterior <- predict(lda(PHASEN ~ ., data = B3))$post s3d <- quadplot(posterior, col = rainbow(4)[B3$PHASEN], labelpch = 22:25, labelcex = 0.8, pch = (22:25)[apply(posterior, 1, which.max)], main = "LDA posterior assignments") quadlines(centerlines(4), sp = s3d, lty = "dashed") posterior <- predict(qda(PHASEN ~ ., data = B3))$post s3d <- quadplot(posterior, col = rainbow(4)[B3$PHASEN], labelpch = 22:25, labelcex = 0.8, pch = (22:25)[apply(posterior, 1, which.max)], main = "QDA posterior assignments") quadlines(centerlines(4), sp = s3d, lty = "dashed") par(opar)
library("MASS") data(B3) opar <- par(mfrow = c(1, 2), pty = "s") posterior <- predict(lda(PHASEN ~ ., data = B3))$post s3d <- quadplot(posterior, col = rainbow(4)[B3$PHASEN], labelpch = 22:25, labelcex = 0.8, pch = (22:25)[apply(posterior, 1, which.max)], main = "LDA posterior assignments") quadlines(centerlines(4), sp = s3d, lty = "dashed") posterior <- predict(qda(PHASEN ~ ., data = B3))$post s3d <- quadplot(posterior, col = rainbow(4)[B3$PHASEN], labelpch = 22:25, labelcex = 0.8, pch = (22:25)[apply(posterior, 1, which.max)], main = "QDA posterior assignments") quadlines(centerlines(4), sp = s3d, lty = "dashed") par(opar)
Builds a classification rule using regularized group covariance matrices that are supposed to be more robust against multicollinearity in the data.
rda(x, ...) ## Default S3 method: rda(x, grouping = NULL, prior = NULL, gamma = NA, lambda = NA, regularization = c(gamma = gamma, lambda = lambda), crossval = TRUE, fold = 10, train.fraction = 0.5, estimate.error = TRUE, output = FALSE, startsimplex = NULL, max.iter = 100, trafo = TRUE, simAnn = FALSE, schedule = 2, T.start = 0.1, halflife = 50, zero.temp = 0.01, alpha = 2, K = 100, ...) ## S3 method for class 'formula' rda(formula, data, ...)
rda(x, ...) ## Default S3 method: rda(x, grouping = NULL, prior = NULL, gamma = NA, lambda = NA, regularization = c(gamma = gamma, lambda = lambda), crossval = TRUE, fold = 10, train.fraction = 0.5, estimate.error = TRUE, output = FALSE, startsimplex = NULL, max.iter = 100, trafo = TRUE, simAnn = FALSE, schedule = 2, T.start = 0.1, halflife = 50, zero.temp = 0.01, alpha = 2, K = 100, ...) ## S3 method for class 'formula' rda(formula, data, ...)
x |
Matrix or data frame containing the explanatory variables
(required, if |
formula |
Formula of the form ‘ |
data |
A data frame (or matrix) containing the explanatory variables. |
grouping |
(Optional) a vector specifying the class for
each observation; if not specified, the first column of
‘ |
prior |
(Optional) prior probabilities for the classes.
Default: proportional to training sample sizes.
“ |
gamma , lambda , regularization
|
One or both of the rda-parameters may be fixed manually. Unspecified parameters are determined by minimizing the estimated error rate (see below). |
crossval |
Logical. If |
fold |
The number of Cross-Validation- or Bootstrap-samples to be drawn. |
train.fraction |
In case of Bootstrapping: the fraction of the data to be used for training in each Bootstrap-sample; the remainder is used to estimate the misclassification rate. |
estimate.error |
Logical. If |
output |
Logical flag to indicate whether text output during computation is desired. |
startsimplex |
(Optional) a starting simplex for the Nelder-Mead-minimization. |
max.iter |
Maximum number of iterations for Nelder-Mead. |
trafo |
Logical; indicates whether minimization is carrried out using transformed parameters. |
simAnn |
Logical; indicates whether Simulated Annealing shall be used. |
schedule |
Annealing schedule 1 or 2 (exponential or polynomial). |
T.start |
Starting temperature for Simulated Annealing. |
halflife |
Number of iterations until temperature is reduced to a half (schedule 1). |
zero.temp |
Temperature at which it is set to zero (schedule 1). |
alpha |
Power of temperature reduction (linear, quadratic, cubic,...) (schedule 2). |
K |
Number of iterations until temperature = 0 (schedule 2). |
... |
currently unused |
J.H. Friedman (see references below) suggested a method to fix
almost singular covariance matrices in discriminant analysis.
Basically, individual covariances as in QDA are used, but
depending on two parameters ( and
), these can be shifted towards a
diagonal matrix and/or the pooled covariance
matrix. For (
,
) it equals QDA,
for (
,
) it equals LDA.
You may fix these parameters at certain values or leave it to
the function to try to find “optimal” values. If one
parameter is given, the other one is determined using the
R-function ‘optimize
’. If no parameter is
given, both are determined numerically by a
Nelder-Mead-(Simplex-)algorithm with the option of using
Simulated Annealing.
The goal function to be minimized is the (estimated)
misclassification rate; the misclassification rate is estimated
either by Cross-Validation or by repeatedly dividing the data
into training- and test-sets (Boostrapping).
Warning: If these sets are small, optimization is expected to produce almost random results. We recommend to adjust the parameters manually in such a case. In all other cases it is recommended to run the optimization several times in order to see whether stable results are gained.
Since the Nelder-Mead-algorithm is actually intended for continuous functions while the observed error rate by its nature is discrete, a greater number of Boostrap-samples might improve the optimization by increasing the smoothness of the response surface (and, of course, by reducing variance and bias). If a set of parameters leads to singular covariance matrices, a penalty term is added to the misclassification rate which will hopefully help to maneuver back out of singularity (so do not worry about error rates greater than one during optimization).
A list of class rda
containing the following
components:
call |
The (matched) function call. |
regularization |
vector containing the two regularization parameters (gamma, lambda) |
classes |
the names of the classes |
prior |
the prior probabilities for the classes |
error.rate |
apparent error rate (if computation was not suppressed), and, if any optimization took place, the final (cross-validated or bootstrapped) error rate estimate as well. |
means |
Group means. |
covariances |
Array of group covariances. |
covpooled |
Pooled covariance. |
converged |
(Logical) indicator of convergence (only for Nelder-Mead). |
iter |
Number of iterations actually performed (only for Nelder-Mead). |
The explicit defintion of ,
and the resulting covariance estimates
is as follows:
The pooled covariance estimate is
given as well as the individual covariance estimates
for each group.
First, using , a convex combination of
these two is computed:
Then, another convex combination is constructed using the above estimate and a (scaled) identity matrix:
The factor
in front of the identity matrix I is the mean of the diagonal
elements of
, so it is
the mean variance of all
variables assuming the group
covariance
.
For the four extremes of (,
)
the covariance structure reduces to special cases:
(,
):
QDA - individual covariance for each group.
(,
):
LDA - a common covariance matrix.
(,
):
Conditional independent variables - similar to Naive Bayes,
but variable variances within group (main diagonal elements)
are equal.
(,
):
Classification using euclidean distance - as in previous case,
but variances are the same for all groups. Objects are assigned
to group with nearest mean.
Christian Röver, [email protected]
Friedman, J.H. (1989): Regularized Discriminant Analysis. In: Journal of the American Statistical Association 84, 165-175.
Press, W.H., Flannery, B.P., Teukolsky, S.A., Vetterling, W.T. (1992): Numerical Recipes in C. Cambridge: Cambridge University Press.
data(iris) x <- rda(Species ~ ., data = iris, gamma = 0.05, lambda = 0.2) predict(x, iris)
data(iris) x <- rda(Species ~ ., data = iris, gamma = 0.05, lambda = 0.2) predict(x, iris)
Plotting method for objects of class
EDAM
or som
.
shardsplot(object, plot.type = c("eight", "four", "points", "n"), expand = 1, stck = TRUE, grd = FALSE, standardize = FALSE, data.or = NA, label = FALSE, plot = TRUE, classes = 0, vertices = TRUE, classcolors = "rainbow", wghts = 0, xlab = "Dimension 1", ylab = "Dimension 2", xaxs = "i", yaxs = "i", plot.data.column = NA, log.classes = FALSE, revert.colors = FALSE, ...) level_shardsplot(object, par.names, rows = 1:NCOL(object$data), centers = rep(NA, length(par.names)), class.labels = NA, revert.colors = rep(FALSE, length(par.names)), log.classes = rep(FALSE, length(par.names)), centeredcolors = colorRamp(c("red", "white", "blue")), mfrow = c(2, 2), plot.type = c("eight", "four", "points", "n"), expand = 1, stck = TRUE, grd = FALSE, standardize = FALSE, label = FALSE, plot = TRUE, vertices = TRUE, classcolors = "topo", wghts = 0, xlab = "Dimension 1", ylab = "Dimension 2", xaxs = "i", yaxs = "i", ...) ## S3 method for class 'EDAM' plot(...)
shardsplot(object, plot.type = c("eight", "four", "points", "n"), expand = 1, stck = TRUE, grd = FALSE, standardize = FALSE, data.or = NA, label = FALSE, plot = TRUE, classes = 0, vertices = TRUE, classcolors = "rainbow", wghts = 0, xlab = "Dimension 1", ylab = "Dimension 2", xaxs = "i", yaxs = "i", plot.data.column = NA, log.classes = FALSE, revert.colors = FALSE, ...) level_shardsplot(object, par.names, rows = 1:NCOL(object$data), centers = rep(NA, length(par.names)), class.labels = NA, revert.colors = rep(FALSE, length(par.names)), log.classes = rep(FALSE, length(par.names)), centeredcolors = colorRamp(c("red", "white", "blue")), mfrow = c(2, 2), plot.type = c("eight", "four", "points", "n"), expand = 1, stck = TRUE, grd = FALSE, standardize = FALSE, label = FALSE, plot = TRUE, vertices = TRUE, classcolors = "topo", wghts = 0, xlab = "Dimension 1", ylab = "Dimension 2", xaxs = "i", yaxs = "i", ...) ## S3 method for class 'EDAM' plot(...)
object |
an object of class |
par.names |
names used to lable the data columns |
rows |
vector with indices of colomns to be plotted |
centers |
vector of type numeric defining the class centers for the data. NA if data does not have a center. |
class.labels |
matrix of type text and |
centeredcolors |
colors to represent the classes with a central value |
mfrow |
parameter defining number of plots on a page. see |
plot.type |
a character giving the shape of the shards.
Available are “ |
expand |
a numeric giving the relative expansion of the axes.
A value greater than one implies smaller shards. Varying |
stck |
logical. If |
grd |
logical. If |
standardize |
logical. If |
data.or |
original data and classes where the first k columns are variables and the (k+1)-th column are the classes.
If defined and class of |
label |
logical. If |
plot |
logical. If |
classes |
a vector giving alternative classes for objects of class |
vertices |
logical. If |
classcolors |
colors to represent the classes, or a character giving the colorscale for the classes.
Since now available scales are |
wghts |
an optional vector of length k giving relative weights of the variables
in computing Euclidean distances. Meaningless if |
xaxs |
see |
yaxs |
see |
xlab |
see |
ylab |
see |
... |
further plotting parameters. |
plot.data.column |
column index defining from |
log.classes |
boolean indicating that the data should be transformed with the logarithmic function before calculating the cell coloring |
revert.colors |
boolean indicating that the colorscale should be reverted. |
level_shardsplot
uses multiple shardsplot
representations of a SOM in order to depict how
the data used to calculate the SOM is distribution across the map.
Two representations are possible for the data, first with a single color ramp from the minimum
value to the maximum value. The second representation is usefull for data for which a basic
value exists some where between minimum and maximum for which a special color representation should be used
(e.g. 0 is indicated with white).
If plot.type
is “four
” or “eight
”, the shape of each shard depends
on the relative distances of the actual object
or codebook to its up to eight neighbours. If plot.type
is “eight
”, shardsplot
corresponds to the representation method
suggested by Cottrell and de Bodt (1996) for Kohonen Self-Organizing Maps.
If plot.type
is “points
”, shardsplot
reduces to a usual scatter plot.
The following list is (invisibly) returned:
Cells.ex |
the images of the visualized data |
S |
the criterion of the visualization |
Nils Raabe, level_shardsplot
function from Dominik Reusser
Cottrell, M., and de Bodt, E. (1996). A Kohonen Map Representation to Avoid Misleading Interpretations. Proceedings of the European Symposium on Atrificial Neural Networks, D-Facto, pp. 103–110.
# Compute clusters and an Eight Directions Arranged Map for the # country data. Plotting the result. data(countries) logcount <- log(countries[,2:7]) sdlogcount <- apply(logcount, 2, sd) logstand <- t((t(logcount) / sdlogcount) * c(1,2,6,5,5,3)) cclasses <- cutree(hclust(dist(logstand)), k = 6) countryEDAM <- EDAM(logstand, classes = cclasses, sa = FALSE, iter.max = 10, random = FALSE) plot(countryEDAM, vertices = FALSE, label = TRUE, stck = FALSE) # Compute and plot a Self-Organizing Map for the iris data data(iris) library(som) irissom <- som(iris[,1:4], xdim = 6, ydim = 14) shardsplot(irissom, data.or = iris, vertices = FALSE) opar <- par(xpd = NA) legend(7.5, 6.1, col = rainbow(3), xjust = 0.5, yjust = 0, legend = levels(iris[, 5]), pch = 16, horiz = TRUE) par(opar) level_shardsplot(irissom, par.names = names(iris), class.labels = NA, mfrow = c(2,2))
# Compute clusters and an Eight Directions Arranged Map for the # country data. Plotting the result. data(countries) logcount <- log(countries[,2:7]) sdlogcount <- apply(logcount, 2, sd) logstand <- t((t(logcount) / sdlogcount) * c(1,2,6,5,5,3)) cclasses <- cutree(hclust(dist(logstand)), k = 6) countryEDAM <- EDAM(logstand, classes = cclasses, sa = FALSE, iter.max = 10, random = FALSE) plot(countryEDAM, vertices = FALSE, label = TRUE, stck = FALSE) # Compute and plot a Self-Organizing Map for the iris data data(iris) library(som) irissom <- som(iris[,1:4], xdim = 6, ydim = 14) shardsplot(irissom, data.or = iris, vertices = FALSE) opar <- par(xpd = NA) legend(7.5, 6.1, col = rainbow(3), xjust = 0.5, yjust = 0, legend = levels(iris[, 5]), pch = 16, horiz = TRUE) par(opar) level_shardsplot(irissom, par.names = names(iris), class.labels = NA, mfrow = c(2,2))
Function for simple knn classification.
sknn(x, ...) ## Default S3 method: sknn(x, grouping, kn = 3, gamma=0, ...) ## S3 method for class 'data.frame' sknn(x, ...) ## S3 method for class 'matrix' sknn(x, grouping, ..., subset, na.action = na.fail) ## S3 method for class 'formula' sknn(formula, data = NULL, ..., subset, na.action = na.fail)
sknn(x, ...) ## Default S3 method: sknn(x, grouping, kn = 3, gamma=0, ...) ## S3 method for class 'data.frame' sknn(x, ...) ## S3 method for class 'matrix' sknn(x, grouping, ..., subset, na.action = na.fail) ## S3 method for class 'formula' sknn(formula, data = NULL, ..., subset, na.action = na.fail)
x |
matrix or data frame containing the explanatory variables
(required, if |
grouping |
factor specifying the class for each observation
(required, if |
formula |
formula of the form |
data |
Data frame from which variables specified in |
kn |
Number of nearest neighbours to use. |
gamma |
gamma parameter for rbf in knn. If |
subset |
An index vector specifying the cases to be used in the training sample. (Note: If given, this argument must be named.) |
na.action |
specify the action to be taken if |
... |
currently unused |
If gamma>0
an gaussian like density is used to weight the classes of the kn
nearest neighbors.
weight=exp(-gamma*distance)
. This is similar to an rbf kernel.
If the distances are large it may be useful to scale
the data first.
A list containing the function call.
Karsten Luebke, [email protected]
data(iris) x <- sknn(Species ~ ., data = iris) x <- sknn(Species ~ ., gamma = 4, data = iris)
data(iris) x <- sknn(Species ~ ., data = iris) x <- sknn(Species ~ ., gamma = 4, data = iris)
Forward/backward variable selection for classification using any specified
classification function and selecting by estimated classification performance measure from ucpm
.
stepclass(x, ...) ## Default S3 method: stepclass(x, grouping, method, improvement = 0.05, maxvar = Inf, start.vars = NULL, direction = c("both", "forward", "backward"), criterion = "CR", fold = 10, cv.groups = NULL, output = TRUE, min1var = TRUE, ...) ## S3 method for class 'formula' stepclass(formula, data, method, ...)
stepclass(x, ...) ## Default S3 method: stepclass(x, grouping, method, improvement = 0.05, maxvar = Inf, start.vars = NULL, direction = c("both", "forward", "backward"), criterion = "CR", fold = 10, cv.groups = NULL, output = TRUE, min1var = TRUE, ...) ## S3 method for class 'formula' stepclass(formula, data, method, ...)
x |
matrix or data frame containing the explanatory variables
(required, if |
formula |
A formula of the form |
data |
data matrix (rows=cases, columns=variables) |
grouping |
class indicator vector (a factor) |
method |
character, name of classification function
(e.g. “ |
improvement |
least improvement of performance measure desired to include or exclude any variable (<=1) |
maxvar |
maximum number of variables in model |
start.vars |
set variables to start with (indices or names).
Default is no variables if ‘ |
direction |
“ |
criterion |
performance measure taken from |
fold |
parameter for cross-validation; omitted if ‘ |
cv.groups |
vector of group indicators for cross-validation. By default assigned automatically. |
output |
indicator (logical) for textoutput during computation (slows down computation!) |
min1var |
logical, whether to include at least one variable in the model, even if the prior itself already is a reasonable model. |
... |
further parameters passed to classification function (‘ |
The classification “method” (e.g. ‘lda
’) must have its own
‘predict
’ method (like ‘predict.lda
’ for ‘lda
’)
that either returns a matrix of posterior probabilities or a list with an element ‘posterior
’ containing
that matrix instead. It must be able to deal with matrices as in method(x, grouping, ...)
Then a stepwise variable selection is performed.
The initial model is defined by the provided starting variables;
in every step new models are generated by including every single
variable that is not in the model, and by excluding every single
variable that is in the model. The resulting performance measure for these
models are estimated (by cross-validation), and if the maximum value of the chosen
criterion is better than ‘improvement
’ plus the value so far, the
corresponding variable is in- or excluded. The procedure stops, if
the new best value is not good enough, or if the specified maximum
number of variables is reached.
If ‘direction
’ is “forward
”, the model is only extended (by including
further variables), if ‘direction
’ is “backward
”, the model is only
reduced (by excluding variables from the model).
An object of class ‘stepclass
’ containing the following components:
call |
the (matched) function call. |
method |
name of classification function used (e.g. “ |
start.variables |
vector of starting variables. |
process |
data frame showing selection process (included/excluded variables and performance measure). |
model |
the final model: data frame with 2 columns; indices and names of variables. |
perfomance.measure |
value of the criterion used by |
formula |
formula of the form ‘ |
Christian Röver, [email protected], Irina Czogiel
step
, stepAIC
,
and greedy.wilks
for stepwise variable selection according to Wilk's lambda
data(iris) library(MASS) iris.d <- iris[,1:4] # the data iris.c <- iris[,5] # the classes sc_obj <- stepclass(iris.d, iris.c, "lda", start.vars = "Sepal.Width") sc_obj plot(sc_obj) ## or using formulas: sc_obj <- stepclass(Species ~ ., data = iris, method = "qda", start.vars = "Sepal.Width", criterion = "AS") # same as above sc_obj ## now you can say stuff like ## qda(sc_obj$formula, data = B3)
data(iris) library(MASS) iris.d <- iris[,1:4] # the data iris.c <- iris[,5] # the classes sc_obj <- stepclass(iris.d, iris.c, "lda", start.vars = "Sepal.Width") sc_obj plot(sc_obj) ## or using formulas: sc_obj <- stepclass(Species ~ ., data = iris, method = "qda", start.vars = "Sepal.Width", criterion = "AS") # same as above sc_obj ## now you can say stuff like ## qda(sc_obj$formula, data = B3)
Function to call SVMlight from R for classification. Multiple group classification is done with the one-against-rest partition of data.
svmlight(x, ...) ## Default S3 method: svmlight(x, grouping, temp.dir = NULL, pathsvm = NULL, del = TRUE, type = "C", class.type = "oaa", svm.options = NULL, prior = NULL, out = FALSE, ...) ## S3 method for class 'data.frame' svmlight(x, ...) ## S3 method for class 'matrix' svmlight(x, grouping, ..., subset, na.action = na.fail) ## S3 method for class 'formula' svmlight(formula, data = NULL, ..., subset, na.action = na.fail)
svmlight(x, ...) ## Default S3 method: svmlight(x, grouping, temp.dir = NULL, pathsvm = NULL, del = TRUE, type = "C", class.type = "oaa", svm.options = NULL, prior = NULL, out = FALSE, ...) ## S3 method for class 'data.frame' svmlight(x, ...) ## S3 method for class 'matrix' svmlight(x, grouping, ..., subset, na.action = na.fail) ## S3 method for class 'formula' svmlight(formula, data = NULL, ..., subset, na.action = na.fail)
x |
matrix or data frame containing the explanatory variables
(required, if |
grouping |
factor specifying the class for each observation
(required, if |
formula |
formula of the form |
data |
Data frame from which variables specified in |
temp.dir |
directory for temporary files. |
pathsvm |
Path to SVMlight binaries (required, if path is unknown by the OS). |
del |
Logical: whether to delete temporary files |
type |
Perform |
class.type |
Multiclass scheme to use. See details. |
svm.options |
Optional parameters to SVMlight. For further details see: “How to use” on http://svmlight.joachims.org/. |
prior |
A Priori probabilities of classes. |
out |
Logical: whether SVMlight output ahouild be printed on console (only for Windows OS.) |
subset |
An index vector specifying the cases to be used in the training sample. (Note: If given, this argument must be named.) |
na.action |
specify the action to be taken if |
... |
currently unused |
Function to call SVMlight from R for classification (type="C"
).
SVMlight is an implementation of Vapnik's Support Vector Machine. It
is written in C by Thorsten Joachims. On the homepage (see below) the
source-code and several binaries for SVMlight are available. If more
then two classes are given the SVM is learned by the one-against-all
scheme (class.type="oaa"
). That means that each class is trained against the other K-1
classes. The class with the highest decision function in the SVM
wins. So K SVMs have to be learned.
If class.type="oao"
each class is tested against every other and the final class is elected
by a majority vote.
If type="R"
a SVM Regression is performed.
A list containing the function call and the result of SVMlight.
SVMlight (http://svmlight.joachims.org/) must be installed before using this interface.
Karsten Luebke, [email protected], Andrea Preusser
## Not run: ## Only works if the svmlight binaries are in the path. data(iris) x <- svmlight(Species ~ ., data = iris) ## Using RBF-Kernel with gamma=0.1: data(B3) x <- svmlight(PHASEN ~ ., data = B3, svm.options = "-t 2 -g 0.1") ## End(Not run)
## Not run: ## Only works if the svmlight binaries are in the path. data(iris) x <- svmlight(Species ~ ., data = iris) ## Using RBF-Kernel with gamma=0.1: data(B3) x <- svmlight(PHASEN ~ ., data = B3, svm.options = "-t 2 -g 0.1") ## End(Not run)
Function to add a frame to an existing (barycentric) plot.
triframe(label = 1:3, label.col = 1, cex = 1, ...)
triframe(label = 1:3, label.col = 1, cex = 1, ...)
label |
labels for the three corners of the plot. |
label.col |
text color for labels. |
cex |
Magnification factor for label text relative to the default. |
... |
Further graphical parameters passed to |
Christian Röver, [email protected]
triplot
, trilines
, trigrid
, centerlines
triplot(grid = TRUE, frame = FALSE) # plot without frame some.triangle <- rbind(c(0, 0.65, 0.35), c(0.53, 0.47, 0), c(0.72, 0, 0.28))[c(1:3, 1), ] trilines(some.triangle, col = "red", pch = 16, type = "b") triframe(label = c("left", "top", "right"), col = "blue", label.col = "green3") # frame on top of points
triplot(grid = TRUE, frame = FALSE) # plot without frame some.triangle <- rbind(c(0, 0.65, 0.35), c(0.53, 0.47, 0), c(0.72, 0, 0.28))[c(1:3, 1), ] trilines(some.triangle, col = "red", pch = 16, type = "b") triframe(label = c("left", "top", "right"), col = "blue", label.col = "green3") # frame on top of points
Function to add a grid to an existing (barycentric) plot.
trigrid(x = seq(0.1, 0.9, by = 0.1), y = NULL, z = NULL, lty = "dashed", col = "grey", ...)
trigrid(x = seq(0.1, 0.9, by = 0.1), y = NULL, z = NULL, lty = "dashed", col = "grey", ...)
x |
Values along which to draw grid lines for first dimension
(or all dimensions if |
y |
Grid lines for second dimension. |
z |
Grid lines for third dimension. |
lty |
Line type (see |
col |
Line colour (see |
... |
Further graphical parameters passed to |
Grid lines illustrate the set of points for which one of the dimensions is held constant; e.g. horizontal lines contain all points with a certain value y for the second dimension, connecting the two extreme points (0,y,1-y) and (1-y,y,0).
Grids may be designed more flexible than with triplot
's grid
option.
Christian Röver, [email protected]
triplot
, trilines
, triframe
, centerlines
triplot(grid = FALSE) trigrid(c(1/3, 0.5)) # same grid for all 3 dimensions triplot(grid = c(1/3, 0.5)) # (same effect) triplot(grid = FALSE) # different grids for all dimensions: trigrid(x = 1/3, y = 0.5, z = seq(0.2, 0.8, by=0.2)) triplot(grid = FALSE) # grid for third dimension only: trigrid(x = NA, y = NA, z = c(0.1, 0.2, 0.4, 0.8))
triplot(grid = FALSE) trigrid(c(1/3, 0.5)) # same grid for all 3 dimensions triplot(grid = c(1/3, 0.5)) # (same effect) triplot(grid = FALSE) # different grids for all dimensions: trigrid(x = 1/3, y = 0.5, z = seq(0.2, 0.8, by=0.2)) triplot(grid = FALSE) # grid for third dimension only: trigrid(x = NA, y = NA, z = c(0.1, 0.2, 0.4, 0.8))
Function to add a point and the corresponding perpendicular lines to all three sides to an existing (barycentric) plot.
triperplines(x, y = NULL, z = NULL, lcol = "red", pch = 17, ...)
triperplines(x, y = NULL, z = NULL, lcol = "red", pch = 17, ...)
x |
fraction of first component
OR 3-element vector (for all three components, omitting |
y |
(optional) fraction of second component. |
z |
(optional) fraction of third component. |
lcol |
line color |
pch |
plotting character. |
... |
Adds a (single!) point and lines to an existing plot (generated by triplot
).
The lines originate from the point and run (perpendicular) towards all three sides.
The lengths (and proportions) of these lines are identical to those of x
, y
and z
.
a 2-column-matrix containing plot coordinates.
Christian Röver, [email protected]
triplot
, tripoints
, trilines
, tritrafo
triplot() # empty plot triperplines(1/2, 1/3, 1/6)
triplot() # empty plot triperplines(1/2, 1/3, 1/6)
Function to produce triangular (barycentric) plots illustrating proportions of 3 components, e.g. discrete 3D-distributions or mixture fractions that sum up to 1.
triplot(x = NULL, y = NULL, z = NULL, main = "", frame = TRUE, label = 1:3, grid = seq(0.1, 0.9, by = 0.1), center = FALSE, set.par = TRUE, ...)
triplot(x = NULL, y = NULL, z = NULL, main = "", frame = TRUE, label = 1:3, grid = seq(0.1, 0.9, by = 0.1), center = FALSE, set.par = TRUE, ...)
x |
Vector of fractions of first component
OR 3-column matrix containing all three components (omitting |
y |
(Optional) vector of fractions of second component. |
z |
(Optional) vector of fractions of third component. |
main |
Main title |
frame |
Controls whether a frame (triangle) and labels are drawn. |
label |
(Character) vector of labels for the three corners. |
grid |
Values along which grid lines are to be drawn (or |
center |
Controls whether or not to draw centerlines at which there is a
‘tie’ between any two dimensions (see also |
set.par |
Controls whether graphical parameter |
... |
Further graphical parameters passed to |
The barycentric plot illustrates the set of points (x,y,z) with x,y,z between 0 and 1 and x+y+z=1; that is, the triangle spanned by (1,0,0), (0,1,0) and (0,0,1) in 3-dimensional space. The three dimensions x, y and z correspond to lower left, upper and lower right corner of the plot. The greater the share of x in the proportion, the closer the point is to the lower left corner; Points on the opposite (upper right) side have a zero x-fraction. The grid lines show the points at which one dimension is held constant, horizontal lines for example contain points with a constant second dimension.
Christian Röver, [email protected]
tripoints
, trilines
, triperplines
, trigrid
,
triframe
for points, lines and layout, tritrafo
for placing labels,
and quadplot
for the same in 4 dimensions.
# illustrating probabilities: triplot(label = c("1, 2 or 3", "4 or 5", "6"), main = "die rolls: probabilities", pch = 17) triperplines(1/2, 1/3, 1/6) # expected... triplot(1/2, 1/3, 1/6, label = c("1, 2 or 3", "4 or 5", "6"), main = "die rolls: expected and observed frequencies", pch = 17) # ... and observed frequencies. dierolls <- matrix(sample(1:3, size = 50*20, prob = c(1/2, 1/3, 1/6), replace = TRUE), ncol = 50) frequencies <- t(apply(dierolls, 1, function(x)(summary(factor(x, levels = 1:3)))) / 50) tripoints(frequencies) # LDA classification posterior: data(iris) require(MASS) pred <- predict(lda(Species ~ ., data = iris),iris) plotchar <- rep(1,150) plotchar[pred$class != iris$Species] <- 19 triplot(pred$posterior, label = colnames(pred$posterior), main = "LDA posterior assignments", center = TRUE, pch = plotchar, col = rep(c("blue", "green3", "red"), rep(50, 3)), grid = TRUE) legend(x = -0.6, y = 0.7, col = c("blue", "green3", "red"), pch = 15, legend = colnames(pred$posterior))
# illustrating probabilities: triplot(label = c("1, 2 or 3", "4 or 5", "6"), main = "die rolls: probabilities", pch = 17) triperplines(1/2, 1/3, 1/6) # expected... triplot(1/2, 1/3, 1/6, label = c("1, 2 or 3", "4 or 5", "6"), main = "die rolls: expected and observed frequencies", pch = 17) # ... and observed frequencies. dierolls <- matrix(sample(1:3, size = 50*20, prob = c(1/2, 1/3, 1/6), replace = TRUE), ncol = 50) frequencies <- t(apply(dierolls, 1, function(x)(summary(factor(x, levels = 1:3)))) / 50) tripoints(frequencies) # LDA classification posterior: data(iris) require(MASS) pred <- predict(lda(Species ~ ., data = iris),iris) plotchar <- rep(1,150) plotchar[pred$class != iris$Species] <- 19 triplot(pred$posterior, label = colnames(pred$posterior), main = "LDA posterior assignments", center = TRUE, pch = plotchar, col = rep(c("blue", "green3", "red"), rep(50, 3)), grid = TRUE) legend(x = -0.6, y = 0.7, col = c("blue", "green3", "red"), pch = 15, legend = colnames(pred$posterior))
Function to add points or lines to an existing (barycentric) plot.
tripoints(x, y = NULL, z = NULL, ...) trilines(x, y = NULL, z = NULL, ...)
tripoints(x, y = NULL, z = NULL, ...) trilines(x, y = NULL, z = NULL, ...)
x |
Vector of fractions of first component
OR 3-column matrix containing all three components (omitting |
y |
(optional) vector of fractions of second component. |
z |
(optional) vector of fractions of third component. |
... |
Adds points or lines to an existing plot (generated by triplot
).
Christian Röver, [email protected]
points
, lines
, triplot
, tritrafo
, centerlines
triplot() # empty plot tripoints(0.1, 0.2, 0.7) # a point tripoints(c(0.2, 0.6), c(0.3, 0.3), c(0.5, 0.1), pch = c(2, 6)) # two points trilines(c(0.1, 0.6), c(0.2, 0.3), c(0.7, 0.1), col = "blue", lty = "dotted") # a line trilines(centerlines(3))
triplot() # empty plot tripoints(0.1, 0.2, 0.7) # a point tripoints(c(0.2, 0.6), c(0.3, 0.3), c(0.5, 0.1), pch = c(2, 6)) # two points trilines(c(0.1, 0.6), c(0.2, 0.3), c(0.7, 0.1), col = "blue", lty = "dotted") # a line trilines(centerlines(3))
Function to carry out the transformation into 2D space
for triplot
, trilines
etc.
tritrafo(x, y = NULL, z = NULL, check = TRUE, tolerance = 0.0001)
tritrafo(x, y = NULL, z = NULL, check = TRUE, tolerance = 0.0001)
x |
Vector of fractions of first component
OR 3-column matrix containing all three components (omitting |
y |
(optional) vector of fractions of second component. |
z |
(optional) vector of fractions of third component. |
check |
if |
tolerance |
tolerance for above sum check. |
Projects the mixture given by x
, y
, and z
with x
, y
, z
between one and zero and x+y+z=1
into
a two-dimensional space.
For further details see triplot
.
A matrix with two columns corresponding to the two dimensions.
Christian Röver, [email protected]
triplot
, tripoints
, trilines
, trigrid
tritrafo(0.1, 0.2, 0.7) tritrafo(0.1, 0.2, 0.6) # warning triplot() points(tritrafo(0.1, 0.2, 0.7), col="red") tripoints(0.1, 0.2, 0.7, col="green") # the same tritrafo(c(0.1,0.2), c(0.3,0.4), c(0.6,0.4)) tritrafo(diag(3)) point <- c(0.25,0.6,0.15) triplot(point, pch=16) text(tritrafo(point), "(0.25, 0.60, 0.15)", adj=c(0.5,2)) # add a label
tritrafo(0.1, 0.2, 0.7) tritrafo(0.1, 0.2, 0.6) # warning triplot() points(tritrafo(0.1, 0.2, 0.7), col="red") tripoints(0.1, 0.2, 0.7, col="green") # the same tritrafo(c(0.1,0.2), c(0.3,0.4), c(0.6,0.4)) tritrafo(diag(3)) point <- c(0.25,0.6,0.15) triplot(point, pch=16) text(tritrafo(point), "(0.25, 0.60, 0.15)", adj=c(0.5,2)) # add a label
Function to calculate the Correctness Rate, the Accuracy, the Ability to Seperate and the Confidence of a classification rule.
ucpm(m, tc, ec = NULL)
ucpm(m, tc, ec = NULL)
m |
matrix of (scaled) membership values |
tc |
vector of true classes |
ec |
vector of estimated classes (only required if scaled membership values are used) |
The correctness rate is the estimator for the correctness of a classification rule (1-error rate).
The accuracy is based on the euclidean distances between (scaled) membership vectors and the vectors representing the true class corner. These distances are standardized so that a measure of 1 is achieved if all vectors lie in the correct corners and 0 if they all lie in the center.
Analougously, the ability to seperate is based on the distances between (scaled) membership vectors and the vector representing the corresponding assigned class corner.
The confidence is the mean of the membership values of the assigned classes.
A list with elements:
CR |
Correctness Rate |
AC |
Accuracy |
AS |
Ability to Seperate |
CF |
Confidence |
CFvec |
Confidence for each (true) class |
Karsten Luebke, [email protected]
Garczarek, Ursula Maria (2002): Classification rules in standardized partition spaces. Dissertation, University of Dortmund. URL http://hdl.handle.net/2003/2789
library(MASS) data(iris) ucpm(predict(lda(Species ~ ., data = iris))$posterior, iris$Species)
library(MASS) data(iris) ucpm(predict(lda(Species ~ ., data = iris))$posterior, iris$Species)
Computes weight of evidence transform of factor variables for binary classification.
woe(x, ...) ## Default S3 method: woe(x, grouping, weights = NULL, zeroadj = 0, ids = NULL, appont = TRUE, ...) ## S3 method for class 'formula' woe(formula, data = NULL, weights = NULL, ...)
woe(x, ...) ## Default S3 method: woe(x, grouping, weights = NULL, zeroadj = 0, ids = NULL, appont = TRUE, ...) ## S3 method for class 'formula' woe(formula, data = NULL, weights = NULL, ...)
x |
A matrix or data frame containing the explanatory variables. |
grouping |
A factor specifying the binary class for each observation. |
formula |
A formula of the form |
data |
Data frame from which variables specified in formula are to be taken. |
weights |
Vector with observation weights. For call |
zeroadj |
Additive constant to be added for a level with 0 observations in a class. |
ids |
Vector of either indices or variable names that specifies the variables to be transformed. |
appont |
Application on training data: logical indicating whether the transformed values for the training data should be returned by recursive calling of |
... |
For |
To each factor level a numeric value
is assigned where 1 and 2 denote the class labels. The WOE transform is motivated for subsequent modelling by logistic regression. Note that the frequencies of the classes should be investigated before. Information values heuristically quantify the discriminatory power of a variable by
.
Returns an object of class woe that can be applied to new data.
woe |
WOE coefficients for factor2numeric transformation of each (specified) variable. |
IV |
Vector of information values of all transformed variables. |
newx |
Data frame of transformed data if |
Gero Szepannek
Good, I. (1950): Probability and the Weighting of Evidences. Charles Griffin, London.
Kullback, S. (1959): Information Theory and Statistics. Wiley, New York.
## load German credit data data("GermanCredit") ## training/validation split train <- sample(nrow(GermanCredit), round(0.6*nrow(GermanCredit))) woemodel <- woe(credit_risk~., data = GermanCredit[train,], zeroadj=0.5, applyontrain = TRUE) woemodel ## plot variable information values and woes plot(woemodel) plot(woemodel, type = "woes") ## apply woes traindata <- predict(woemodel, GermanCredit[train,], replace = TRUE) str(traindata) ## fit logistic regression model glmodel <- glm(credit_risk~., traindata, family=binomial) summary(glmodel) pred.trn <- predict(glmodel, traindata, type = "response") ## predict validation data validata <- predict(woemodel, GermanCredit[-train,], replace = TRUE) pred.val <- predict(glmodel, validata, type = "response")
## load German credit data data("GermanCredit") ## training/validation split train <- sample(nrow(GermanCredit), round(0.6*nrow(GermanCredit))) woemodel <- woe(credit_risk~., data = GermanCredit[train,], zeroadj=0.5, applyontrain = TRUE) woemodel ## plot variable information values and woes plot(woemodel) plot(woemodel, type = "woes") ## apply woes traindata <- predict(woemodel, GermanCredit[train,], replace = TRUE) str(traindata) ## fit logistic regression model glmodel <- glm(credit_risk~., traindata, family=binomial) summary(glmodel) pred.trn <- predict(glmodel, traindata, type = "response") ## predict validation data validata <- predict(woemodel, GermanCredit[-train,], replace = TRUE) pred.val <- predict(glmodel, validata, type = "response")
Applies variable selection to data based on variable clusterings as resulting from corclust
or CLV
.
xtractvars(object, data, thres = 0.5)
xtractvars(object, data, thres = 0.5)
object |
Object of class |
data |
Data where variables are to be selected. Coloumn names must be identical to those used in corclust model. |
thres |
Maximum accepted average within cluster correlation for selection of a variable. |
Of each cluster the first variable is selected as well as all other variables with an average within cluster correlation below thres
.
The data is returned where unselected coloumns are removed.
Gero Szepannek
Roever, C. and Szepannek, G. (2005): Application of a genetic algorithm to variable selection in fuzzy clustering. In C. Weihs and W. Gaul (eds), Classification - The Ubiquitous Challenge, 674-681, Springer.
See also corclust
, cvtree
and CLV
.
data(B3) ccres <- corclust(B3) plot(ccres) cvtres <- cvtree(ccres, k = 3) newdata <- xtractvars(cvtres, B3, thres = 0.5)
data(B3) ccres <- corclust(B3) plot(ccres) cvtres <- cvtree(ccres, k = 3) newdata <- xtractvars(cvtres, B3, thres = 0.5)