/*
* File name: PrimeAgent.java (package eas.users.lukas.primeProperties.primeEvolution)
* Author(s): lko
* Java version: 7.0
* Generation date: 24.11.2012 (13:34:21)
*
* (c) This file and the EAS (Easy Agent Simulation) framework containing it
* is protected by Creative Commons by-nc-sa license. Any altered or
* further developed versions of this file have to meet the agreements
* stated by the license conditions.
*
* In a nutshell
* -------------
* You are free:
* - to Share -- to copy, distribute and transmit the work
* - to Remix -- to adapt the work
*
* Under the following conditions:
* - Attribution -- You must attribute the work in the manner specified by the
* author or licensor (but not in any way that suggests that they endorse
* you or your use of the work).
* - Noncommercial -- You may not use this work for commercial purposes.
* - Share Alike -- If you alter, transform, or build upon this work, you may
* distribute the resulting work only under the same or a similar license to
* this one.
*
* + Detailed license conditions (Germany):
* http://creativecommons.org/licenses/by-nc-sa/3.0/de/
* + Detailed license conditions (unported):
* http://creativecommons.org/licenses/by-nc-sa/3.0/deed.en
*
* This header must be placed in the beginning of any version of this file.
*/
package eas.users.lukas.primeProperties.primeEvolution;
import java.util.List;
import eas.simulation.agent.GenericSensor;
import eas.simulation.spatial.sim2D.standardAgents.AbstractAgent2D;
import eas.startSetup.ParCollection;
import eas.startSetup.SingleParameter;
import eas.startSetup.parameterDatatypes.Datatypes;
/**
* @author lko
*/
public class PrimeAgent extends AbstractAgent2D<PrimeEnvironment> {
/**
*
*/
private static final long serialVersionUID = 7490607160547513705L;
private PolynomeGenome pol;
public PolynomeGenome getPol() {
return this.pol;
}
@Override
public List<SingleParameter> getParameters() {
List<SingleParameter> list = super.getParameters();
list.add(new SingleParameter("GenomeLength", Datatypes.integerRange(1, 500), 50, "Genome length = number of coefficients", "PRIMES"));
return list;
}
public PrimeAgent(int id, PrimeEnvironment env, ParCollection params) {
super(id, env, params);
pol = new PolynomeGenome(params.getParValueInt("GenomeLength"));
for (int i = 0; i < 50; i++) {
pol.mutateRandomPositionPlusMinusOne();
}
this.addSensor(new GenericSensor<PolynomeGenome, PrimeEnvironment, PrimeAgent>() {
/**
*
*/
private static final long serialVersionUID = -7899157572078253373L;
@Override
public PolynomeGenome sense(PrimeEnvironment env, PrimeAgent agent) {
return agent.pol;
}
@Override
public String id() {
return "Polynome";
}
});
}
}