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

it.unibo.alchemist.core.ArrayIndexedPriorityQueue Maven / Gradle / Ivy

There is a newer version: 35.0.0
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.core;

import edu.umd.cs.findbugs.annotations.SuppressFBWarnings;
import gnu.trove.impl.Constants;
import gnu.trove.map.TObjectIntMap;
import gnu.trove.map.hash.TObjectIntHashMap;
import it.unibo.alchemist.model.Actionable;
import it.unibo.alchemist.model.Time;

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

/**
 * This class implements the indexed priority queue through an Array.
 *
 * @param  concentration type
 */
public final class ArrayIndexedPriorityQueue implements Scheduler {

    private final TObjectIntMap> indexes =
        new TObjectIntHashMap<>(Constants.DEFAULT_CAPACITY, Constants.DEFAULT_LOAD_FACTOR, -1);
    private final List




© 2015 - 2024 Weber Informatics LLC | Privacy Policy