/*
* File name: StupidEnvironment.java (package eas.users.lukas.demos.stupidModel)
* Author(s): Lukas König
* Java version: 6.0
* Generation date: 14.09.2011 (16:10:24)
*
* (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.demos.stupidModel;
import java.util.Random;
import eas.simulation.Wink;
import eas.simulation.spatial.sim2D.gridSimulation.standardEnvironments.AbstractGridEnvironment;
import eas.simulation.spatial.sim2D.gridSimulation.standardGridObjects.GridDoubleValue;
import eas.startSetup.ParCollection;
/**
* @author Lukas König
*
*/
public class StupidEnvironment extends AbstractGridEnvironment<StupidBug> {
/**
*
*/
private static final long serialVersionUID = -9175099686722551281L;
/**
* @param ident
* @param params
* @param width
* @param height
* @param isTorus
*/
public StupidEnvironment(int ident, ParCollection params, int width,
int height, boolean isTorus) {
super(ident, params, width, height, isTorus);
}
private double regrowRate = 0.0;
public void setRegrowRate(double rate) {
this.regrowRate = rate;
}
private Random rand = new Random();
@Override
public void step(Wink simTime) {
super.step(simTime);
for (int i = 0; i < this.getWidth(); i++) {
for (int j = 0; j < this.getHeight(); j++) {
if (rand.nextDouble() < regrowRate) {
GridDoubleValue gdv = (GridDoubleValue) this.getFieldPosition(i, j).get(0);
double value = rand.nextDouble() * regrowRate;
value = gdv.getMaxValue() * value;
if (value > gdv.getValue()) {
gdv.setValue(value);
}
}
}
}
}
}