smile.base.cart.OrdinalNode Maven / Gradle / Ivy
The newest version!
/*
* Copyright (c) 2010-2021 Haifeng Li. All rights reserved.
*
* Smile is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Smile is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Smile. If not, see .
*/
package smile.base.cart;
import smile.data.Tuple;
import smile.data.type.StructField;
import smile.data.type.StructType;
import java.io.Serial;
/**
* A node with an ordinal split variable (real-valued or ordinal categorical value).
*
* @author Haifeng Li
*/
public class OrdinalNode extends InternalNode {
@Serial
private static final long serialVersionUID = 2L;
/**
* The split value.
*/
final double value;
/**
* Constructor.
* @param feature the index of feature column.
* @param value the split value.
* @param score the split score.
* @param deviance the deviance.
* @param trueChild the true branch child.
* @param falseChild the false branch child.
*/
public OrdinalNode(int feature, double value, double score, double deviance, Node trueChild, Node falseChild) {
super(feature, score, deviance, trueChild, falseChild);
this.value = value;
}
@Override
public LeafNode predict(Tuple x) {
return x.getDouble(feature) <= value ? trueChild.predict(x) : falseChild.predict(x);
}
@Override
public boolean branch(Tuple x) {
return x.getDouble(feature) <= value;
}
@Override
public OrdinalNode replace(Node trueChild, Node falseChild) {
return new OrdinalNode(feature, value, score, deviance, trueChild, falseChild);
}
@Override
public String dot(StructType schema, StructField response, int id) {
StructField field = schema.field(feature);
return String.format(" %d [label=<%s ≤ %s
size = %d
impurity reduction = %.4f>, fillcolor=\"#00000000\"];\n", id, field.name, field.toString(value), size(), score);
}
@Override
public String toString(StructType schema, boolean trueBranch) {
StructField field = schema.field(feature);
String condition = trueBranch ? "<=" : ">";
return String.format("%s%s%g", field.name, condition, value);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy