annotate src/Finder.h @ 147:3673e2dae6a7 structure

Factor out getBestEdgeCost
author Chris Cannam
date Thu, 22 Jan 2015 12:04:44 +0000
parents c665173b3a33
children 4159f6b71942
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@147 40
Chris@147 41 /**
Chris@147 42 * Find the location and cost of the cheapest path cost within the
Chris@147 43 * final row and column of the search area, given that the area
Chris@147 44 * extends as far as the point at (row, col). This is used by
Chris@147 45 * getExpandDirection and can also be used, for example, to
Chris@147 46 * determine the current best estimate alignment for a frame we
Chris@147 47 * have just reached.
Chris@147 48 */
Chris@147 49 void getBestEdgeCost(int row, int col,
Chris@147 50 int &bestRow, int &bestCol,
Chris@147 51 double &bestCost);
Chris@147 52
Chris@147 53 /**
Chris@147 54 * Calculate which direction to expand the search area in, given
Chris@147 55 * that so far it extends as far as the point at (row, col).
Chris@147 56 */
Chris@45 57 Matcher::Advance getExpandDirection(int row, int col);
Chris@45 58
cannam@0 59 /** Calculates a rectangle of the path cost matrix so that the
cannam@0 60 * minimum cost path between the bottom left and top right
cannam@0 61 * corners can be computed. Caches previous values to avoid
cannam@0 62 * calling find() multiple times, and is several times faster as
cannam@0 63 * a result.
cannam@0 64 *
cannam@0 65 * @param r1 the bottom of the rectangle to be calculated
cannam@0 66 * @param c1 the left side of the rectangle to be calculated
cannam@0 67 * @param r2 the top of the rectangle to be calculated
cannam@0 68 * @param c2 the right side of the rectangle to be calculated
cannam@0 69 */
cannam@0 70 void recalculatePathCostMatrix(int r1, int c1, int r2, int c2);
cannam@0 71
Chris@30 72 /**
Chris@30 73 * Track back after all of the matchers have been fed in order to
Chris@30 74 * obtain the lowest cost path available. Path x and y coordinate
Chris@30 75 * pairs are returned in corresponding elements of pathx and
Chris@30 76 * pathy. Return value is the length of the returned path: only
Chris@30 77 * this many elements from pathx and pathy are valid (any
Chris@30 78 * subsequent ones may be spurious).
Chris@31 79 *
Chris@31 80 * @param smooth whether to smooth the path before returning it
Chris@30 81 */
Chris@31 82 int retrievePath(bool smooth, std::vector<int> &pathx, std::vector<int> &pathy);
Chris@72 83
Chris@72 84 protected:
Chris@82 85 #ifdef PERFORM_ERROR_CHECKS
Chris@81 86 struct ErrorPosition {
Chris@86 87 enum Type { NoError = 0, WrongCost, WrongAdvance, NoAdvance };
Chris@81 88 ErrorPosition() : type(NoError) { }
Chris@81 89 Type type;
Chris@81 90 int r;
Chris@81 91 int c;
Chris@81 92 double prevCost;
Chris@81 93 float distance;
Chris@81 94 double costWas;
Chris@81 95 double costShouldBe;
Chris@84 96 Matcher::Advance advanceWas;
Chris@84 97 Matcher::Advance advanceShouldBe;
Chris@81 98 };
Chris@81 99 ErrorPosition checkPathCostMatrix();
Chris@92 100 void checkAndReport();
Chris@82 101 #endif
Chris@82 102
Chris@147 103 Matcher *m_m; // I do not own this
Chris@147 104
Chris@72 105 int m_duration1;
Chris@72 106 int m_duration2;
Chris@147 107 };
cannam@0 108
cannam@0 109 #endif