All Downloads are FREE. Search and download functionalities are using the official Maven repository.

it.unibo.alchemist.model.implementations.actions.LsaAscendingGradientDist Maven / Gradle / Ivy

/*
 * Copyright (C) 2010-2019, Danilo Pianini and contributors listed in the main project's alchemist/build.gradle file.
 *
 * This file is part of Alchemist, and is distributed under the terms of the
 * GNU General Public License, with a linking exception,
 * as described in the file LICENSE in the Alchemist distribution's top directory.
 */
package it.unibo.alchemist.model.implementations.actions;

import it.unibo.alchemist.expressions.implementations.AST;
import it.unibo.alchemist.expressions.implementations.Expression;
import it.unibo.alchemist.expressions.implementations.NumTreeNode;
import it.unibo.alchemist.expressions.interfaces.IExpression;
import it.unibo.alchemist.model.implementations.molecules.LsaMolecule;
import it.unibo.alchemist.model.implementations.nodes.LsaNode;
import it.unibo.alchemist.model.interfaces.Environment;
import it.unibo.alchemist.model.interfaces.ILsaMolecule;
import it.unibo.alchemist.model.interfaces.ILsaNode;
import it.unibo.alchemist.model.interfaces.Neighborhood;
import it.unibo.alchemist.model.interfaces.Node;
import it.unibo.alchemist.model.interfaces.Position;

import java.util.ArrayList;
import java.util.List;


/**
 *
 * @param 

position type */ public final class LsaAscendingGradientDist

> extends SAPERENeighborAgent

{ private static final long serialVersionUID = 7719580008466360029L; private static final ILsaMolecule MOLGRAD = new LsaMolecule("grad, req, Type, Distance, Time"); private static final ILsaMolecule MOLRESPONSE = new LsaMolecule("response, Req, Ser, MD, D"); private static final int POS = 3; private final Environment, ?> environment; /** * @param environment environment * @param node node */ public LsaAscendingGradientDist(final Environment, P> environment, final ILsaNode node) { super(environment, node, MOLRESPONSE); this.environment = environment; } @Override public void execute() { double minGrad = getLSAArgumentAsDouble(getNode().getConcentration(MOLGRAD).get(0), POS); final Neighborhood> neigh = environment.getNeighborhood(getNode()); final List targetPositions = new ArrayList<>(); for (final Node> node : neigh.getNeighbors()) { final LsaNode n = (LsaNode) node; final List gradList; gradList = n.getConcentration(MOLGRAD); if (!gradList.isEmpty()) { for (final ILsaMolecule iExpressions : gradList) { final double valueGrad = (Double) iExpressions.getArg(POS).calculate(null).getValue(null); if (valueGrad <= minGrad) { minGrad = valueGrad; targetPositions.add(n); } } } } if (!targetPositions.isEmpty()) { final P pd = getPosition(targetPositions.get(targetPositions.size() - 1)); final double distance = getCurrentPosition().distanceTo(pd); final List l = MOLRESPONSE.allocateVar(getMatches()); final IExpression d = l.remove(l.size() - 1); final double olddistance = (Double) d.getRootNodeData(); final double newdistance = distance + olddistance; l.add(new Expression(new AST(new NumTreeNode(newdistance)))); final LsaMolecule mol = new LsaMolecule(l); (targetPositions.get(targetPositions.size() - 1)).setConcentration(mol); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy