cannam@31: /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ cannam@31: cannam@31: /* cannam@31: QM DSP Library cannam@31: cannam@31: Centre for Digital Music, Queen Mary, University of London. cannam@31: This file copyright 2008 Kurt Jacobson. cannam@31: All rights reserved. cannam@31: */ cannam@31: cannam@31: #include "CosineDistance.h" cannam@31: cannam@31: #include cannam@31: #include cannam@31: cannam@31: using std::cerr; cannam@31: cannam@31: double CosineDistance::distance(const vector &v1, cannam@31: const vector &v2) cannam@31: { cannam@31: dist = 1.0; dDenTot = 0; dDen1 = 0; dDen2 = 0; dSum1 =0; cannam@31: cannam@31: //check if v1, v2 same size cannam@31: if (v1.size() != v2.size()) cannam@31: { cannam@31: cerr << "CosineDistance::distance: ERROR: vectors not the same size\n"; cannam@31: return 1.0; cannam@31: } cannam@31: else cannam@31: { cannam@31: for(int i=0; i