The NaiveBayes
class implements an Integer-Based Naive Bayes Classifier, which is a commonly used such classifier for discrete input data. The classifier is trained using a data matrix x and a classification vector y. Each data vector in the matrix is classified into one of k classes numbered 0, ..., k-1. Prior probabilities are calculated based on the population of each class in the training-set. Relative posterior probabilities are computed by multiplying these by values computed using conditional probabilities. stored in Conditional Probability Tables (CPTs).
The classifier is naive, because it assumes variable/feature independence and therefore simply multiplies the conditional probabilities.
Value parameters
- cname_
-
the name for each class
- fname_
-
the name for each feature/variable xj
- hparam
-
the hyper-parameters
- k
-
the number of classes
- vc
-
the value count (number of distinct values) for each feature/variable xj
- x
-
the input/data m-by-n matrix with instances stored in rows
- y
-
the response/classification m-vector, where y_i = class for row i of matrix x
Attributes
- Companion
- object
- Graph
-
- Supertypes
Members list
Type members
Inherited classlikes
The BestStep
is used to record the best improvement step found so far.
The BestStep
is used to record the best improvement step found so far.
Value parameters
- col
-
the column/variable to ADD/REMOVE for this step
- mod
-
the model including selected features/variables for this step
- qof
-
the Quality of Fit (QoF) for this step
Attributes
- Inherited from:
- Classifier
- Supertypes
-
trait Serializabletrait Producttrait Equalsclass Objecttrait Matchableclass AnyShow all
Value members
Concrete methods
Compute the conditional probability of X given y for each feature xj.
Compute the conditional probability of X given y for each feature xj.
Value parameters
- nu_Xy
-
the joint frequency of X and y for each feature xj and class value
- x_
-
the integer-valued data vectors stored as rows of a matrix
- y_
-
the class vector, where y(i) = class for row i of the matrix x, x(i)
Attributes
Get the Conditional Probability Tables (CPTs) stored in tensor p_Xy. Must call train first to get values for p_Xy.
Get the Conditional Probability Tables (CPTs) stored in tensor p_Xy. Must call train first to get values for p_Xy.
Attributes
Predict the integer value of y = f(z) by computing the product of the class probabilities p_y and all the conditional probabilities P(X_j = z_j | y = c) and returning the class with the highest relative probability. This method adds "positive log probabilities" to avoids underflow. Note, p_yz from Classifier
holds the relative probabilities of y given z. To recover q relative probability compute 2^(-q) where q is a plog.
Predict the integer value of y = f(z) by computing the product of the class probabilities p_y and all the conditional probabilities P(X_j = z_j | y = c) and returning the class with the highest relative probability. This method adds "positive log probabilities" to avoids underflow. Note, p_yz from Classifier
holds the relative probabilities of y given z. To recover q relative probability compute 2^(-q) where q is a plog.
Value parameters
- z
-
the new vector to predict
Attributes
- Definition Classes
Predict the integer value of y = f(z) by computing the product of the class probabilities p_y and all the conditional probabilities P(X_j = z_j | y = c) and returning the class with the highest relative probability. Note, p_yz from Classifier
holds the relative probabilities of y given z.
Predict the integer value of y = f(z) by computing the product of the class probabilities p_y and all the conditional probabilities P(X_j = z_j | y = c) and returning the class with the highest relative probability. Note, p_yz from Classifier
holds the relative probabilities of y given z.
Value parameters
- z
-
the new vector to predict
Attributes
- Definition Classes
Produce a QoF summary for a model with diagnostics for each predictor x_0, x_1, and the overall Quality of Fit (QoF).
Produce a QoF summary for a model with diagnostics for each predictor x_0, x_1, and the overall Quality of Fit (QoF).
Value parameters
- b_
-
the parameters/coefficients for the model
- fname_
-
the array of feature/variable names
- vifs
-
the Variance Inflation Factors (VIFs)
- x_
-
the testing/full data/input matrix
Attributes
- Definition Classes
Test the predictive model y_ = f(x_) + e and return its predictions and QoF vector. Testing may be in-sample (on the full dataset) or out-of-sample (on the testing set) as determined by the parameters passed in. Note: must call train before test.
Test the predictive model y_ = f(x_) + e and return its predictions and QoF vector. Testing may be in-sample (on the full dataset) or out-of-sample (on the testing set) as determined by the parameters passed in. Note: must call train before test.
Value parameters
- x_
-
the testing/full data/input matrix (defaults to full x)
- y_
-
the testing/full response/output vector (defaults to full y)
Attributes
Train a classification model y_ = f(x_) + e where x_ is the data/input matrix and y_ is the response/output vector. These arguments default to the full dataset x and y, but may be restricted to a training set Training involves estimating the model parameters or pmf. Train the classifier by computing the class probabilities for y, and the conditional probabilities for each x_j given y.
Train a classification model y_ = f(x_) + e where x_ is the data/input matrix and y_ is the response/output vector. These arguments default to the full dataset x and y, but may be restricted to a training set Training involves estimating the model parameters or pmf. Train the classifier by computing the class probabilities for y, and the conditional probabilities for each x_j given y.
Value parameters
- x_
-
the training/full data/input matrix (defaults to full x)
- y_
-
the training/full response/output vector (defaults to full y)
Attributes
- Definition Classes
Inherited methods
Compute the accuracy of the classification, i.e., the fraction of correct classifications. Note, the correct classifications tp_i are in the main diagonal of the confusion matrix.
Compute the accuracy of the classification, i.e., the fraction of correct classifications. Note, the correct classifications tp_i are in the main diagonal of the confusion matrix.
Attributes
- Inherited from:
- FitC
Perform backward elimination to find the least predictive variable to remove from the existing model, returning the variable to eliminate, the new parameter vector and the new Quality of Fit (QoF). May be called repeatedly.
Perform backward elimination to find the least predictive variable to remove from the existing model, returning the variable to eliminate, the new parameter vector and the new Quality of Fit (QoF). May be called repeatedly.
Value parameters
- cols
-
the columns of matrix x currently included in the existing model
- first
-
first variable to consider for elimination (default (1) assume intercept x_0 will be in any model)
- idx_q
-
index of Quality of Fit (QoF) to use for comparing quality
Attributes
- See also
-
Fit
for index of QoF measures. - Inherited from:
- Classifier
Perform backward elimination to find the least predictive variables to remove from the full model, returning the variables left and the new Quality of Fit (QoF) measures for all steps.
Perform backward elimination to find the least predictive variables to remove from the full model, returning the variables left and the new Quality of Fit (QoF) measures for all steps.
Value parameters
- cross
-
whether to include the cross-validation QoF measure
- first
-
first variable to consider for elimination
- idx_q
-
index of Quality of Fit (QoF) to use for comparing quality
Attributes
- See also
-
Fit
for index of QoF measures. - Inherited from:
- Classifier
Build a sub-model that is restricted to the given columns of the data matrix. Override for models that support feature selection.
Build a sub-model that is restricted to the given columns of the data matrix. Override for models that support feature selection.
Value parameters
- x_cols
-
the columns that the new model is restricted to
Attributes
- Inherited from:
- Classifier
Given a continuous data vector z, classify it returning the class number (0, ..., k-1) with the highest relative posterior probability. Return the best class, its name and its relative probability.
Given a continuous data vector z, classify it returning the class number (0, ..., k-1) with the highest relative posterior probability. Return the best class, its name and its relative probability.
Value parameters
- z
-
the data vector to classify
Attributes
- Inherited from:
- Classifier
Given a discrete data vector z, classify it returning the class number (0, ..., k-1) with the highest relative posterior probability. Return the best class, its name and its relative probability.
Given a discrete data vector z, classify it returning the class number (0, ..., k-1) with the highest relative posterior probability. Return the best class, its name and its relative probability.
Value parameters
- z
-
the data vector to classify
Attributes
- Inherited from:
- Classifier
Clear the total cummulative confusion matrix.
Compare the actual class y vector versus the predicted class yp vector, returning the confusion matrix cmat, which for k = 2 is yp 0 1 ---------- y 0 | tn fp | 1 | fn tp | ---------- Note: ScalaTion's confusion matrix is Actual × Predicted, but to swap the position of actual y (rows) with predicted yp (columns) simply use cmat.transpose, the transpose of cmat.
Compare the actual class y vector versus the predicted class yp vector, returning the confusion matrix cmat, which for k = 2 is yp 0 1 ---------- y 0 | tn fp | 1 | fn tp | ---------- Note: ScalaTion's confusion matrix is Actual × Predicted, but to swap the position of actual y (rows) with predicted yp (columns) simply use cmat.transpose, the transpose of cmat.
Value parameters
- y_
-
the actual class values/labels for full (y) or test (y_e) dataset
- yp
-
the predicted class values/labels
Attributes
- See also
- Inherited from:
- FitC
Contract the actual class y_ vector versus the predicted class yp vector.
Contract the actual class y_ vector versus the predicted class yp vector.
Value parameters
- y_
-
the actual class values/labels for full (y) or test (y_e) dataset
- yp
-
the predicted class values/labels
Attributes
- Inherited from:
- FitC
Attributes
- Inherited from:
- Classifier
Diagnose the health of the model by computing the Quality of Fit (QoF) measures, from the error/residual vector and the predicted & actual responses. Requires the actual and predicted responses to be non-negative integers. Must override when there negative responses.
Diagnose the health of the model by computing the Quality of Fit (QoF) measures, from the error/residual vector and the predicted & actual responses. Requires the actual and predicted responses to be non-negative integers. Must override when there negative responses.
Value parameters
- y_
-
the actual response/output vector to use (test/full)
- yp
-
the predicted response/output vector (test/full)
Attributes
- Inherited from:
- FitC
Diagnose the health of the model by computing the Quality of Fit (QoF) measures, from the error/residual vector and the predicted & actual responses. For some models the instances may be weighted.
Diagnose the health of the model by computing the Quality of Fit (QoF) measures, from the error/residual vector and the predicted & actual responses. For some models the instances may be weighted.
Value parameters
- w
-
the weights on the instances (defaults to null)
- y_
-
the actual response/output vector to use (test/full)
- yp
-
the predicted response/output vector (test/full)
Attributes
- Definition Classes
- Inherited from:
- FitC
Compute the F1-measure, i.e., the harmonic mean of the precision and recall.
Compute the F1-measure, i.e., the harmonic mean of the precision and recall.
Value parameters
- p
-
the precision
- r
-
the recall
Attributes
- Inherited from:
- FitC
Compute the micro-F1-measure vector, i.e., the harmonic mean of the precision and recall.
Compute the micro-F1-measure vector, i.e., the harmonic mean of the precision and recall.
Attributes
- Inherited from:
- FitC
Return the Quality of Fit (QoF) measures corresponding to the labels given above in the fitLabel method.
Return the Quality of Fit (QoF) measures corresponding to the labels given above in the fitLabel method.
Attributes
- Inherited from:
- FitC
Return the labels for the Quality of Fit (QoF) measures. Override to add additional QoF measures.
Return the labels for the Quality of Fit (QoF) measures. Override to add additional QoF measures.
Attributes
- Inherited from:
- FitC
Return the Quality of Fit (QoF) vector micro-measures, i.e., measures for each class.
Return the Quality of Fit (QoF) vector micro-measures, i.e., measures for each class.
Attributes
- Inherited from:
- FitC
Perform forward selection to find the most predictive variable to add the existing model, returning the variable to add and the new model. May be called repeatedly.
Perform forward selection to find the most predictive variable to add the existing model, returning the variable to add and the new model. May be called repeatedly.
Value parameters
- cols
-
the columns of matrix x currently included in the existing model
- idx_q
-
index of Quality of Fit (QoF) to use for comparing quality
Attributes
- See also
-
Fit
for index of QoF measures. - Inherited from:
- Classifier
Perform forward selection to find the most predictive variables to have in the model, returning the variables added and the new Quality of Fit (QoF) measures for all steps.
Perform forward selection to find the most predictive variables to have in the model, returning the variables added and the new Quality of Fit (QoF) measures for all steps.
Value parameters
- cross
-
whether to include the cross-validation QoF measure
- idx_q
-
index of Quality of Fit (QoF) to use for comparing quality
Attributes
- See also
-
Fit
for index of QoF measures. - Inherited from:
- Classifier
Return the feature/variable names.
Return the used data matrix x. Mainly for derived classes where x is expanded from the given columns in x_, e.g., SymbolicRegression.quadratic
adds squared columns.
Return the used data matrix x. Mainly for derived classes where x is expanded from the given columns in x_, e.g., SymbolicRegression.quadratic
adds squared columns.
Attributes
- Inherited from:
- Classifier
Return the used response vector y. Mainly for derived classes where y is transformed, e.g., TranRegression
, Regression4TS
.
Return the used response vector y. Mainly for derived classes where y is transformed, e.g., TranRegression
, Regression4TS
.
Attributes
- Inherited from:
- Classifier
Return the help string that describes the Quality of Fit (QoF) measures provided by the FitC
class. Override to correspond to fitLabel.
Return the help string that describes the Quality of Fit (QoF) measures provided by the FitC
class. Override to correspond to fitLabel.
Attributes
- Inherited from:
- FitC
Return the hyper-parameters.
Compute Cohen's kappa coefficient that measures agreement between actual y and predicted yp classifications.
Compute Cohen's kappa coefficient that measures agreement between actual y and predicted yp classifications.
Value parameters
- y_
-
the actual response/output vector to use (test/full)
- yp
-
the predicted response/output vector (test/full)
Attributes
- See also
-
en.wikipedia.org/wiki/Cohen%27s_kappa
- Inherited from:
- FitC
Given a continuous data vector z, classify it returning the class number (0, ..., k-1) with the highest relative posterior probability. Return the best class, its name and its relative log-probability. This method adds "positive log probabilities" to avoids underflow. To recover q relative probability compute 2^(-q) where q is a plog.
Given a continuous data vector z, classify it returning the class number (0, ..., k-1) with the highest relative posterior probability. Return the best class, its name and its relative log-probability. This method adds "positive log probabilities" to avoids underflow. To recover q relative probability compute 2^(-q) where q is a plog.
Value parameters
- z
-
the data vector to classify
Attributes
- Inherited from:
- Classifier
Given a discrete data vector z, classify it returning the class number (0, ..., k-1) with the highest relative posterior probability. Return the best class, its name and its relative log-probability. This method adds "positive log probabilities" to avoids underflow. To recover q relative probability compute 2^(-q) where q is a plog.
Given a discrete data vector z, classify it returning the class number (0, ..., k-1) with the highest relative posterior probability. Return the best class, its name and its relative log-probability. This method adds "positive log probabilities" to avoids underflow. To recover q relative probability compute 2^(-q) where q is a plog.
Value parameters
- z
-
the data vector to classify
Attributes
- Inherited from:
- Classifier
Attributes
- Inherited from:
- Classifier
Return the number of terms/parameters in the model, e.g., b_0 + b_1 x_1 + b_2 x_2 has three terms.
Return the number of terms/parameters in the model, e.g., b_0 + b_1 x_1 + b_2 x_2 has three terms.
Attributes
- Inherited from:
- Classifier
Compute the micro-precision, micro-recall and micro-specificity vectors which have elements for each class i in {0, 1, ... k-1}. Precision is the fraction classified as true that are actually true. Recall (sensitivity) is the fraction of the actually true that are classified as true. Specificity is the fraction of the actually false that are classified as false. Note, for k = 2, ordinary precision p, recall r and specificity s will correspond to the last elements in the pv, rv and sv micro vectors.
Compute the micro-precision, micro-recall and micro-specificity vectors which have elements for each class i in {0, 1, ... k-1}. Precision is the fraction classified as true that are actually true. Recall (sensitivity) is the fraction of the actually true that are classified as true. Specificity is the fraction of the actually false that are classified as false. Note, for k = 2, ordinary precision p, recall r and specificity s will correspond to the last elements in the pv, rv and sv micro vectors.
Attributes
- Inherited from:
- FitC
Return the vector of parameter values analog, the estimate of the response pmf.
Return the vector of parameter values analog, the estimate of the response pmf.
Attributes
- Inherited from:
- Classifier
Predict the value of y = f(z) by evaluating the model equation. Single output models return Double
, while multi-output models return VectorD
.
Predict the value of y = f(z) by evaluating the model equation. Single output models return Double
, while multi-output models return VectorD
.
Value parameters
- z
-
the new vector to predict
Attributes
- Inherited from:
- Classifier
Predict the value of vector y = f(x_) using matrix x_
Predict the value of vector y = f(x_) using matrix x_
Value parameters
- x_
-
the matrix to use for making predictions, one for each row
Attributes
- Inherited from:
- Classifier
Compute the Efron's pseudo R-squared value. Override to McFadden's, etc.
Compute the Efron's pseudo R-squared value. Override to McFadden's, etc.
Value parameters
- p1
-
the first parameter
- p2
-
the second parameter
Attributes
- Inherited from:
- FitC
Return the coefficient of determination (R^2). Must call diagnose first.
Return the coefficient of determination (R^2). Must call diagnose first.
Attributes
- Inherited from:
- FitM
Return a basic report on a trained and tested model.
Return a basic report on a trained and tested model.
Value parameters
- ftVec
-
the vector of qof values produced by the
FitC
trait
Attributes
- Definition Classes
-
Classifier -> Model
- Inherited from:
- Classifier
Return a basic report on a trained and tested multi-variate model.
Return a basic report on a trained and tested multi-variate model.
Value parameters
- ftMat
-
the matrix of qof values produced by the
Fit
trait
Attributes
- Inherited from:
- Model
Return the vector of residuals/errors.
Perform feature selection to find the most predictive variables to have in the model, returning the variables added and the new Quality of Fit (QoF) measures for all steps.
Perform feature selection to find the most predictive variables to have in the model, returning the variables added and the new Quality of Fit (QoF) measures for all steps.
Value parameters
- cross
-
whether to include the cross-validation QoF measure
- idx_q
-
index of Quality of Fit (QoF) to use for comparing quality
- tech
-
the feature selection technique to apply
Attributes
- See also
-
Fit
for index of QoF measures. - Inherited from:
- Classifier
Return the sum of the squares for error (sse). Must call diagnose first.
Return the sum of the squares for error (sse). Must call diagnose first.
Attributes
- Inherited from:
- FitM
Perform stepwise regression to find the most predictive variables to have in the model, returning the variables left and the new Quality of Fit (QoF) measures for all steps. At each step it calls forwardSel and backwardElim and takes the best of the two actions. Stops when neither action yields improvement.
Perform stepwise regression to find the most predictive variables to have in the model, returning the variables left and the new Quality of Fit (QoF) measures for all steps. At each step it calls forwardSel and backwardElim and takes the best of the two actions. Stops when neither action yields improvement.
Value parameters
- cross
-
whether to include the cross-validation QoF measure
- idx_q
-
index of Quality of Fit (QoF) to use for comparing quality
Attributes
- See also
-
Fit
for index of QoF measures. - Inherited from:
- Classifier
Test/evaluate the model's Quality of Fit (QoF) and return the predictions and QoF vectors. This may include the importance of its parameters (e.g., if 0 is in a parameter's confidence interval, it is a candidate for removal from the model). Extending traits and classess should implement various diagnostics for the test and full (training + test) datasets.
Test/evaluate the model's Quality of Fit (QoF) and return the predictions and QoF vectors. This may include the importance of its parameters (e.g., if 0 is in a parameter's confidence interval, it is a candidate for removal from the model). Extending traits and classess should implement various diagnostics for the test and full (training + test) datasets.
Value parameters
- x_
-
the testiing/full data/input matrix (impl. classes may default to x)
- y_
-
the testiing/full response/output vector (impl. classes may default to y)
Attributes
- Inherited from:
- Classifier
Return the indices for the test-set.
Return the indices for the test-set.
Value parameters
- n_test
-
the size of test-set
- rando
-
whether to select indices randomly or in blocks
Attributes
- See also
-
scalation.mathstat.TnT_Split
- Inherited from:
- Classifier
Return the confusion matrix for k = 2 as a tuple (tn, fp, fn, tp).
Return the confusion matrix for k = 2 as a tuple (tn, fp, fn, tp).
Value parameters
- con
-
the confusion matrix (defaults to cmat)
Attributes
- Inherited from:
- FitC
Return a copy of the total cumulative confusion matrix tcmat and clear tcmat.
Return a copy of the total cumulative confusion matrix tcmat and clear tcmat.
Attributes
- Inherited from:
- FitC
Train the model 'y_ = f(x_) + e' on a given dataset, by optimizing the model parameters in order to minimize error '||e||' or maximize log-likelihood 'll'.
Train the model 'y_ = f(x_) + e' on a given dataset, by optimizing the model parameters in order to minimize error '||e||' or maximize log-likelihood 'll'.
Value parameters
- x_
-
the training/full data/input matrix (impl. classes may default to x)
- y_
-
the training/full response/output vector (impl. classes may default to y)
Attributes
- Inherited from:
- Classifier
The train2 method should work like the train method, but should also optimize hyper-parameters (e.g., shrinkage or learning rate). Only implementing classes needing this capability should override this method.
The train2 method should work like the train method, but should also optimize hyper-parameters (e.g., shrinkage or learning rate). Only implementing classes needing this capability should override this method.
Value parameters
- x_
-
the training/full data/input matrix (defaults to full x)
- y_
-
the training/full response/output vector (defaults to full y)
Attributes
- Inherited from:
- Classifier
Train and test the predictive model y_ = f(x_) + e and report its QoF and plot its predictions.
Train and test the predictive model y_ = f(x_) + e and report its QoF and plot its predictions.
Value parameters
- x_
-
the training/full data/input matrix (defaults to full x)
- xx
-
the testing/full data/input matrix (defaults to full x)
- y_
-
the training/full response/output vector (defaults to full y)
- yy
-
the testing/full response/output vector (defaults to full y)
Attributes
- Inherited from:
- Classifier
Attributes
- Inherited from:
- Classifier
Compute the Variance Inflation Factor (VIF) for each variable to test for multi-collinearity by regressing x_j against the rest of the variables. A VIF over 50 indicates that over 98% of the variance of x_j can be predicted from the other variables, so x_j may be a candidate for removal from the model. Note: override this method to use a superior regression technique.
Compute the Variance Inflation Factor (VIF) for each variable to test for multi-collinearity by regressing x_j against the rest of the variables. A VIF over 50 indicates that over 98% of the variance of x_j can be predicted from the other variables, so x_j may be a candidate for removal from the model. Note: override this method to use a superior regression technique.
Value parameters
- skip
-
the number of columns of x at the beginning to skip in computing VIF
Attributes
- Inherited from:
- Classifier
Inherited fields
The optional reference to an ontological concept