Free cookie consent management tool by TermsFeed Policy Generator

source: trunk/sources/HeuristicLab.Problems.VehicleRouting/3.4/ProblemInstances/SingleDepotVRP/CVRP/CVRPTW/CVRPPDTW/CVRPPDTWProblemInstance.cs @ 13578

Last change on this file since 13578 was 12488, checked in by pfleck, 10 years ago

#2400

  • Interfaces for Capaciated-, PickupAndDelivery- and TimeWindowed-ProblemInstances now specify an additional penalty parameter to set the current penalty factor for the constraint relaxation.
  • The setter of the penalty-property in the ProblemInstances is removed.
  • A CurrentPenalty property is added for setting the adapted penalty value from the relaxation analyzers. These properties are explicitly implemented to "hide" the setter from the API, so that it wont be used unaware of the relaxation mechanics.
  • Hide the CurrentPenaltyParameters for same reasons to avoid setting it unwarily.
  • Added additional infos in the error message off the VRPInstances unit-test.
File size: 5.3 KB
Line 
1#region License Information
2/* HeuristicLab
3 * Copyright (C) 2002-2015 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
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 System;
23using System.Collections.Generic;
24using System.Linq;
25using HeuristicLab.Common;
26using HeuristicLab.Core;
27using HeuristicLab.Data;
28using HeuristicLab.Optimization;
29using HeuristicLab.Parameters;
30using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
31using HeuristicLab.PluginInfrastructure;
32using HeuristicLab.Problems.VehicleRouting.Interfaces;
33using HeuristicLab.Problems.VehicleRouting.Variants;
34
35namespace HeuristicLab.Problems.VehicleRouting.ProblemInstances {
36  [Item("CVRPPDTWProblemInstance", "Represents a single depot CVRPPDTW instance.")]
37  [StorableClass]
38  public class CVRPPDTWProblemInstance : CVRPTWProblemInstance, IPickupAndDeliveryProblemInstance {
39    protected IValueParameter<IntArray> PickupDeliveryLocationParameter {
40      get { return (IValueParameter<IntArray>)Parameters["PickupDeliveryLocation"]; }
41    }
42    protected IValueParameter<DoubleValue> PickupViolationPenaltyParameter {
43      get { return (IValueParameter<DoubleValue>)Parameters["EvalPickupViolationPenalty"]; }
44    }
45
46    public IntArray PickupDeliveryLocation {
47      get { return PickupDeliveryLocationParameter.Value; }
48      set { PickupDeliveryLocationParameter.Value = value; }
49    }
50
51    protected IValueParameter<DoubleValue> CurrentPickupViolationPenaltyParameter {
52      get { return (IValueParameter<DoubleValue>)Parameters["CurrentPickupViolationPenalty"]; }
53    }
54
55    public DoubleValue PickupViolationPenalty {
56      get {
57        DoubleValue currentPickupViolationPenalty = CurrentPickupViolationPenaltyParameter.Value;
58        if (currentPickupViolationPenalty != null)
59          return currentPickupViolationPenalty;
60        else
61          return PickupViolationPenaltyParameter.Value;
62      }
63    }
64    DoubleValue IPickupAndDeliveryProblemInstance.CurrentPickupViolationPenalty {
65      get { return CurrentOverloadPenaltyParameter.Value; }
66      set { CurrentPickupViolationPenaltyParameter.Value = value; }
67    }
68
69    protected override IEnumerable<IOperator> GetOperators() {
70      return
71        ApplicationManager.Manager.GetInstances<IPickupAndDeliveryOperator>()
72        .Where(o => !(o is IAnalyzer))
73        .Cast<IOperator>().Union(base.GetOperators());
74    }
75
76    protected override IEnumerable<IOperator> GetAnalyzers() {
77      return ApplicationManager.Manager.GetInstances<IPickupAndDeliveryOperator>()
78        .Where(o => o is IAnalyzer)
79        .Cast<IOperator>().Union(base.GetAnalyzers());
80    }
81
82    protected override IVRPEvaluator Evaluator {
83      get {
84        return new CVRPPDTWEvaluator();
85      }
86    }
87
88    public int GetPickupDeliveryLocation(int city) {
89      return PickupDeliveryLocation[city];
90    }
91
92    [StorableConstructor]
93    protected CVRPPDTWProblemInstance(bool deserializing) : base(deserializing) { }
94
95    public CVRPPDTWProblemInstance() {
96      Parameters.Add(new ValueParameter<IntArray>("PickupDeliveryLocation", "The pickup and delivery location for each customer.", new IntArray()));
97
98      Parameters.Add(new ValueParameter<DoubleValue>("EvalPickupViolationPenalty", "The pickup violation penalty considered in the evaluation.", new DoubleValue(100)));
99      Parameters.Add(new OptionalValueParameter<DoubleValue>("CurrentPickupViolationPenalty", "The current pickup violation penalty considered in the evaluation.") { Hidden = true });
100
101      AttachEventHandlers();
102    }
103
104    public override IDeepCloneable Clone(Cloner cloner) {
105      return new CVRPPDTWProblemInstance(this, cloner);
106    }
107
108    protected CVRPPDTWProblemInstance(CVRPPDTWProblemInstance original, Cloner cloner)
109      : base(original, cloner) {
110      AttachEventHandlers();
111    }
112
113    [StorableHook(HookType.AfterDeserialization)]
114    private void AfterDeserialization() {
115      AttachEventHandlers();
116    }
117
118    private void AttachEventHandlers() {
119      PickupDeliveryLocationParameter.ValueChanged += new EventHandler(PickupDeliveryLocationParameter_ValueChanged);
120    }
121
122    public override void InitializeState() {
123      base.InitializeState();
124
125      CurrentPickupViolationPenaltyParameter.Value = null;
126    }
127
128    #region Event handlers
129    void PickupDeliveryLocationParameter_ValueChanged(object sender, EventArgs e) {
130      PickupDeliveryLocationParameter.Value.ItemChanged += new EventHandler<EventArgs<int>>(Value_ItemChanged);
131      EvalBestKnownSolution();
132    }
133
134    void Value_ItemChanged(object sender, EventArgs<int> e) {
135      EvalBestKnownSolution();
136    }
137    #endregion
138  }
139}
Note: See TracBrowser for help on using the repository browser.