Gaia
resistoraveragedistance.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_RESISTORAVERAGEDISTANCE_H
21 #define GAIA_RESISTORAVERAGEDISTANCE_H
22 
23 #include "distancefunction.h"
24 
25 namespace gaia2 {
26 
45  public:
46  ResistorAverageDistance(const PointLayout& layout, const ParameterMap& params);
47  Real operator()(const Point& p1, const Point& p2, int seg1, int seg2) const;
48 
49  protected:
50  int _meanIdx, _covIdx, _icovIdx, _covdetIdx;
51  int _meanIdxEnd, _covIdxEnd, _icovIdxEnd;
52 };
53 
54 } // namespace gaia2
55 
56 #endif // GAIA_RESISTORAVERAGEDISTANCE_H
This class computes the symmetric resistor-average distance of a given Region.
Definition: resistoraveragedistance.h:44
Real operator()(const Point &p1, const Point &p2, int seg1, int seg2) const
This function computes the distance between the two given points.
Definition: resistoraveragedistance.cpp:82
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
Definition: distancefunction.h:37
Definition: parameter.h:34
Definition: point.h:106