Pallas Solver  0.1
C++ Global Optimization Algorithms
crossover_strategy.h
1 // Pallas Solver
2 // Copyright 2015. All rights reserved.
3 //
4 // Redistribution and use in source and binary forms, with or without
5 // modification, are permitted provided that the following conditions are met:
6 //
7 // * Redistributions of source code must retain the above copyright notice,
8 // this list of conditions and the following disclaimer.
9 // * Redistributions in binary form must reproduce the above copyright notice,
10 // this list of conditions and the following disclaimer in the documentation
11 // and/or other materials provided with the distribution.
12 //
13 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
14 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16 // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
17 // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18 // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19 // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20 // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21 // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22 // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
23 // POSSIBILITY OF SUCH DAMAGE.
24 //
25 // Author: ryan.latture@gmail.com (Ryan Latture)
26 
27 #ifndef PALLAS_CROSSOVER_STRATEGY_H
28 #define PALLAS_CROSSOVER_STRATEGY_H
29 
30 #include "pallas/types.h"
31 #include "pallas/scoped_ptr.h"
33 
34 namespace pallas {
35  namespace internal {
36 
38  public:
39  static CrossoverStrategy* Create(CrossoverStrategyType type,
40  double crossover_probability,
41  unsigned int num_parameters);
42 
43  virtual ~CrossoverStrategy() { };
44 
45  virtual void Crossover(Vector &trial, const Vector &bprime) = 0;
46 
47  void set_crossover_probability(double crossover_probability);
48 
49  protected:
52  double crossover_probability_;
53  };
54 
56  public:
57  BinomialCrossover(double crossover_probability, unsigned int num_parameters);
58 
59  void Crossover(Vector &trial, const Vector &bprime);
60  };
61 
63  public:
64  ExponentialCrossover(double crossover_probability, unsigned int num_parameters);
65 
66  void Crossover(Vector &trial, const Vector &bprime);
67  };
68 
69  } // namespace internal
70 } // namespace pallas
71 
72 #endif // PALLAS_CROSSOVER_STRATEGY_H
Definition: basinhopping.h:51
Definition: scoped_ptr.h:45
Definition: crossover_strategy.h:62
Definition: crossover_strategy.h:55
Definition: crossover_strategy.h:37