annotate src/FeatureConditioner.cpp @ 139:b62dbe2ba958 refactors

Fix uninitialised variable
author Chris Cannam
date Fri, 19 Dec 2014 15:07:57 +0000
parents 8e240bbea845
children cfba9aec7569
rev   line source
Chris@103 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@103 2
Chris@103 3 /*
Chris@103 4 Vamp feature extraction plugin using the MATCH audio alignment
Chris@103 5 algorithm.
Chris@103 6
Chris@103 7 Centre for Digital Music, Queen Mary, University of London.
Chris@103 8
Chris@103 9 This program is free software; you can redistribute it and/or
Chris@103 10 modify it under the terms of the GNU General Public License as
Chris@103 11 published by the Free Software Foundation; either version 2 of the
Chris@103 12 License, or (at your option) any later version. See the file
Chris@103 13 COPYING included with this distribution for more information.
Chris@103 14 */
Chris@103 15
Chris@103 16 #include "FeatureConditioner.h"
Chris@103 17
Chris@103 18 #include <iostream>
Chris@130 19 #include <cmath>
Chris@103 20
Chris@103 21 using namespace std;
Chris@103 22
Chris@103 23 vector<double>
Chris@103 24 FeatureConditioner::process(const vector<double> &feature)
Chris@103 25 {
Chris@103 26 if (m_prev.empty()) {
Chris@103 27 m_prev.resize(feature.size(), 0.0);
Chris@103 28 }
Chris@103 29 if (m_prev.size() != feature.size()) {
Chris@103 30 cerr << "ERROR: FeatureConditioner::process: feature size "
Chris@103 31 << feature.size() << " differs from previous feature size "
Chris@103 32 << m_prev.size() << endl;
Chris@103 33 return feature;
Chris@103 34 }
Chris@103 35
Chris@103 36 int size = feature.size();
Chris@103 37
Chris@103 38 vector<double> out(size, 0.0);
Chris@103 39
Chris@103 40 double totalEnergy = 0;
Chris@116 41
Chris@116 42 switch (m_params.order) {
Chris@116 43
Chris@116 44 case OutputRectifiedDerivative:
Chris@103 45 for (int i = 0; i < size; i++) {
Chris@103 46 totalEnergy += feature[i];
Chris@103 47 if (feature[i] > m_prev[i]) {
Chris@103 48 out[i] = feature[i] - m_prev[i];
Chris@103 49 } else {
Chris@103 50 out[i] = 0;
Chris@103 51 }
Chris@103 52 }
Chris@116 53 break;
Chris@116 54
Chris@116 55 case OutputDerivative:
Chris@103 56 for (int i = 0; i < size; i++) {
Chris@116 57 totalEnergy += feature[i];
Chris@130 58 out[i] = fabs(feature[i] - m_prev[i]);
Chris@116 59 }
Chris@116 60 break;
Chris@116 61
Chris@116 62 case OutputFeatures:
Chris@116 63 for (int i = 0; i < size; i++) {
Chris@116 64 totalEnergy += feature[i];
Chris@103 65 out[i] = feature[i];
Chris@103 66 }
Chris@116 67 break;
Chris@103 68 }
Chris@103 69
Chris@139 70 if (m_ltAverage == 0.0) {
Chris@103 71 m_ltAverage = totalEnergy;
Chris@103 72 } else {
Chris@103 73 double decay = m_params.decay;
Chris@103 74 m_ltAverage = m_ltAverage * decay + totalEnergy * (1.0 - decay);
Chris@103 75 }
Chris@103 76
Chris@103 77 if (totalEnergy <= m_params.silenceThreshold) {
Chris@103 78 for (int i = 0; i < size; i++) {
Chris@103 79 out[i] = 0;
Chris@103 80 }
Chris@103 81 } else if (m_params.norm == NormaliseToSum1) {
Chris@103 82 for (int i = 0; i < size; i++) {
Chris@103 83 out[i] /= totalEnergy;
Chris@103 84 }
Chris@103 85 } else if (m_params.norm == NormaliseToLTAverage) {
Chris@103 86 for (int i = 0; i < size; i++) {
Chris@103 87 out[i] /= m_ltAverage;
Chris@103 88 }
Chris@103 89 }
Chris@103 90
Chris@103 91 m_prev = feature;
Chris@103 92 return out;
Chris@103 93 }
Chris@103 94