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

it.unibo.alchemist.model.conditions.MoleculeHasConcentration Maven / Gradle / Ivy

Go to download

Abstract, incarnation independent implementations of the Alchemist's interfaces. Provides support for those who want to write incarnations.

There is a newer version: 35.0.1
Show newest version
/*
 * Copyright (C) 2010-2023, 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.conditions;

import it.unibo.alchemist.model.Condition;
import it.unibo.alchemist.model.Context;
import it.unibo.alchemist.model.Molecule;
import it.unibo.alchemist.model.Node;
import it.unibo.alchemist.model.Reaction;

import java.util.Objects;

/**
 * A condition that is valid iff a molecule has exactly the desired concentration.
 * 
 * @param  concentration type
 */
public final class MoleculeHasConcentration extends AbstractCondition {

    private static final long serialVersionUID = 1L;
    private final Molecule mol;
    private final T value;

    /**
     * @param node
     *            the node
     * @param molecule
     *            the target molecule
     * @param value
     *            the desired concentration
     */
    public MoleculeHasConcentration(final Node node, final Molecule molecule, final T value) {
        super(node);
        this.mol = Objects.requireNonNull(molecule);
        this.value = Objects.requireNonNull(value);
        declareDependencyOn(this.mol);
    }

    @Override
    public Condition cloneCondition(final Node node, final Reaction reaction) {
        return new MoleculeHasConcentration<>(node, mol, value);
    }

    @Override
    public Context getContext() {
        return Context.LOCAL;
    }

    @Override
    public double getPropensityContribution() {
        return isValid() ? 1 : 0;
    }

    @Override
    public boolean isValid() {
        return value.equals(getNode().getConcentration(mol));
    }

    @Override
    public String toString() {
        return mol + "=" + value + "?[" + isValid() + "]";
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy