R/coding.r

Defines functions as.dummy.data.frame as.dummy.list as.dummy.matrix as.dummy.factor as.dummy.integer as.dummy.logical as.dummy

Documented in as.dummy as.dummy.data.frame as.dummy.matrix

# coding.r
#
# dummy coding for data mining applications
#
# fixme: no reverse methods implemented
#
# ceeboo 2005

as.dummy <- function(x, ...) 
    UseMethod("as.dummy")

as.dummy.logical <- function(x, ...) {
    x <- as.dummy(as.factor(x))
    x
}

as.dummy.integer <- function(x, ...) { 
    x <- as.dummy(as.factor(x))
    x
}

as.dummy.factor <- function(x, ...) {
    x <- .Call("R_as_dummy", x)
    x
}

as.dummy.matrix <- function(x, sep=" ", drop=FALSE, ...) {
    if (is.null(colnames(x)))
       colnames(x) <- paste("V", 1:dim(x)[2], sep="")
    obj <- NULL
    levels <- NULL
    colnames <- NULL
    varnames <- NULL
    for (i in 1:dim(x)[2]) {
        z <- as.dummy(x[,i])
        if (drop && nlevels(z) == 1)
           next
        obj <- cbind(obj, z)
        levels <- c(levels, list(levels(z)))
        varnames <- c(varnames, colnames(x)[i])
        colnames <- c(colnames, paste(colnames(x)[i], levels(z), sep=sep))
    }
    rownames(obj) <- rownames(x)
    colnames(obj) <- colnames
    names(levels) <- varnames
    attr(obj, "levels") <- levels
    obj
}

as.dummy.list <- function(x, ...)
    lapply(x, function(z) as.dummy(z))

as.dummy.data.frame <- function(x, sep=" ", drop=FALSE, ...) {
    if (is.null(names(x)))
       names(x) <- paste("V", 1:length(x), sep="")
    obj <- NULL
    levels <- NULL
    colnames <- NULL
    varnames <- NULL
    for (name in names(x)) {
        z <- as.dummy(x[[name]])
        if (drop && nlevels(z) == 1)
           next
        obj <- cbind(obj, z)
        levels <- c(levels, list(levels(z)))
        varnames <- c(varnames, name)
        colnames <- c(colnames, paste(name, levels(z), sep=sep))
    }
    rownames(obj) <- rownames(x)
    colnames(obj) <- colnames
    names(levels) <- varnames
    attr(obj, "levels") <- levels
    obj
}

###

Try the cba package in your browser

Any scripts or data that you put into this service are public.

cba documentation built on Dec. 7, 2022, 5:17 p.m.