it.unibo.alchemist.model.implementations.nodes.LsaNode Maven / Gradle / Ivy
/*
* Copyright (C) 2010-2022, Danilo Pianini and contributors
* listed, for each module, in the respective subproject's build.gradle.kts 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.nodes;
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.interfaces.Environment;
import it.unibo.alchemist.model.interfaces.ILsaMolecule;
import it.unibo.alchemist.model.interfaces.ILsaNode;
import it.unibo.alchemist.model.interfaces.Molecule;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* This class realizes a node with LSA concentration.
*/
public final class LsaNode extends GenericNode> implements ILsaNode {
private static final long serialVersionUID = -2167025208984968645L;
private final List instances = new ArrayList<>();
private static final ILsaMolecule ZEROMOL = new LsaMolecule("0");
/**
* @param environment
* The environment (used for safe node id computation)
*/
public LsaNode(final Environment, ?> environment) {
super(environment);
}
@Override
public boolean contains(@Nonnull final Molecule molecule) {
if (molecule instanceof ILsaMolecule) {
final ILsaMolecule toMatch = (ILsaMolecule) molecule;
return instances.stream().anyMatch(mol -> mol.matches(toMatch));
}
return false;
}
@Override
@Nullable
protected List createT() { // NOPMD: this must return null, not an empty collection.
return null; // NOPMD: this must return null, not an empty collection.
}
@Override
public int getMoleculeCount() {
return instances.size();
}
@Override
public List getConcentration(@Nonnull final Molecule m) {
if (!(m instanceof ILsaMolecule)) {
throw new IllegalArgumentException(m + " is not a compatible molecule type");
}
final ILsaMolecule mol = (ILsaMolecule) m;
final ArrayList listMol = new ArrayList<>();
for (final ILsaMolecule instance : instances) {
if (mol.matches(instance)) {
listMol.add(instance);
}
}
return listMol;
}
@Override
@Nonnull
public Map> getContents() {
final Map> res = new HashMap<>(instances.size(), 1.0f);
for (final ILsaMolecule m : instances) {
final List l;
if (res.containsKey(m)) {
/*
* Safe by construction.
*/
l = res.get(m);
} else {
l = new ArrayList<>(1);
l.add(ZEROMOL);
res.put(m, l);
}
final Double v = (Double) l.get(0).getArg(0).getRootNodeData() + 1;
final IExpression e = new Expression(new NumTreeNode(v));
l.set(0, new LsaMolecule(Collections.singletonList(e)));
}
return res;
}
@Override
public List getLsaSpace() {
return Collections.unmodifiableList(instances);
}
@Override
public boolean removeConcentration(final ILsaMolecule matchedInstance) {
for (int i = 0; i < instances.size(); i++) {
if (matchedInstance.matches(instances.get(i))) {
instances.remove(i);
return true;
}
}
throw new IllegalStateException("Tried to remove missing " + matchedInstance + " from " + this);
}
@Override
public void setConcentration(final ILsaMolecule inst) {
if (inst.isIstance()) {
instances.add(inst);
} else {
throw new IllegalStateException("Tried to insert uninstanced " + inst + " into " + this);
}
}
@Override
public void setConcentration(@Nonnull final Molecule molecule, final List c) {
if (molecule instanceof ILsaMolecule) {
final ILsaMolecule il = (ILsaMolecule) molecule;
setConcentration(il);
} else {
throw new IllegalArgumentException(molecule + " is not a compatible molecule type");
}
}
@Override
@Nonnull
public String toString() {
return getId() + " contains: " + instances.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy