Free cookie consent management tool by TermsFeed Policy Generator

Ignore:
Timestamp:
11/19/10 13:54:50 (14 years ago)
Author:
svonolfe
Message:

Implemented review comments (#1236)

Location:
trunk/sources/HeuristicLab.Problems.VehicleRouting/3.3
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/sources/HeuristicLab.Problems.VehicleRouting/3.3/Analyzers/BestVRPSolutionAnalyzer.cs

    r4722 r4851  
    8181      get { return (ValueLookupParameter<ResultCollection>)Parameters["Results"]; }
    8282    }
     83    public LookupParameter<DoubleValue> BestKnownQualityParameter {
     84      get { return (LookupParameter<DoubleValue>)Parameters["BestKnownQuality"]; }
     85    }
     86    public LookupParameter<VRPSolution> BestKnownSolutionParameter {
     87      get { return (LookupParameter<VRPSolution>)Parameters["BestKnownSolution"]; }
     88    }
    8389
    8490    [StorableConstructor]
     
    97103      Parameters.Add(new LookupParameter<DoubleArray>("ServiceTime", "The service time of each customer."));
    98104
     105      Parameters.Add(new LookupParameter<DoubleValue>("BestKnownQuality", "The quality of the best known solution of this VRP instance."));
     106      Parameters.Add(new LookupParameter<VRPSolution>("BestKnownSolution", "The best known solution of this VRP instance."));
     107
    99108      Parameters.Add(new ScopeTreeLookupParameter<DoubleValue>("Quality", "The qualities of the VRP solutions which should be analyzed."));
    100109      Parameters.Add(new ScopeTreeLookupParameter<DoubleValue>("Distance", "The distances of the VRP solutions which should be analyzed."));
     
    111120    }
    112121
     122    [StorableHook(HookType.AfterDeserialization)]
     123    private void AfterDeserializationHook() {
     124      #region Backwards Compatibility
     125      if (!Parameters.ContainsKey("BestKnownQuality")) {
     126        Parameters.Add(new LookupParameter<DoubleValue>("BestKnownQuality", "The quality of the best known solution of this VRP instance."));
     127      }
     128      if (!Parameters.ContainsKey("BestKnownSolution")) {
     129        Parameters.Add(new LookupParameter<VRPSolution>("BestKnownSolution", "The best known solution of this VRP instance."));
     130      }
     131      #endregion
     132    }
     133
    113134    public override IOperation Apply() {
    114135      DoubleMatrix coordinates = CoordinatesParameter.ActualValue;
     
    121142      ItemArray<DoubleValue> travelTimes = TravelTimeParameter.ActualValue;
    122143      ItemArray<DoubleValue> vehiclesUtilizations = VehiclesUtilizedParameter.ActualValue;
     144
     145      DoubleValue bestKnownQuality = BestKnownQualityParameter.ActualValue;
    123146
    124147      int i = qualities.Select((x, index) => new { index, x.Value }).OrderBy(x => x.Value).First().index;
     
    159182      }
    160183
     184      if (bestKnownQuality == null ||
     185          qualities[i].Value < bestKnownQuality.Value) {
     186        BestKnownQualityParameter.ActualValue = new DoubleValue(qualities[i].Value);
     187        BestKnownSolutionParameter.ActualValue = (VRPSolution)solution.Clone();
     188      }
     189
    161190      return base.Apply();
    162191    }
  • trunk/sources/HeuristicLab.Problems.VehicleRouting/3.3/VehicleRoutingProblem.cs

    r4847 r4851  
    114114      get { return BestKnownQualityParameter; }
    115115    }
    116     public OptionalValueParameter<IVRPEncoding> BestKnownSolutionParameter {
    117       get { return (OptionalValueParameter<IVRPEncoding>)Parameters["BestKnownSolution"]; }
     116    public OptionalValueParameter<VRPSolution> BestKnownSolutionParameter {
     117      get { return (OptionalValueParameter<VRPSolution>)Parameters["BestKnownSolution"]; }
    118118    }
    119119    #endregion
     
    160160      set { BestKnownQualityParameter.Value = value; }
    161161    }
    162     public IVRPEncoding BestKnownSolution {
     162    public VRPSolution BestKnownSolution {
    163163      get { return BestKnownSolutionParameter.Value; }
    164164      set { BestKnownSolutionParameter.Value = value; }
     
    219219      Parameters.Add(new ValueParameter<DoubleArray>("ServiceTime", "The service time of each customer.", new DoubleArray()));
    220220      Parameters.Add(new OptionalValueParameter<DoubleValue>("BestKnownQuality", "The quality of the best known solution of this VRP instance."));
    221       Parameters.Add(new OptionalValueParameter<IVRPEncoding>("BestKnownSolution", "The best known solution of this TSP instance."));
     221      Parameters.Add(new OptionalValueParameter<VRPSolution>("BestKnownSolution", "The best known solution of this VRP instance."));
    222222      Parameters.Add(new ValueParameter<DoubleValue>("EvalFleetUsageFactor", "The fleet usage factor considered in the evaluation.", new DoubleValue(100)));
    223223      Parameters.Add(new ValueParameter<DoubleValue>("EvalTimeFactor", "The time factor considered in the evaluation.", new DoubleValue(0)));
     
    440440      #region Backwards Compatibility
    441441      if (!Parameters.ContainsKey("BestKnownSolution")) {
    442         Parameters.Add(new OptionalValueParameter<IVRPEncoding>("BestKnownSolution", "The best known solution of this TSP instance."));
     442        Parameters.Add(new OptionalValueParameter<VRPSolution>("BestKnownSolution", "The best known solution of this TSP instance."));
    443443      }
    444444      #endregion
     
    673673      if (BestKnownSolution != null) {
    674674        //call evaluator
    675         IValueParameter<DoubleMatrix> distMatrix = new ValueParameter<DoubleMatrix>("DistMatrix",
     675        IValueLookupParameter<DoubleMatrix> distMatrix = new ValueLookupParameter<DoubleMatrix>("DistMatrix",
    676676          DistanceMatrix);
    677677
    678678        TourEvaluation eval = VRPEvaluator.Evaluate(
    679           BestKnownSolution,
     679          BestKnownSolution.Solution,
    680680          Vehicles,
    681681          DueTime,
     
    695695        DistanceMatrix = distMatrix.Value;
    696696
     697        BestKnownSolution.DistanceMatrix = DistanceMatrix;
     698        BestKnownSolution.Distance = new DoubleValue(eval.Distance);
     699        BestKnownSolution.Overload = new DoubleValue(eval.Overload);
     700        BestKnownSolution.Quality = new DoubleValue(eval.Quality);
     701        BestKnownSolution.Tardiness = new DoubleValue(eval.Tardiness);
     702        BestKnownSolution.TravelTime = new DoubleValue(eval.TravelTime);
     703        BestKnownSolution.VehicleUtilization = new DoubleValue(eval.VehcilesUtilized);
     704
    697705        BestKnownQuality = new DoubleValue(eval.Quality);
    698706      } else {
     
    717725
    718726      if (cities != Coordinates.Rows - 1)
    719         ErrorHandling.ShowErrorDialog(new Exception("Invalid solution"));
    720       else
    721         BestKnownSolutionParameter.Value = encoding;
     727        ErrorHandling.ShowErrorDialog(new Exception("The optimal solution does not seem to correspond  with the problem data."));
     728      else {
     729        VRPSolution solution = new VRPSolution();
     730        solution.Solution = encoding;
     731        solution.Coordinates = Coordinates;
     732        solution.DistanceMatrix = DistanceMatrix;
     733        solution.ReadyTime = ReadyTime;
     734        solution.DueTime = DueTime;
     735        solution.ServiceTime = ServiceTime;
     736        solution.UseDistanceMatrix = UseDistanceMatrix;
     737
     738        BestKnownSolutionParameter.Value = solution;
     739      }
    722740    }
    723741
Note: See TracChangeset for help on using the changeset viewer.