Gaia
crosssegmentdistance.h
1 /*
2  * Copyright (C) 2006-2013 Music Technology Group - Universitat Pompeu Fabra
3  *
4  * This file is part of Gaia
5  *
6  * Gaia is free software: you can redistribute it and/or modify it under
7  * the terms of the GNU Affero General Public License as published by the Free
8  * Software Foundation (FSF), either version 3 of the License, or (at your
9  * option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful, but WITHOUT
12  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
13  * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
14  * details.
15  *
16  * You should have received a copy of the Affero GNU General Public License
17  * version 3 along with this program. If not, see http://www.gnu.org/licenses/
18  */
19 
20 #ifndef GAIA_CROSSSEGMENTDISTANCE_H
21 #define GAIA_CROSSSEGMENTDISTANCE_H
22 
23 #include "distancefunction.h"
24 
25 namespace gaia2 {
26 
27 class DistAggr {
28 public:
29  virtual Real initValue() const { return 0; }
30  virtual Real operator()(Real x, Real y) const = 0;
31  virtual Real postProcess(Real x, int nsegs) const { return x; }
32  virtual ~DistAggr() {}
33 };
34 
55  public:
56  CrossSegmentDistance(const PointLayout& layout, const ParameterMap& params);
58  Real operator()(const Point& p1, const Point& p2, int seg1, int seg2) const;
59 
60  protected:
61  DistanceFunction* _dist;
62  DistAggr *_aggr1, *_aggr2;
63 };
64 
65 } // namespace gaia2
66 
67 #endif // GAIA_CROSSSEGMENTDISTANCE_H
This class describes the layout of a point.
Definition: pointlayout.h:60
Main Gaia namespace, which contains all the library functions.
Definition: addfield.cpp:22
This class calculates a distance between segments from two points.
Definition: crosssegmentdistance.h:54
Definition: distancefunction.h:37
Definition: parameter.h:34
Definition: crosssegmentdistance.h:27
Definition: point.h:106