#region License Information
/* HeuristicLab
* Copyright (C) 2002-2012 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
*
* This file is part of HeuristicLab.
*
* HeuristicLab is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* HeuristicLab is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with HeuristicLab. If not, see .
*/
#endregion
namespace HeuristicLab.Problems.Instances {
///
/// Describes instances of the Capacitated Task Assignment Problem (CTAP).
///
public interface ICTAPInstance {
///
/// The name of the instance
///
string Name { get; }
///
/// Optional! The description of the instance
///
string Description { get; }
///
/// The number M of processors
///
int Processors { get; }
///
/// The number N of tasks
///
int Tasks { get; }
///
/// An MxN Matrix with M = |Processors| and N = |Tasks|
///
double[,] ExecutionCosts { get; }
///
/// An NxN Matrix with N = |Tasks|
///
double[,] CommunicationCosts { get; }
///
/// An array of length N with N = |Tasks|
///
double[] MemoryRequirements { get; }
///
/// An array of length M with M = |Processors|
///
double[] MemoryCapacities { get; }
///
/// Optional! An array of length N with N = |Tasks|
///
int[] BestKnownAssignment { get; }
///
/// Optional! The quality value of the
///
double? BestKnownQuality { get; }
}
}