Pallas Solver  0.1
C++ Global Optimization Algorithms
shuffler.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_INTERNAL_SHUFFLER_H
28 #define PALLAS_INTERNAL_SHUFFLER_H
29 
31 #include "pallas/scoped_ptr.h"
32 
33 
34 namespace pallas {
35  namespace internal {
36  class Shuffler {
37  public:
38  Shuffler(unsigned int population_size)
39  : population_size_(population_size) {
41  new RandomNumberGenerator<unsigned int>(0, population_size_ - 1));
42  swap(random_idx_, tmp_random_idx);
43  };
44 
45  template<typename T>
46  void Shuffle(T* data, unsigned int num_times = 1) {
47  for (unsigned int i = 0; i < num_times; ++i) {
48  for (unsigned int j = population_size_ - 1; j > 0; --j) {
49  std::swap(data[j], data[(*random_idx_)()]);
50  }
51  }
52  };
53 
54  private:
55  const unsigned int population_size_;
57 
58  };
59 
60  } // namespace internal
61 } // namespace pallas
62 
63 #endif //PALLAS_RANDOM_NUMBER_GENERATOR_H
Definition: shuffler.h:36
Definition: basinhopping.h:51
Definition: scoped_ptr.h:45