#region License Information /* HeuristicLab * Copyright (C) 2002-2015 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.Collections.Generic; using System.Linq; using HeuristicLab.Common; using HeuristicLab.Core; using HeuristicLab.Persistence.Default.CompositeSerializers.Storable; namespace HeuristicLab.Algorithms.CMAEvolutionStrategy { [Item("CMAParameters", "CMA-ES controls many strategy parameters that guide the search and which are combined in this class.")] [StorableType("1DF8935F-2A40-4597-9FB6-761A763B83C0")] public sealed class CMAParameters : Item { [Storable(Name = "axisRatio")] public double AxisRatio { get; set; } [Storable(Name = "sigma")] public double Sigma { get; set; } [Storable(Name = "sigmaBounds")] public double[,] SigmaBounds { get; set; } [Storable(Name = "mu")] public int Mu { get; set; } [Storable(Name = "weights")] public double[] Weights { get; set; } [Storable(Name = "muEff")] public double MuEff { get; set; } [Storable(Name = "cc")] public double CC { get; set; } [Storable(Name = "cs")] public double CS { get; set; } [Storable(Name = "damps")] public double Damps { get; set; } [Storable(Name = "muCov")] public double MuCov { get; set; } [Storable(Name = "cCov")] public double CCov { get; set; } [Storable(Name = "cCovSep")] public double CCovSep { get; set; } [Storable(Name = "pc")] public double[] PC { get; set; } [Storable(Name = "ps")] public double[] PS { get; set; } [Storable(Name = "b")] public double[,] B { get; set; } [Storable(Name = "d")] public double[] D { get; set; } [Storable(Name = "c")] public double[,] C { get; set; } [Storable(Name = "bDz")] public double[] BDz { get; set; } [Storable(Name = "chiN")] public double ChiN { get; set; } [Storable(Name = "initialIterations")] public int InitialIterations { get; set; } [Storable(Name = "qualityHistory")] private IEnumerable StorableQualityHistory { get { return QualityHistory ?? Enumerable.Empty(); } set { if (value != null) QualityHistory = new Queue(value); } } public Queue QualityHistory { get; set; } [Storable(Name = "qualityHistorySize")] public int QualityHistorySize { get; set; } [StorableConstructor] private CMAParameters(bool deserializing) : base(deserializing) { } private CMAParameters(CMAParameters original, Cloner cloner) : base(original, cloner) { this.AxisRatio = original.AxisRatio; if (original.B != null) this.B = (double[,])original.B.Clone(); if (original.BDz != null) this.BDz = (double[])original.BDz.Clone(); if (original.C != null) this.C = (double[,])original.C.Clone(); this.CCov = original.CCov; this.CCovSep = original.CCovSep; this.CC = original.CC; this.ChiN = original.ChiN; this.CS = original.CS; if (original.D != null) this.D = (double[])original.D.Clone(); this.Damps = original.Damps; this.InitialIterations = original.InitialIterations; this.Mu = original.Mu; this.MuCov = original.MuCov; this.MuEff = original.MuEff; if (original.PC != null) this.PC = (double[])original.PC.Clone(); if (original.PS != null) this.PS = (double[])original.PS.Clone(); this.Sigma = original.Sigma; if (original.SigmaBounds != null) this.SigmaBounds = (double[,])original.SigmaBounds.Clone(); if (original.Weights != null) this.Weights = (double[])original.Weights.Clone(); if (original.QualityHistory != null) this.QualityHistory = new Queue(original.QualityHistory); this.QualityHistorySize = original.QualityHistorySize; } public CMAParameters() { } public override IDeepCloneable Clone(Cloner cloner) { return new CMAParameters(this, cloner); } } }