Free cookie consent management tool by TermsFeed Policy Generator

source: stable/HeuristicLab.Encodings.ScheduleEncoding/3.3/JobSequenceMatrix/Crossovers/JSMSXXCrossover.cs @ 17877

Last change on this file since 17877 was 17181, checked in by swagner, 5 years ago

#2875: Merged r17180 from trunk to stable

File size: 3.8 KB
RevLine 
[6406]1#region License Information
2/* HeuristicLab
[17181]3 * Copyright (C) Heuristic and Evolutionary Algorithms Laboratory (HEAL)
[6406]4 *
5 * This file is part of HeuristicLab.
6 *
7 * HeuristicLab is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * HeuristicLab is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with HeuristicLab. If not, see <http://www.gnu.org/licenses/>.
19 */
20#endregion
21
22using HeuristicLab.Common;
23using HeuristicLab.Core;
24using HeuristicLab.Encodings.PermutationEncoding;
[17097]25using HEAL.Attic;
[6406]26
27namespace HeuristicLab.Encodings.ScheduleEncoding.JobSequenceMatrix {
28  [Item("JSMSubsequenceExchangeCrossover", "Represents a crossover operation identifiying and exchanging equal subsequences of the parents to generate offspring.")]
[17097]29  [StorableType("029A3890-FEB7-4D01-9092-E33CEBD8C0CC")]
[6406]30  public class JSMSXXCrossover : JSMCrossover {
[8887]31
[6406]32    [StorableConstructor]
[17097]33    protected JSMSXXCrossover(StorableConstructorFlag _) : base(_) { }
[8887]34    protected JSMSXXCrossover(JSMSXXCrossover original, Cloner cloner) : base(original, cloner) { }
35    public JSMSXXCrossover() : base() { }
36
[6406]37    public override IDeepCloneable Clone(Cloner cloner) {
38      return new JSMSXXCrossover(this, cloner);
39    }
40
41    public static JSMEncoding Apply(IRandom random, JSMEncoding parent1, JSMEncoding parent2) {
[8887]42      var result = new JSMEncoding();
[6406]43      int subSequenceLength = random.Next(parent1.JobSequenceMatrix[0].Length);
44      for (int i = 0; i < parent1.JobSequenceMatrix.Count; i++) {
[8887]45        var p1 = (Permutation)parent1.JobSequenceMatrix[i].Clone();
46        var p2 = (Permutation)parent2.JobSequenceMatrix[i].Clone();
[6406]47        FindAndExchangeSubsequences(p1, p2, subSequenceLength);
48        result.JobSequenceMatrix.Add(p1);
49      }
50      return result;
51    }
[8887]52
[6406]53    private static void FindAndExchangeSubsequences(Permutation p1, Permutation p2, int subSequenceLength) {
54      for (int i = 0; i <= p1.Length - subSequenceLength; i++) {
55        int[] ss1 = GetSubSequenceAtPosition(p1, i, subSequenceLength);
56        for (int j = 0; j <= p2.Length - subSequenceLength; j++) {
57          int[] ss2 = GetSubSequenceAtPosition(p2, j, subSequenceLength);
58          if (AreEqualSubsequences(ss1, ss2)) {
59            ExchangeSubsequences(p1, i, p2, j, subSequenceLength);
60            return;
61          }
62        }
63      }
64    }
[8887]65
[6406]66    private static void ExchangeSubsequences(Permutation p1, int index1, Permutation p2, int index2, int subSequenceLength) {
[8887]67      var aux = (Permutation)p1.Clone();
[6406]68      for (int i = 0; i < subSequenceLength; i++) {
69        p1[i + index1] = p2[i + index2];
70        p2[i + index2] = aux[i + index1];
71      }
72    }
[8887]73
[6406]74    private static bool AreEqualSubsequences(int[] ss1, int[] ss2) {
75      int counter = 0;
76      for (int i = 0; i < ss1.Length; i++) {
77        for (int j = 0; j < ss2.Length; j++) {
78          if (ss1[i] == ss2[j])
79            counter++;
80        }
81      }
82      return counter == ss1.Length;
83    }
[8887]84
[6406]85    private static int[] GetSubSequenceAtPosition(Permutation p1, int index, int subSequenceLength) {
[8887]86      var result = new int[subSequenceLength];
[6406]87      for (int i = 0; i < subSequenceLength; i++)
88        result[i] = p1[i + index];
89
90      return result;
91    }
92
93    public override JSMEncoding Cross(IRandom random, JSMEncoding parent1, JSMEncoding parent2) {
94      return Apply(random, parent1, parent2);
95    }
96  }
97}
Note: See TracBrowser for help on using the repository browser.