Bridge++  Ver. 2.0.2
sorter.h
Go to the documentation of this file.
1 
14 #ifndef SORTER_INCLUDED
15 #define SORTER_INCLUDED
16 
17 #include <cmath>
18 #include <algorithm>
19 #include <cassert>
20 #include <vector>
21 #include <string>
22 
24 // sort utility class.
25 //
26 // usage:
27 // Sorter sorter(sort_type);
28 // sort_type =
29 // abs_ascending : absolute ascending order |v_0| <= |v_1| <= ...
30 // abs_descending : absolute descending order |v_0| >= |v_1| >= ...
31 // ascending : arithmetic ascending order v_0 <= v_1 <= ...
32 // descending : arithmetic descending order v_0 >= v_1 >= ...
33 // sorter.sort(vec); to sort vec : vector<double>. destructive.
34 // sorter.sort_index(vec); returns index of vec in sorted order.
35 // sorter.comp(a, b); compare two values a, b with the sort condition.
36 //
37 
38 class Sorter
39 {
40  public:
41 
42  Sorter(const std::string& type);
43 
44  virtual ~Sorter();
45 
47  void sort(std::vector<double>& v);
48 
50  void sort(std::vector<double>& v, const size_t nelem);
51 
53  std::vector<int> sort_index(std::vector<double>& v);
54 
56  std::vector<int> sort_index(std::vector<double>& v, const size_t nelem);
57 
59  bool comp(const double lhs, const double rhs);
60 
61  private:
62 
63  // sort order
64  struct by_abs_ascend;
65  struct by_abs_descend;
66  struct by_ascend;
67  struct by_descend;
68 
69  struct by_order;
70  struct proxy;
71 
72  typedef std::pair<int, double> pair_t;
73 
74  by_order *m_order;
75 
76  // non-copyable
77  Sorter(const Sorter&);
78  Sorter& operator=(const Sorter&);
79 };
80 #endif /* SORTER_INCLUDED */
Sorter::by_abs_descend
absolute descending order
Definition: sorter.cpp:43
Sorter::by_order
base class for sort ordering
Definition: sorter.cpp:18
Sorter::by_ascend
ascending order
Definition: sorter.cpp:54
Sorter::Sorter
Sorter(const std::string &type)
constructor with sort ordering as a string arg
Definition: sorter.cpp:98
Sorter::pair_t
std::pair< int, double > pair_t
Definition: sorter.h:70
Sorter::by_descend
descending order
Definition: sorter.cpp:66
Sorter::by_abs_ascend
absolute ascending order
Definition: sorter.cpp:34
Sorter::sort_index
std::vector< int > sort_index(std::vector< double > &v)
sort an array and return list of index; v is sorted on exit.
Definition: sorter.cpp:137
Sorter::comp
bool comp(const double lhs, const double rhs)
call sort condition.
Definition: sorter.cpp:189
Sorter::m_order
by_order * m_order
Definition: sorter.h:74
Sorter::sort
void sort(std::vector< double > &v)
sort an array of values; v is sorted on exit.
Definition: sorter.cpp:117
Sorter::operator=
Sorter & operator=(const Sorter &)
Sorter
Definition: sorter.h:38
Sorter::~Sorter
virtual ~Sorter()
destructor
Definition: sorter.cpp:109
Element_type::type
type
Definition: bridge_defs.h:41