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

it.unibo.alchemist.model.reactions.ChemicalReaction 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.reactions;

import it.unibo.alchemist.model.Condition;
import it.unibo.alchemist.model.Environment;
import it.unibo.alchemist.model.Node;
import it.unibo.alchemist.model.Time;
import it.unibo.alchemist.model.TimeDistribution;

import javax.annotation.Nonnull;

/**
 * 
 * 
 * @param  concentration type
 */
public class ChemicalReaction extends AbstractReaction {

    private static final long serialVersionUID = -5260452049415003046L;
    private double currentRate;

    /**
     * @param n
     *            node
     * @param pd
     *            time distribution
     */
    public ChemicalReaction(final Node n, final TimeDistribution pd) {
        super(n, pd);
    }

    /**
     * {@inheritDoc}
     */
    @Nonnull
    @Override
    public ChemicalReaction cloneOnNewNode(@Nonnull final Node node, @Nonnull final Time currentTime) {
        return makeClone(() -> new ChemicalReaction<>(node, getTimeDistribution().cloneOnNewNode(node, currentTime)));
    }

    @Override
    public final void initializationComplete(@Nonnull final Time atTime, @Nonnull final Environment environment) {
        update(atTime, true, environment);
    }

    /**
     * Subclasses must call super.updateInternalStatus for the rate to get updated in case of method override.
     */
    @Override
    protected void updateInternalStatus(
            final Time currentTime,
            final boolean hasBeenExecuted,
            final Environment environment
    ) {
        currentRate = getTimeDistribution().getRate();
        for (final Condition cond : getConditions()) {
            final double v = cond.getPropensityContribution();
            if (v == 0) {
                currentRate = 0;
                break;
            }
            if (v < 0) {
                throw new IllegalStateException("Condition " + cond + " returned a negative propensity conditioning value");
            }
            currentRate *= cond.getPropensityContribution();
        }
    }

    @Override
    public final double getRate() {
        return currentRate;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy