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

it.unibo.alchemist.model.interfaces.Context Maven / Gradle / Ivy

There is a newer version: 20.0.1
Show newest version
/*
 * 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.interfaces;

/**
 * This enum describes the possible contexts for a given {@link Action} or
 * {@link Condition}. A context represents the elements which are read for a
 * {@link Condition} and the elements that may be subject of modifications for
 * an {@link Action}. Choosing the right {@link Context} is crucial: if it's too
 * restricted the simulation will be invalid, if it's too wide it WILL impact
 * dramatically on performances. Contexts are used internally to better
 * determine dependencies among reactions. See
 * 
 * this paper for further information about the usage of contexts.
 * 
 */
public enum Context {
    /**
     * The reaction potentially influences every other reaction.
     */
    GLOBAL,
    /**
     * The reaction can influence only the node in which it's placed.
     */
    LOCAL,
    /**
     * The reaction may influence its node and the neighboring ones.
     */
    NEIGHBORHOOD;

    /**
     *
     * @param c1 context to compare
     * @param c2 other context to compare
     * @return the wider (more general) between the two: if either one is {@link #GLOBAL}, then {@link #GLOBAL} is
     * returned. Otherwise, if either one is {@link #NEIGHBORHOOD}, {@link #NEIGHBORHOOD} is returned. Otherwise,
     * {@link #LOCAL} is returned.
     */
    public static Context getWider(final Context c1, final Context c2) {
        if (c1 == GLOBAL || c2 == GLOBAL) {
            return GLOBAL;
        }
        if (c1 == NEIGHBORHOOD || c2 == NEIGHBORHOOD) {
            return NEIGHBORHOOD;
        }
        return LOCAL;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy