annotate src/Finder.h @ 81:c603d77b00ac refactors

Toward cost checks
author Chris Cannam
date Thu, 27 Nov 2014 08:13:29 +0000
parents c3c50d5e05b7
children 3616d541d69e
rev   line source
cannam@0 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
cannam@0 2
cannam@0 3 /*
cannam@0 4 Vamp feature extraction plugin using the MATCH audio alignment
cannam@0 5 algorithm.
cannam@0 6
cannam@0 7 Centre for Digital Music, Queen Mary, University of London.
cannam@0 8 This file copyright 2007 Simon Dixon, Chris Cannam and QMUL.
cannam@0 9
cannam@0 10 This program is free software; you can redistribute it and/or
cannam@0 11 modify it under the terms of the GNU General Public License as
cannam@0 12 published by the Free Software Foundation; either version 2 of the
cannam@0 13 License, or (at your option) any later version. See the file
cannam@0 14 COPYING included with this distribution for more information.
cannam@0 15 */
cannam@0 16
cannam@0 17 #ifndef _FINDER_H_
cannam@0 18 #define _FINDER_H_
cannam@0 19
cannam@0 20 #include <vector>
cannam@0 21 #include <iostream>
cannam@0 22
cannam@0 23 #include "Matcher.h"
cannam@0 24
Chris@72 25 class Finder
Chris@72 26 {
cannam@0 27 public:
Chris@72 28 Finder(Matcher *pm);
cannam@0 29
cannam@0 30 ~Finder();
cannam@0 31
Chris@60 32 /**
Chris@60 33 * Tell the finder that one or both files ends sooner than it
Chris@60 34 * thought, i.e. that some of the trailing features are silence or
Chris@60 35 * otherwise to be ignored. d1 and d2 are feature frame counts for
Chris@60 36 * matchers 1 and 2 respectively. If this is not called, the full
Chris@60 37 * duration of each input will be considered.
Chris@60 38 */
Chris@60 39 void setDurations(int d1, int d2);
Chris@60 40
Chris@45 41 Matcher::Advance getExpandDirection(int row, int col);
Chris@45 42 Matcher::Advance getExpandDirection(int row, int col, bool check);
Chris@45 43
cannam@0 44 /** Calculates a rectangle of the path cost matrix so that the
cannam@0 45 * minimum cost path between the bottom left and top right
cannam@0 46 * corners can be computed. Caches previous values to avoid
cannam@0 47 * calling find() multiple times, and is several times faster as
cannam@0 48 * a result.
cannam@0 49 *
cannam@0 50 * @param r1 the bottom of the rectangle to be calculated
cannam@0 51 * @param c1 the left side of the rectangle to be calculated
cannam@0 52 * @param r2 the top of the rectangle to be calculated
cannam@0 53 * @param c2 the right side of the rectangle to be calculated
cannam@0 54 */
cannam@0 55 void recalculatePathCostMatrix(int r1, int c1, int r2, int c2);
cannam@0 56
Chris@30 57 /**
Chris@30 58 * Track back after all of the matchers have been fed in order to
Chris@30 59 * obtain the lowest cost path available. Path x and y coordinate
Chris@30 60 * pairs are returned in corresponding elements of pathx and
Chris@30 61 * pathy. Return value is the length of the returned path: only
Chris@30 62 * this many elements from pathx and pathy are valid (any
Chris@30 63 * subsequent ones may be spurious).
Chris@31 64 *
Chris@31 65 * @param smooth whether to smooth the path before returning it
Chris@30 66 */
Chris@31 67 int retrievePath(bool smooth, std::vector<int> &pathx, std::vector<int> &pathy);
Chris@72 68
Chris@72 69 protected:
Chris@81 70 struct ErrorPosition {
Chris@81 71 enum Type { NoError = 0, CostError };
Chris@81 72 ErrorPosition() : type(NoError) { }
Chris@81 73 Type type;
Chris@81 74 int r;
Chris@81 75 int c;
Chris@81 76 double prevCost;
Chris@81 77 float distance;
Chris@81 78 Matcher::Advance advance;
Chris@81 79 double costWas;
Chris@81 80 double costShouldBe;
Chris@81 81 };
Chris@81 82 ErrorPosition checkPathCostMatrix();
Chris@81 83
Chris@72 84 Matcher *m_m;
Chris@72 85 int m_duration1;
Chris@72 86 int m_duration2;
cannam@0 87 }; // class Finder
cannam@0 88
cannam@0 89 #endif