Introduction to the noisemodel package"

knitr::opts_chunk$set(
  collapse = TRUE,
  comment = "#>"
)

getInfo <- function(what = "Suggests") {
  text <- packageDescription("noisemodel")[what][[1]]
  text <- gsub("\n", ", ", text, fixed = TRUE)
  text <- gsub(">=", "$\\\\ge$", text, fixed = TRUE)
  eachPkg <- strsplit(text, ", ", fixed = TRUE)[[1]]
  eachPkg <- gsub(",", "", eachPkg, fixed = TRUE)
  #out <- paste("\\\**", eachPkg[order(tolower(eachPkg))], "}", sep = "")
  #paste(out, collapse = ", ")
  length(eachPkg)
}

The **noisemodel** package contains the first extensive implementation of noise models for classification datasets. It provides 72 noise models found in the specialized literature that allow errors to be introduced in different ways in class labels, attributes or both in combination. Each of them is properly documented and referenced, unifying their results through a specific S3 class, which benefits from customized `print`, `summary` and `plot` methods.

Installation

The noisemodel package can be installed in R from CRAN servers using the command:

# install.packages("noisemodel")

This command installs all the dependencies of the package that are necessary for the operation of the noise models. In order to access all the functions of the package, it is necessary to use the R command:

library(noisemodel)

Documentation

All the information corresponding to each noise model can be consulted from the CRAN website. Additionally, the help() command can be used. For example, in order to check the documentation of the Symmetric uniform label noise model, we can use the command:

# help(sym_uni_ln)

Usage of noise models

For introducing noise in a dataset, each noise model in the noisemodel package provides two standard ways of use:

An example on how to use these two methods for introducing noise in the iris2D dataset with the sym_uni_ln model is shown below:

# load the dataset
data(iris2D)

# usage of the default method
set.seed(9)
outdef <- sym_uni_ln(x = iris2D[,-ncol(iris2D)], y = iris2D[,ncol(iris2D)], level = 0.1)

# show results
summary(outdef, showid = TRUE)
plot(outdef)

# usage of the method for class formula
set.seed(9)
outfrm <- sym_uni_ln(formula = Species ~ ., data = iris2D, level = 0.1)

# check the match of noisy indices
identical(outdef$idnoise, outfrm$idnoise)

Note that, the `$` operator is used to access the elements returned by the noise model in the objects `outdef` and `outfrm`.

Output values

All noise models return an object of class ndmodel. It is designed to unify the output value of the methods included in the noisemodel package. The class ndmodel is a list of elements with the most relevant information of the noise introduction process:

As an example, the structure of the ndmodel object returned using the sym_uni_ln model is shown below:

str(outdef)

In order to display the results of the class `ndmodel` in a friendly way in the R console, specific `print`, `summary` and `plot` functions are implemented. The `print` function presents the basic information about the noise introduction process contained in an object of class `ndmodel`:

print(outdef)

The information offered by `print` is as follows:

On the other hand, the `summary` function displays a summary containing information about the noise introduction process contained in an object of class `ndmodel`, with other additional details. This function can be called by typing the following R command:

summary(outdef, showid = TRUE)

The information offered by this function is as follows:

Finally, the `plot` function displays a representation of the dataset contained in an object of class `ndmodel` after the application of a noise introduction model.

plot(outdef)

This function performs a two-dimensional representation using the **ggplot2** package of the dataset contained in the object *x* of class `ndmodel`. Each of the classes in the dataset (available in `x$ynoise`) is represented by a different color.



Try the noisemodel package in your browser

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

noisemodel documentation built on Oct. 17, 2022, 9:05 a.m.