CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Classes | Public Types | Public Member Functions | Private Attributes
lhef::Matching< Delta > Class Template Reference

#include <Matching.h>

Classes

struct  AlwaysTrue
 
struct  Comparator
 
struct  Match
 

Public Types

typedef SimpleMatrix< Delta >
::size_type 
index_type
 

Public Member Functions

Delta delta (index_type index1, index_type index2) const
 
Delta delta (Match match) const
 
bool isMatched1st (index_type index)
 
bool isMatched2nd (index_type index)
 
template<class SortComparator , class CutCriterion >
std::vector< Matchmatch (SortComparator sortComparator=SortComparator(), CutCriterion cutCriterion=CutCriterion())
 
template<class SortComparator >
std::vector< Matchmatch ()
 
std::vector< Matchmatch ()
 
template<typename V1 , typename V2 , class Separation >
 Matching (const V1 &v1, const V2 &v2, Separation separation)
 

Private Attributes

std::vector< bool > matched1
 
std::vector< bool > matched2
 
SimpleMatrix< Delta > matrix
 

Detailed Description

template<typename Delta>
class lhef::Matching< Delta >

Definition at line 14 of file Matching.h.

Member Typedef Documentation

template<typename Delta>
typedef SimpleMatrix<Delta>::size_type lhef::Matching< Delta >::index_type

Definition at line 16 of file Matching.h.

Constructor & Destructor Documentation

template<typename Delta>
template<typename V1 , typename V2 , class Separation >
lhef::Matching< Delta >::Matching ( const V1 &  v1,
const V2 &  v2,
Separation  separation 
)
inline

Definition at line 19 of file Matching.h.

References i, j, and lhef::Matching< Delta >::matrix.

19  :
20  matrix(v1.size(), v2.size()),
21  matched1(v1.size(), false),
22  matched2(v2.size(), false)
23  {
24  index_type i = 0;
25  for(typename V1::const_iterator iter1 = v1.begin();
26  iter1 != v1.end(); ++iter1, i++) {
27  index_type j = 0;
28  for(typename V2::const_iterator iter2 = v2.begin();
29  iter2 != v2.end(); ++iter2, j++)
30  matrix(i, j) = separation(*iter1, *iter2);
31 
32  }
33  }
int i
Definition: DBlmapReader.cc:9
std::vector< bool > matched1
Definition: Matching.h:116
std::vector< bool > matched2
Definition: Matching.h:116
int j
Definition: DBlmapReader.cc:9
SimpleMatrix< Delta >::size_type index_type
Definition: Matching.h:16
SimpleMatrix< Delta > matrix
Definition: Matching.h:115

Member Function Documentation

template<typename Delta>
Delta lhef::Matching< Delta >::delta ( index_type  index1,
index_type  index2 
) const
inline

Definition at line 44 of file Matching.h.

References lhef::Matching< Delta >::matrix.

45  { return matrix(index1, index2); }
SimpleMatrix< Delta > matrix
Definition: Matching.h:115
template<typename Delta>
Delta lhef::Matching< Delta >::delta ( Match  match) const
inline

Definition at line 47 of file Matching.h.

References lhef::Matching< Delta >::Match::index1, lhef::Matching< Delta >::Match::index2, and lhef::Matching< Delta >::matrix.

48  { return matrix(match.index1, match.index2); }
std::vector< Match > match()
Definition: Matching.h:105
SimpleMatrix< Delta > matrix
Definition: Matching.h:115
template<typename Delta>
bool lhef::Matching< Delta >::isMatched1st ( index_type  index)
inline

Definition at line 111 of file Matching.h.

References cmsHarvester::index, and lhef::Matching< Delta >::matched1.

111 { return matched1[index]; }
std::vector< bool > matched1
Definition: Matching.h:116
template<typename Delta>
bool lhef::Matching< Delta >::isMatched2nd ( index_type  index)
inline

Definition at line 112 of file Matching.h.

References cmsHarvester::index, and lhef::Matching< Delta >::matched2.

112 { return matched2[index]; }
std::vector< bool > matched2
Definition: Matching.h:116
template<typename Delta>
template<class SortComparator , class CutCriterion >
std::vector<Match> lhef::Matching< Delta >::match ( SortComparator  sortComparator = SortComparator(),
CutCriterion  cutCriterion = CutCriterion() 
)
inline

Definition at line 72 of file Matching.h.

References cuy::col, i, MultipleCompare::Match(), lhef::Matching< Delta >::matched1, lhef::Matching< Delta >::matched2, matches, lhef::Matching< Delta >::matrix, min(), query::result, lhef::SimpleMatrix< T >::size(), and python.multivaluedict::sort().

75  {
76  std::vector<index_type> matches(matrix.size());
77  for(index_type i = 0; i != matrix.size(); i++)
78  matches[i] = i;
79 
80  std::sort(matches.begin(), matches.end(),
81  Comparator<SortComparator>(matrix, sortComparator));
82 
83  std::vector<Match> result;
84  result.reserve(std::min(matrix.rows(), matrix.cols()));
85  for(typename std::vector<index_type>::const_iterator iter =
86  matches.begin(); iter != matches.end(); ++iter) {
87 
88  index_type row = matrix.row(*iter);
89  index_type col = matrix.col(*iter);
90  if (matched1[row] || matched2[col])
91  continue;
92 
93  if (!cutCriterion(matrix[*iter]))
94  continue;
95 
96  matched1[row] = true;
97  matched2[col] = true;
98  result.push_back(Match(row, col));
99  }
100 
101  return result;
102  }
int i
Definition: DBlmapReader.cc:9
size_type size() const
Definition: SimpleMatrix.h:21
std::vector< bool > matched1
Definition: Matching.h:116
size_type col(size_type index) const
Definition: SimpleMatrix.h:34
std::vector< bool > matched2
Definition: Matching.h:116
size_type row(size_type index) const
Definition: SimpleMatrix.h:33
tuple result
Definition: query.py:137
T min(T a, T b)
Definition: MathUtil.h:58
SimpleMatrix< Delta >::size_type index_type
Definition: Matching.h:16
size_type cols() const
Definition: SimpleMatrix.h:20
size_type rows() const
Definition: SimpleMatrix.h:19
SimpleMatrix< Delta > matrix
Definition: Matching.h:115
int col
Definition: cuy.py:1008
template<typename Delta>
template<class SortComparator >
std::vector<Match> lhef::Matching< Delta >::match ( )
inline

Definition at line 105 of file Matching.h.

106  { return match<SortComparator, AlwaysTrue>(); }
template<typename Delta>
std::vector<Match> lhef::Matching< Delta >::match ( )
inline

Definition at line 108 of file Matching.h.

109  { return match<std::less<Delta>, AlwaysTrue>(); }

Member Data Documentation

template<typename Delta>
std::vector<bool> lhef::Matching< Delta >::matched1
private
template<typename Delta>
std::vector<bool> lhef::Matching< Delta >::matched2
private
template<typename Delta>
SimpleMatrix<Delta> lhef::Matching< Delta >::matrix
private