- Timestamp:
- 07/12/16 19:34:31 (8 years ago)
- Location:
- branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings
- Files:
-
- 49 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/GroupingVectorCrossover.cs
r13032 r14046 23 23 using HeuristicLab.Core; 24 24 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 25 using HeuristicLab.Problems.BinPacking .Interfaces;25 using HeuristicLab.Problems.BinPacking; 26 26 27 27 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/GroupingVectorDiscreteCrossover.cs
r13032 r14046 24 24 using HeuristicLab.Encodings.IntegerVectorEncoding; 25 25 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 26 using HeuristicLab.Problems.BinPacking.Interfaces; 26 using HeuristicLab.Problems.BinPacking; 27 27 28 28 29 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/GroupingVectorEncoding.cs
r13613 r14046 28 28 using HeuristicLab.Encodings.IntegerVectorEncoding; 29 29 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 30 using HeuristicLab.Problems.BinPacking .Interfaces;30 using HeuristicLab.Problems.BinPacking; 31 31 32 32 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/GroupingVectorManipulator.cs
r13032 r14046 24 24 using HeuristicLab.Core; 25 25 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 26 using HeuristicLab.Problems.BinPacking .Interfaces;26 using HeuristicLab.Problems.BinPacking; 27 27 28 28 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/GroupingVectorSinglePointCrossover.cs
r13032 r14046 24 24 using HeuristicLab.Encodings.IntegerVectorEncoding; 25 25 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 26 using HeuristicLab.Problems.BinPacking.Interfaces; 26 using HeuristicLab.Problems.BinPacking; 27 27 28 28 29 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/Moves/ChangeGrouping/ChangeGroupingMove.cs
r13032 r14046 25 25 using HeuristicLab.Encodings.IntegerVectorEncoding; 26 26 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 27 using HeuristicLab.Problems.BinPacking .Interfaces;27 using HeuristicLab.Problems.BinPacking; 28 28 29 29 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { 30 30 [Item("Change Grouping Move", "A move on a grouping vector that is specified by a single group-assignment-index.")] 31 31 [StorableClass] 32 public class ChangeGroupingMove : GroupingMove, IPackingMove {32 public class ChangeGroupingMove : GroupingMove, IPackingMove { 33 33 [Storable] 34 34 public int Index { get; protected set; } -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/Moves/ChangeGrouping/ChangeGroupingMoveGenerator.cs
r13032 r14046 26 26 using HeuristicLab.Parameters; 27 27 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 28 using HeuristicLab.Problems.BinPacking .Interfaces;28 using HeuristicLab.Problems.BinPacking; 29 29 30 30 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/Moves/GroupingMove.cs
r13032 r14046 24 24 using HeuristicLab.Core; 25 25 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 26 using HeuristicLab.Problems.BinPacking .Interfaces;26 using HeuristicLab.Problems.BinPacking; 27 27 28 28 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/Moves/GroupingMoveHardTabuCriterion.cs
r13032 r14046 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking .Interfaces;29 using HeuristicLab.Problems.BinPacking; 30 30 31 31 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/Moves/GroupingMoveMaker.cs
r13032 r14046 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking.Interfaces; 29 using HeuristicLab.Problems.BinPacking; 30 30 31 31 32 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/Moves/GroupingMoveSoftTabuCriterion.cs
r13032 r14046 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking .Interfaces;29 using HeuristicLab.Problems.BinPacking; 30 30 31 31 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/Moves/GroupingTabuMaker.cs
r13032 r14046 25 25 using HeuristicLab.Parameters; 26 26 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 27 using HeuristicLab.Problems.BinPacking.Interfaces; 27 using HeuristicLab.Problems.BinPacking; 28 28 29 29 30 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { 30 31 [Item("Grouping tabu maker", "Declares a given grouping move as tabu, by adding its attributes to the tabu list and also store the solution quality or the move quality (whichever is better).")] 31 32 [StorableClass] 32 public class GroupingTabuMaker : TabuMaker, IGroupingVectorMoveOperator {33 public class GroupingTabuMaker : TabuMaker, IGroupingVectorMoveOperator { 33 34 public ILookupParameter<IPackingMove> PackingMoveParameter { 34 35 get { return (ILookupParameter<IPackingMove>)Parameters["PackingMove"]; } … … 43 44 public GroupingTabuMaker() 44 45 : base() { 45 46 Parameters.Add(new LookupParameter<IPackingMove>("PackingMove", "The move to evaluate.")); 46 47 Parameters.Add(new LookupParameter<GroupingVectorEncoding>("GroupingVector", "The solution to evaluate.")); 47 48 } … … 53 54 protected override IItem GetTabuAttribute(bool maximization, double quality, double moveQuality) { 54 55 IPackingMove move = PackingMoveParameter.ActualValue; 55 GroupingVectorEncoding groupingVector = GroupingVectorParameter.ActualValue; 56 GroupingVectorEncoding groupingVector = GroupingVectorParameter.ActualValue; 56 57 double baseQuality = moveQuality; 57 if (maximization && quality > moveQuality || !maximization && quality < moveQuality) 58 if (maximization && quality > moveQuality || !maximization && quality < moveQuality) 58 59 baseQuality = quality; // we make an uphill move, the lower bound is the solution quality 59 60 -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/Moves/SwapGrouping/SwapGroupingMove.cs
r13032 r14046 25 25 using HeuristicLab.Encodings.IntegerVectorEncoding; 26 26 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 27 using HeuristicLab.Problems.BinPacking.Interfaces; 27 using HeuristicLab.Problems.BinPacking; 28 28 29 29 30 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/GroupingVector/Moves/SwapGrouping/SwapGroupingMoveGenerator.cs
r13032 r14046 26 26 using HeuristicLab.Parameters; 27 27 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 28 using HeuristicLab.Problems.BinPacking.Interfaces; 28 using HeuristicLab.Problems.BinPacking; 29 29 30 30 31 namespace HeuristicLab.Encodings.PackingEncoding.GroupingVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/Moves/Multi/Moves/ChangePositionMove.cs
r13032 r14046 23 23 using HeuristicLab.Core; 24 24 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 25 using HeuristicLab.Problems.BinPacking .Interfaces;25 using HeuristicLab.Problems.BinPacking; 26 26 27 27 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/Moves/Multi/Moves/SingleGroupingMove.cs
r13032 r14046 23 23 using HeuristicLab.Core; 24 24 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 25 using HeuristicLab.Problems.BinPacking .Interfaces;25 using HeuristicLab.Problems.BinPacking; 26 26 27 27 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/Moves/Multi/Moves/SingleItemRotationMove.cs
r13032 r14046 23 23 using HeuristicLab.Core; 24 24 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 25 using HeuristicLab.Problems.BinPacking .Interfaces;25 using HeuristicLab.Problems.BinPacking; 26 26 27 27 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/Moves/Multi/Moves/SwapPositionMove.cs
r13032 r14046 23 23 using HeuristicLab.Core; 24 24 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 25 using HeuristicLab.Problems.BinPacking .Interfaces;25 using HeuristicLab.Problems.BinPacking; 26 26 27 27 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/Moves/MultiComponentVectorMove.cs
r13032 r14046 24 24 using HeuristicLab.Core; 25 25 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 26 using HeuristicLab.Problems.BinPacking.Interfaces; 26 using HeuristicLab.Problems.BinPacking; 27 27 28 28 29 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/Moves/MultiComponentVectorMoveGenerator.cs
r13032 r14046 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking.Interfaces; 29 using HeuristicLab.Problems.BinPacking; 30 30 31 31 32 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/Moves/MultiComponentVectorMoveHardTabuCriterion.cs
r13032 r14046 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking .Interfaces;29 using HeuristicLab.Problems.BinPacking; 30 30 31 31 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/Moves/MultiComponentVectorMoveMaker.cs
r13032 r14046 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking.Interfaces; 29 using HeuristicLab.Problems.BinPacking; 30 30 31 31 32 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/Moves/MultiComponentVectorMoveSoftTabuCriterion.cs
r13032 r14046 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking .Interfaces;29 using HeuristicLab.Problems.BinPacking; 30 30 31 31 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/Moves/MultiComponentVectorTabuMaker.cs
r13032 r14046 25 25 using HeuristicLab.Parameters; 26 26 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 27 using HeuristicLab.Problems.BinPacking.Interfaces; 27 using HeuristicLab.Problems.BinPacking; 28 28 29 29 30 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { 30 31 [Item("Multi component tabu maker", "Declares a given single grouping move as tabu, by adding its attributes to the tabu list and also store the solution quality or the move quality (whichever is better).")] 31 32 [StorableClass] 32 public class MultiComponentVectorTabuMaker : TabuMaker, IMultiComponentVectorMoveOperator {33 public class MultiComponentVectorTabuMaker : TabuMaker, IMultiComponentVectorMoveOperator { 33 34 public ILookupParameter<IPackingMove> PackingMoveParameter { 34 35 get { return (ILookupParameter<IPackingMove>)Parameters["PackingMove"]; } … … 43 44 public MultiComponentVectorTabuMaker() 44 45 : base() { 45 46 Parameters.Add(new LookupParameter<IPackingMove>("PackingMove", "The move to evaluate.")); 46 47 Parameters.Add(new LookupParameter<MultiComponentVectorEncoding>("MultiComponentVector", "The solution to evaluate.")); 47 48 } … … 55 56 MultiComponentVectorEncoding solution = MultiComponentVectorParameter.ActualValue; 56 57 double baseQuality = moveQuality; 57 if (maximization && quality > moveQuality || !maximization && quality < moveQuality) 58 if (maximization && quality > moveQuality || !maximization && quality < moveQuality) 58 59 baseQuality = quality; // we make an uphill move, the lower bound is the solution quality 59 60 60 61 MultiComponentVectorMove mcvMove = move as MultiComponentVectorMove; 61 62 if (mcvMove != null) -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/Moves/Triple/Moves/MCVTripleMove.cs
r13032 r14046 23 23 using HeuristicLab.Core; 24 24 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 25 using HeuristicLab.Problems.BinPacking .Interfaces;25 using HeuristicLab.Problems.BinPacking; 26 26 27 27 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/MultiComponentVectorCrossover.cs
r13032 r14046 23 23 using HeuristicLab.Core; 24 24 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 25 using HeuristicLab.Problems.BinPacking.Interfaces; 25 using HeuristicLab.Problems.BinPacking; 26 26 27 27 28 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { … … 35 36 public MultiComponentVectorCrossover() 36 37 : base() { 37 38 38 ParentsParameter.ActualName = "MultiComponentVector"; 39 ChildParameter.ActualName = "MultiComponentVector"; 39 40 } 40 41 -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/MultiComponentVectorEncoding.cs
r14041 r14046 28 28 using HeuristicLab.Encodings.PermutationEncoding; 29 29 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 30 using HeuristicLab.Problems.BinPacking .Interfaces;30 using HeuristicLab.Problems.BinPacking; 31 31 32 32 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/MultiComponentVector/MultiComponentVectorManipulator.cs
r13032 r14046 24 24 using HeuristicLab.Core; 25 25 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 26 using HeuristicLab.Problems.BinPacking.Interfaces; 26 using HeuristicLab.Problems.BinPacking; 27 27 28 28 29 namespace HeuristicLab.Encodings.PackingEncoding.MultiComponentVector { … … 35 36 public MultiComponentVectorManipulator() 36 37 : base() { 37 38 EncodedSolutionParameter.ActualName = "MultiComponentVector"; 38 39 } 39 40 -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingPlans/BinPacking.cs
r14045 r14046 22 22 using System.Collections.Generic; 23 23 using System.Linq; 24 using HeuristicLab.Problems.BinPacking.Interfaces;25 using HeuristicLab.Problems.BinPacking.Shapes;26 24 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 27 25 using HeuristicLab.Core; 28 26 using HeuristicLab.Common; 29 27 using HeuristicLab.Collections; 28 using HeuristicLab.Problems.BinPacking; 30 29 31 namespace HeuristicLab.Encodings.PackingEncoding .PackingPlan{30 namespace HeuristicLab.Encodings.PackingEncoding { 32 31 [Item("BinPacking", "Represents a single-bin packing for a bin-packing problem.")] 33 32 [StorableClass] -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingPlans/PackingPlan.cs
r14045 r14046 23 23 using System.Collections.Generic; 24 24 using System.Linq; 25 using HeuristicLab.Problems.BinPacking.Interfaces;26 using HeuristicLab.Problems.BinPacking.Shapes;27 25 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 28 26 using HeuristicLab.Core; … … 34 32 using HeuristicLab.Encodings.PackingEncoding.PackingSequence; 35 33 using HeuristicLab.Encodings.IntegerVectorEncoding; 36 37 namespace HeuristicLab.Encodings.PackingEncoding.PackingPlan { 34 using HeuristicLab.Problems.BinPacking; 35 36 namespace HeuristicLab.Encodings.PackingEncoding { 38 37 [Item("PackingPlan", "Represents a concrete solution for a bin-packing problem.")] 39 38 [StorableClass] -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/Moves/GroupingMoveHardTabuCriterion.cs
r13032 r14046 28 28 using HeuristicLab.Parameters; 29 29 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 30 using HeuristicLab.Problems.BinPacking .Interfaces;30 using HeuristicLab.Problems.BinPacking; 31 31 32 32 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { … … 83 83 int length = PackingSequence.PackingSequence.Length; 84 84 double moveQuality = MoveQualityParameter.ActualValue.Value; 85 bool maximization = MaximizationParameter.ActualValue.Value; 85 bool maximization = MaximizationParameter.ActualValue.Value; 86 86 bool useAspiration = UseAspirationCriterionParameter.Value.Value; 87 87 bool isTabu = IsMoveTabu(tabuList, move, PackingSequence, moveQuality, maximization, useAspiration); -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/Moves/GroupingMoveMaker.cs
r13032 r14046 28 28 using HeuristicLab.Parameters; 29 29 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 30 using HeuristicLab.Problems.BinPacking .Interfaces;30 using HeuristicLab.Problems.BinPacking; 31 31 32 32 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/Moves/GroupingMoveSoftTabuCriterion.cs
r13032 r14046 28 28 using HeuristicLab.Parameters; 29 29 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 30 using HeuristicLab.Problems.BinPacking.Interfaces; 30 using HeuristicLab.Problems.BinPacking; 31 31 32 32 33 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/Moves/Insertion/InsertionMove.cs
r13032 r14046 26 26 using HeuristicLab.Encodings.PermutationEncoding; 27 27 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 28 using HeuristicLab.Problems.BinPacking.Interfaces; 28 using HeuristicLab.Problems.BinPacking; 29 29 30 30 31 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { … … 102 103 } else 103 104 if (Index1 == attr.Index1 && Index2 == attr.Index2) 104 105 return true; 105 106 } 106 107 return false; … … 108 109 109 110 public override string ToString() { 110 return "IM(i1=" +Index1 + ", i2=" + Index2 +")";111 return "IM(i1=" + Index1 + ", i2=" + Index2 + ")"; 111 112 } 112 113 } -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/Moves/Insertion/InsertionMoveGenerator.cs
r13032 r14046 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking.Interfaces; 29 using HeuristicLab.Problems.BinPacking; 30 30 31 31 32 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/Moves/SequenceMove.cs
r13032 r14046 25 25 using HeuristicLab.Core; 26 26 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 27 using HeuristicLab.Problems.BinPacking .Interfaces;27 using HeuristicLab.Problems.BinPacking; 28 28 29 29 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/Moves/SequenceTabuMaker.cs
r13032 r14046 26 26 using HeuristicLab.Parameters; 27 27 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 28 using HeuristicLab.Problems.BinPacking .Interfaces;28 using HeuristicLab.Problems.BinPacking; 29 29 30 30 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { 31 31 [Item("Sequence tabu maker", "Declares a given Sequence move as tabu, by adding its attributes to the tabu list and also store the solution quality or the move quality (whichever is better).")] 32 32 [StorableClass] 33 public class SequenceTabuMaker : TabuMaker, IPackingSequenceMoveOperator {33 public class SequenceTabuMaker : TabuMaker, IPackingSequenceMoveOperator { 34 34 public ILookupParameter<IPackingMove> PackingMoveParameter { 35 35 get { return (ILookupParameter<IPackingMove>)Parameters["PackingMove"]; } … … 44 44 public SequenceTabuMaker() 45 45 : base() { 46 46 Parameters.Add(new LookupParameter<IPackingMove>("PackingMove", "The move to evaluate.")); 47 47 Parameters.Add(new LookupParameter<PackingSequenceEncoding>("PackingSequence", "The solution to evaluate.")); 48 48 } … … 54 54 protected override IItem GetTabuAttribute(bool maximization, double quality, double moveQuality) { 55 55 IPackingMove move = PackingMoveParameter.ActualValue; 56 PackingSequenceEncoding PackingSequence = PackingSequenceParameter.ActualValue; 56 PackingSequenceEncoding PackingSequence = PackingSequenceParameter.ActualValue; 57 57 double baseQuality = moveQuality; 58 if (maximization && quality > moveQuality || !maximization && quality < moveQuality) 58 if (maximization && quality > moveQuality || !maximization && quality < moveQuality) 59 59 baseQuality = quality; // we make an uphill move, the lower bound is the solution quality 60 60 -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/Moves/Swap2/Swap2Move.cs
r13032 r14046 26 26 using HeuristicLab.Encodings.PermutationEncoding; 27 27 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 28 using HeuristicLab.Problems.BinPacking.Interfaces; 28 using HeuristicLab.Problems.BinPacking; 29 29 30 30 31 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/Moves/Swap2/Swap2MoveGenerator.cs
r13032 r14046 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking .Interfaces;29 using HeuristicLab.Problems.BinPacking; 30 30 31 31 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/PackingSequenceCrossover.cs
r13032 r14046 24 24 using HeuristicLab.Core; 25 25 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 26 using HeuristicLab.Problems.BinPacking .Interfaces;26 using HeuristicLab.Problems.BinPacking; 27 27 28 28 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/PackingSequenceEncoding.cs
r14038 r14046 25 25 using HeuristicLab.Core; 26 26 using HeuristicLab.Encodings.PermutationEncoding; 27 using HeuristicLab.Optimization;28 27 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking.Interfaces; 28 using HeuristicLab.Problems.BinPacking; 29 30 30 31 31 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/PackingSequenceInversionManipulator.cs
r13461 r14046 25 25 using HeuristicLab.Encodings.PermutationEncoding; 26 26 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 27 using HeuristicLab.Problems.BinPacking.Interfaces; 27 using HeuristicLab.Problems.BinPacking; 28 28 29 29 30 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/PackingSequenceManipulator.cs
r13032 r14046 25 25 using HeuristicLab.Core; 26 26 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 27 using HeuristicLab.Problems.BinPacking .Interfaces;27 using HeuristicLab.Problems.BinPacking; 28 28 29 29 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { … … 36 36 public PackingSequenceManipulator() 37 37 : base() { 38 38 EncodedSolutionParameter.ActualName = "PackingSequence"; 39 39 } 40 40 -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/PackingSequenceOrderCrossover.cs
r13032 r14046 25 25 using HeuristicLab.Encodings.PermutationEncoding; 26 26 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 27 using HeuristicLab.Problems.BinPacking .Interfaces;27 using HeuristicLab.Problems.BinPacking; 28 28 29 29 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { … … 42 42 } 43 43 44 public override PackingSequenceEncoding Cross(IRandom random, PackingSequenceEncoding parent1, PackingSequenceEncoding parent2) 44 public override PackingSequenceEncoding Cross(IRandom random, PackingSequenceEncoding parent1, PackingSequenceEncoding parent2) { 45 45 PackingSequenceEncoding result = new PackingSequenceEncoding(); 46 46 result.PackingSequence = OrderCrossover.Apply(random, parent1.PackingSequence, parent2.PackingSequence); -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/PackingSequencePartiallyMatchedCrossover.cs
r13032 r14046 25 25 using HeuristicLab.Encodings.PermutationEncoding; 26 26 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 27 using HeuristicLab.Problems.BinPacking.Interfaces; 27 using HeuristicLab.Problems.BinPacking; 28 28 29 29 30 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { … … 42 43 } 43 44 44 public override PackingSequenceEncoding Cross(IRandom random, PackingSequenceEncoding parent1, PackingSequenceEncoding parent2) 45 public override PackingSequenceEncoding Cross(IRandom random, PackingSequenceEncoding parent1, PackingSequenceEncoding parent2) { 45 46 PackingSequenceEncoding result = new PackingSequenceEncoding(); 46 47 result.PackingSequence = PartiallyMatchedCrossover.Apply(random, parent1.PackingSequence, parent2.PackingSequence); -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSequence/PackingSequenceScrambleManipulator.cs
r13461 r14046 24 24 using HeuristicLab.Encodings.PermutationEncoding; 25 25 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 26 using HeuristicLab.Problems.BinPacking .Interfaces;26 using HeuristicLab.Problems.BinPacking; 27 27 28 28 namespace HeuristicLab.Encodings.PackingEncoding.PackingSequence { … … 35 35 public PackingSequenceScrambleManipulator() 36 36 : base() { 37 37 EncodedSolutionParameter.ActualName = "PackingSequence"; 38 38 } 39 39 public override IDeepCloneable Clone(Cloner cloner) { … … 43 43 protected override void Manipulate(IRandom random, PackingSequenceEncoding individual) { 44 44 ScrambleManipulator.Apply(random, individual.PackingSequence); 45 } 45 } 46 46 } 47 47 } -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSolutionCreator.cs
r13032 r14046 26 26 using HeuristicLab.Parameters; 27 27 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 28 using HeuristicLab.Problems.BinPacking .Interfaces;28 using HeuristicLab.Problems.BinPacking; 29 29 30 30 namespace HeuristicLab.Encodings.PackingEncoding { … … 42 42 public PackingSolutionCreator() 43 43 : base() { 44 44 Parameters.Add(new LookupParameter<IItem>("EncodedPackingSolution", "The new bin packing solution candidate.")); 45 45 } 46 46 -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSolutionCrossover.cs
r13032 r14046 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking .Interfaces;29 using HeuristicLab.Problems.BinPacking; 30 30 31 31 namespace HeuristicLab.Encodings.PackingEncoding { -
branches/HeuristicLab.BinPacking/HeuristicLab.Problems.BinPacking/3.3/Encodings/PackingSolutionManipulator.cs
r13032 r14046 27 27 using HeuristicLab.Parameters; 28 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; 29 using HeuristicLab.Problems.BinPacking .Interfaces;29 using HeuristicLab.Problems.BinPacking; 30 30 31 31 namespace HeuristicLab.Encodings.PackingEncoding { … … 47 47 public PackingSolutionManipulator() 48 48 : base() { 49 49 Parameters.Add(new LookupParameter<IPackingSolutionEncoding>("EncodedSolution", "The bin packing solution to be manipulated.")); 50 50 Parameters.Add(new LookupParameter<IRandom>("Random", "The pseudo random number generator which should be used for stochastic manipulation operators.")); 51 51 }
Note: See TracChangeset
for help on using the changeset viewer.