#region License Information
/* HeuristicLab
* Copyright (C) 2002-2019 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
using System.Linq;
using HeuristicLab.Core;
using HeuristicLab.Encodings.IntegerVectorEncoding;
using HeuristicLab.Encodings.PermutationEncoding;
using HeuristicLab.Tests;
namespace HeuristicLab.Encodings.ScheduleEncoding.Tests {
public class TestUtils {
public static JSMEncoding CreateTestJSM1() {
JSMEncoding result = new JSMEncoding(0);
ItemList jsm = result.JobSequenceMatrix;
for (int i = 0; i < 6; i++)
jsm.Add(new Permutation(PermutationTypes.Absolute, new int[] { 0, 1, 2, 3, 4, 5 }));
return result;
}
public static JSMEncoding CreateTestJSM2() {
JSMEncoding result = new JSMEncoding(0);
ItemList jsm = result.JobSequenceMatrix;
for (int i = 0; i < 6; i++)
jsm.Add(new Permutation(PermutationTypes.Absolute, new int[] { 5, 4, 3, 2, 1, 0 }));
return result;
}
public static PWREncoding CreateTestPWR1() {
PWREncoding result = new PWREncoding();
IntegerVector pwr = new IntegerVector(new int[] { 1, 0, 1, 1, 2, 0, 2, 2, 0 });
result.PermutationWithRepetition = pwr;
return result;
}
public static PWREncoding CreateTestPWR2() {
PWREncoding result = new PWREncoding();
IntegerVector pwr = new IntegerVector(new int[] { 0, 1, 1, 0, 2, 0, 1, 2, 2 });
result.PermutationWithRepetition = pwr;
return result;
}
public static ItemList CreateJobData() {
Job j1 = new Job(0, 0);
j1.Tasks.AddRange(new[]{
new Task (0, 0, j1.Index, 1),
new Task (1, 1, j1.Index, 2),
new Task (2, 2, j1.Index, 1)
});
Job j2 = new Job(1, 0);
j2.Tasks.AddRange(new[]{
new Task (3, 2, j2.Index, 2),
new Task (4, 1, j2.Index, 1),
new Task (5, 0, j2.Index, 2)
});
Job j3 = new Job(2, 0);
j3.Tasks.AddRange(new[]{
new Task (6, 0, j3.Index, 1),
new Task (7, 2, j3.Index, 2),
new Task (8, 1, j3.Index, 1)
});
return new ItemList { j1, j2, j3 };
}
public static Schedule CreateTestSchedule1() {
Schedule result = DirectScheduleRandomCreator.Apply(new PWREncoding(3, 3, new TestRandom(new int[] { 1, 0, 1, 1, 2, 0, 2, 2, 0 }, null)), CreateJobData());
return result;
}
public static Schedule CreateTestSchedule2() {
Schedule result = DirectScheduleRandomCreator.Apply(new PWREncoding(3, 3, new TestRandom(new int[] { 0, 1, 1, 0, 2, 0, 1, 2, 2 }, null)), CreateJobData());
return result;
}
public static bool ScheduleEquals(Schedule actual, Schedule expected) {
return actual.Resources.Count == expected.Resources.Count &&
actual.Resources.Zip(expected.Resources, (a, e) => ResourceEquals(a, e)).All(_ => _);
}
public static bool ResourceEquals(Resource actual, Resource expected) {
return actual.Index == expected.Index &&
actual.TotalDuration == expected.TotalDuration &&
actual.Tasks.Count == expected.Tasks.Count &&
actual.Tasks.Zip(expected.Tasks, (a, e) => TaskEquals(a, e)).All(_ => _);
}
public static bool TaskEquals(ScheduledTask actual, ScheduledTask expected) {
return
actual.StartTime == expected.StartTime &&
actual.EndTime == expected.EndTime &&
actual.Duration == expected.Duration &&
actual.ResourceNr == expected.ResourceNr &&
actual.JobNr == expected.JobNr &&
actual.TaskNr == expected.TaskNr;
}
public static bool JSMEncodingEquals(JSMEncoding expected, JSMEncoding actual) {
if (expected.JobSequenceMatrix.Count != actual.JobSequenceMatrix.Count)
return false;
for (int i = 0; i < expected.JobSequenceMatrix.Count; i++) {
if (!PermutationEquals(expected.JobSequenceMatrix[i], actual.JobSequenceMatrix[i]))
return false;
}
return true;
}
private static bool PermutationEquals(Permutation p1, Permutation p2) {
if (p1.Length != p2.Length)
return false;
for (int i = 0; i < p1.Length; i++) {
if (p1[i] != p2[i])
return false;
}
return true;
}
public static bool PRWEncodingEquals(PWREncoding expected, PWREncoding actual) {
if (expected.PermutationWithRepetition.Length != actual.PermutationWithRepetition.Length)
return false;
for (int i = 0; i < expected.PermutationWithRepetition.Length; i++) {
if (expected.PermutationWithRepetition[i] != actual.PermutationWithRepetition[i])
return false;
}
return true;
}
}
}