data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
es.urjc.etsii.grafo.experiment.AbstractExperiment Maven / Gradle / Ivy
package es.urjc.etsii.grafo.experiment;
import es.urjc.etsii.grafo.algorithms.Algorithm;
import es.urjc.etsii.grafo.annotations.InheritedComponent;
import es.urjc.etsii.grafo.io.Instance;
import es.urjc.etsii.grafo.solution.Solution;
import java.util.List;
/**
* Defines an experiment to execute.
* Each experiment is defined by extending this class, multiple experiments can be defined at the same time.
* By default, all experiments are executed at runtime, but this behaviour can be changed in the application.yml configuration file.
*
* @param Solution class
* @param Instance class
*/
@InheritedComponent
public abstract class AbstractExperiment, I extends Instance> {
/**
* Initialize common fields for all experiments
*
*/
protected AbstractExperiment() {}
/**
* Get list of algorithms defined in this experiment. Each experiment can define a different set of algorithms.
* Although the same algorithm can be used several times in the same experiment,
* if you return the same configuration for the same algorithm an exception will be thrown.
*
* @return list of algorithms defined in this experiment
*/
public abstract List> getAlgorithms();
/**
* Return the current experiment name. If not overridden, defaults to the Java class name.
*
* @return Experiment name as string
*/
public String getName() {
return this.getClass().getSimpleName();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy