com.github.chen0040.gp.treegp.program.Primitive Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of java-genetic-programming Show documentation
Show all versions of java-genetic-programming Show documentation
Genetic Programming in Java, including packages on Linear Genetic Programming
package com.github.chen0040.gp.treegp.program;
import com.github.chen0040.data.utils.StringUtils;
import com.github.chen0040.gp.exceptions.SizeMismatchedException;
import com.github.chen0040.gp.commons.Indexable;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
/**
* Created by xschen on 8/5/2017.
*/
public abstract class Primitive implements Serializable, Indexable {
private static final long serialVersionUID = -249257238928605728L;
private final List inputs = new ArrayList<>();
private double value;
private final String symbol;
private final boolean readOnly;
private int index;
public Primitive(){
symbol = "";
readOnly = false;
}
public Primitive(int inputCount, String symbol, double value, boolean readOnly) {
for(int i=0; i < inputCount; ++i){
inputs.add(0.0);
}
this.symbol = symbol;
this.value = value;
this.readOnly = readOnly;
}
public boolean isTerminal(){
return inputs.isEmpty();
}
public String getName(){
if(StringUtils.isEmpty(symbol)){
return (isReadOnly() ? "c" : "v") + index;
} else {
return symbol;
}
}
public Primitive copy(Primitive that) {
if(!symbol.equals(that.getSymbol())){
throw new RuntimeException("Symbol not matched for copy to proceed");
}
inputs.clear();
for(int i=0; i < that.inputs.size(); ++i) {
inputs.add(that.inputs.get(i));
}
value = that.value;
index = that.index;
return this;
}
public int arity(){
return inputs.size();
}
public void read(List values){
if(inputs.size() != values.size()) {
throw new SizeMismatchedException(inputs.size(), values.size());
}
for(int i=0; i < values.size(); ++i) {
inputs.set(i, values.get(i));
}
}
public void setInput(int index, double value){
if(index >= arity()){
throw new IndexOutOfBoundsException(index + " is greater or equal to input size" + arity());
}
inputs.set(index, value);
}
public double getInput(int index) {
if(index >= arity()){
throw new IndexOutOfBoundsException(index + " is greater or equal to input size" + arity());
}
return inputs.get(index);
}
public void setValue(double val){
if(readOnly){
throw new RuntimeException("The primitive is readonly");
}
value = val;
}
public double getValue(){
return value;
}
public String getSymbol(){
return symbol;
}
public boolean isReadOnly(){
return readOnly;
}
@Override public int getIndex() {
return index;
}
@Override public void setIndex(int index) {
this.index = index;
}
@Override public abstract Primitive makeCopy();
@Override public boolean equals(Object o) {
if (this == o)
return true;
if (o == null || getClass() != o.getClass())
return false;
Primitive primitive = (Primitive) o;
/*
if (Double.compare(primitive.value, value) != 0)
return false;
*/
if (readOnly != primitive.readOnly)
return false;
if (index != primitive.index)
return false;
/*
if (inputs != null ? !inputs.equals(primitive.inputs) : primitive.inputs != null)
return false;
*/
return symbol != null ? symbol.equals(primitive.symbol) : primitive.symbol == null;
}
@Override public int hashCode() {
int result;
long temp;
result = 0;
// result = inputs != null ? inputs.hashCode() : 0;
//temp = Double.doubleToLongBits(value);
// result = 31 * result + (int) (temp ^ (temp >>> 32));
result = 31 * result + (symbol != null ? symbol.hashCode() : 0);
result = 31 * result + (readOnly ? 1 : 0);
result = 31 * result + index;
return result;
}
public abstract void execute(Object... tags);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy