org.dmg.pmml.Regression Maven / Gradle / Ivy
package org.dmg.pmml;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlTransient;
import javax.xml.bind.annotation.XmlType;
import com.sun.xml.bind.Locatable;
import com.sun.xml.bind.annotation.XmlLocation;
import org.jpmml.schema.Added;
import org.jpmml.schema.Deprecated;
import org.jpmml.schema.Version;
import org.xml.sax.Locator;
/**
* Java class for anonymous complex type.
*
*
The following schema fragment specifies the expected content contained within this class.
*
*
* <complexType>
* <complexContent>
* <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
* <sequence>
* <element ref="{http://www.dmg.org/PMML-4_2}Extension" maxOccurs="unbounded" minOccurs="0"/>
* <element ref="{http://www.dmg.org/PMML-4_2}Output" minOccurs="0"/>
* <element ref="{http://www.dmg.org/PMML-4_2}ModelStats" minOccurs="0"/>
* <element ref="{http://www.dmg.org/PMML-4_2}Targets" minOccurs="0"/>
* <element ref="{http://www.dmg.org/PMML-4_2}LocalTransformations" minOccurs="0"/>
* <element ref="{http://www.dmg.org/PMML-4_2}ResultField" maxOccurs="unbounded" minOccurs="0"/>
* <element ref="{http://www.dmg.org/PMML-4_2}RegressionTable" maxOccurs="unbounded"/>
* </sequence>
* <attribute name="modelName" type="{http://www.w3.org/2001/XMLSchema}string" />
* <attribute name="functionName" use="required" type="{http://www.dmg.org/PMML-4_2}MINING-FUNCTION" />
* <attribute name="algorithmName" type="{http://www.w3.org/2001/XMLSchema}string" />
* <attribute name="normalizationMethod" type="{http://www.dmg.org/PMML-4_2}REGRESSIONNORMALIZATIONMETHOD" default="none" />
* </restriction>
* </complexContent>
* </complexType>
*
*
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "", propOrder = {
"extensions",
"output",
"modelStats",
"targets",
"localTransformations",
"resultFields",
"regressionTables"
})
@XmlRootElement(name = "Regression")
@Deprecated(Version.PMML_4_1)
public class Regression
extends EmbeddedModel
implements Locatable, HasExtensions
{
@XmlElement(name = "Extension")
protected List extensions;
@XmlElement(name = "Output")
@Added(Version.PMML_4_0)
protected Output output;
@XmlElement(name = "ModelStats")
@Added(Version.PMML_4_0)
protected ModelStats modelStats;
@XmlElement(name = "Targets")
@Added(Version.PMML_4_0)
protected Targets targets;
@XmlElement(name = "LocalTransformations")
protected LocalTransformations localTransformations;
@XmlElement(name = "ResultField")
protected List resultFields;
@XmlElement(name = "RegressionTable", required = true)
protected List regressionTables;
@XmlAttribute(name = "modelName")
protected String modelName;
@XmlAttribute(name = "functionName", required = true)
protected MiningFunctionType functionName;
@XmlAttribute(name = "algorithmName")
protected String algorithmName;
@XmlAttribute(name = "normalizationMethod")
protected RegressionNormalizationMethodType normalizationMethod;
@XmlLocation
@XmlTransient
protected Locator locator;
public Regression() {
super();
}
public Regression(final MiningFunctionType functionName) {
super();
this.functionName = functionName;
}
/**
* Gets the value of the extensions property.
*
*
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a set
method for the extensions property.
*
*
* For example, to add a new item, do as follows:
*
* getExtensions().add(newItem);
*
*
*
*
* Objects of the following type(s) are allowed in the list
* {@link Extension }
*
*
*/
public List getExtensions() {
if (extensions == null) {
extensions = new ArrayList();
}
return this.extensions;
}
/**
* Gets the value of the output property.
*
* @return
* possible object is
* {@link Output }
*
*/
public Output getOutput() {
return output;
}
/**
* Sets the value of the output property.
*
* @param value
* allowed object is
* {@link Output }
*
*/
public void setOutput(Output value) {
this.output = value;
}
/**
* Gets the value of the modelStats property.
*
* @return
* possible object is
* {@link ModelStats }
*
*/
public ModelStats getModelStats() {
return modelStats;
}
/**
* Sets the value of the modelStats property.
*
* @param value
* allowed object is
* {@link ModelStats }
*
*/
public void setModelStats(ModelStats value) {
this.modelStats = value;
}
/**
* Gets the value of the targets property.
*
* @return
* possible object is
* {@link Targets }
*
*/
public Targets getTargets() {
return targets;
}
/**
* Sets the value of the targets property.
*
* @param value
* allowed object is
* {@link Targets }
*
*/
public void setTargets(Targets value) {
this.targets = value;
}
/**
* Gets the value of the localTransformations property.
*
* @return
* possible object is
* {@link LocalTransformations }
*
*/
public LocalTransformations getLocalTransformations() {
return localTransformations;
}
/**
* Sets the value of the localTransformations property.
*
* @param value
* allowed object is
* {@link LocalTransformations }
*
*/
public void setLocalTransformations(LocalTransformations value) {
this.localTransformations = value;
}
/**
* Gets the value of the resultFields property.
*
*
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a set
method for the resultFields property.
*
*
* For example, to add a new item, do as follows:
*
* getResultFields().add(newItem);
*
*
*
*
* Objects of the following type(s) are allowed in the list
* {@link ResultField }
*
*
*/
public List getResultFields() {
if (resultFields == null) {
resultFields = new ArrayList();
}
return this.resultFields;
}
/**
* Gets the value of the regressionTables property.
*
*
* This accessor method returns a reference to the live list,
* not a snapshot. Therefore any modification you make to the
* returned list will be present inside the JAXB object.
* This is why there is not a set
method for the regressionTables property.
*
*
* For example, to add a new item, do as follows:
*
* getRegressionTables().add(newItem);
*
*
*
*
* Objects of the following type(s) are allowed in the list
* {@link RegressionTable }
*
*
*/
public List getRegressionTables() {
if (regressionTables == null) {
regressionTables = new ArrayList();
}
return this.regressionTables;
}
/**
* Gets the value of the modelName property.
*
* @return
* possible object is
* {@link String }
*
*/
public String getModelName() {
return modelName;
}
/**
* Sets the value of the modelName property.
*
* @param value
* allowed object is
* {@link String }
*
*/
public void setModelName(String value) {
this.modelName = value;
}
/**
* Gets the value of the functionName property.
*
* @return
* possible object is
* {@link MiningFunctionType }
*
*/
public MiningFunctionType getFunctionName() {
return functionName;
}
/**
* Sets the value of the functionName property.
*
* @param value
* allowed object is
* {@link MiningFunctionType }
*
*/
public void setFunctionName(MiningFunctionType value) {
this.functionName = value;
}
/**
* Gets the value of the algorithmName property.
*
* @return
* possible object is
* {@link String }
*
*/
public String getAlgorithmName() {
return algorithmName;
}
/**
* Sets the value of the algorithmName property.
*
* @param value
* allowed object is
* {@link String }
*
*/
public void setAlgorithmName(String value) {
this.algorithmName = value;
}
/**
* Gets the value of the normalizationMethod property.
*
* @return
* possible object is
* {@link RegressionNormalizationMethodType }
*
*/
public RegressionNormalizationMethodType getNormalizationMethod() {
if (normalizationMethod == null) {
return RegressionNormalizationMethodType.NONE;
} else {
return normalizationMethod;
}
}
/**
* Sets the value of the normalizationMethod property.
*
* @param value
* allowed object is
* {@link RegressionNormalizationMethodType }
*
*/
public void setNormalizationMethod(RegressionNormalizationMethodType value) {
this.normalizationMethod = value;
}
public Regression withExtensions(Extension... values) {
if (values!= null) {
for (Extension value: values) {
getExtensions().add(value);
}
}
return this;
}
public Regression withExtensions(Collection values) {
if (values!= null) {
getExtensions().addAll(values);
}
return this;
}
public Regression withOutput(Output value) {
setOutput(value);
return this;
}
public Regression withModelStats(ModelStats value) {
setModelStats(value);
return this;
}
public Regression withTargets(Targets value) {
setTargets(value);
return this;
}
public Regression withLocalTransformations(LocalTransformations value) {
setLocalTransformations(value);
return this;
}
public Regression withResultFields(ResultField... values) {
if (values!= null) {
for (ResultField value: values) {
getResultFields().add(value);
}
}
return this;
}
public Regression withResultFields(Collection values) {
if (values!= null) {
getResultFields().addAll(values);
}
return this;
}
public Regression withRegressionTables(RegressionTable... values) {
if (values!= null) {
for (RegressionTable value: values) {
getRegressionTables().add(value);
}
}
return this;
}
public Regression withRegressionTables(Collection values) {
if (values!= null) {
getRegressionTables().addAll(values);
}
return this;
}
public Regression withModelName(String value) {
setModelName(value);
return this;
}
public Regression withFunctionName(MiningFunctionType value) {
setFunctionName(value);
return this;
}
public Regression withAlgorithmName(String value) {
setAlgorithmName(value);
return this;
}
public Regression withNormalizationMethod(RegressionNormalizationMethodType value) {
setNormalizationMethod(value);
return this;
}
public Locator sourceLocation() {
return locator;
}
public void setSourceLocation(Locator newLocator) {
locator = newLocator;
}
@Override
public VisitorAction accept(Visitor visitor) {
VisitorAction status = visitor.visit(this);
for (int i = 0; (((status == VisitorAction.CONTINUE)&&(this.extensions!= null))&&(i