annotate maths/MathUtilities.h @ 84:e5907ae6de17

* Add GPL and README; some tidying
author Chris Cannam
date Mon, 13 Dec 2010 14:55:28 +0000
parents 054c384d860d
children a37635bbb2c1
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 QM DSP Library
cannam@0 5
cannam@0 6 Centre for Digital Music, Queen Mary, University of London.
Chris@84 7 This file 2005-2006 Christian Landone.
Chris@84 8
Chris@84 9 This program is free software; you can redistribute it and/or
Chris@84 10 modify it under the terms of the GNU General Public License as
Chris@84 11 published by the Free Software Foundation; either version 2 of the
Chris@84 12 License, or (at your option) any later version. See the file
Chris@84 13 COPYING included with this distribution for more information.
cannam@0 14 */
cannam@0 15
cannam@0 16 #ifndef MATHUTILITIES_H
cannam@0 17 #define MATHUTILITIES_H
cannam@0 18
cannam@0 19 #include <vector>
cannam@0 20
cannam@79 21 #include "nan-inf.h"
cannam@79 22
cannam@0 23 class MathUtilities
cannam@0 24 {
cannam@0 25 public:
cannam@0 26 static double round( double x );
cannam@34 27
cannam@0 28 static void getFrameMinMax( const double* data, unsigned int len, double* min, double* max );
cannam@34 29
cannam@0 30 static double mean( const double* src, unsigned int len );
cannam@54 31 static double mean( const std::vector<double> &data,
cannam@54 32 unsigned int start, unsigned int count );
cannam@0 33 static double sum( const double* src, unsigned int len );
cannam@34 34 static double median( const double* src, unsigned int len );
cannam@34 35
cannam@0 36 static double princarg( double ang );
cannam@0 37 static double mod( double x, double y);
cannam@34 38
cannam@0 39 static void getAlphaNorm(const double *data, unsigned int len, unsigned int alpha, double* ANorm);
cannam@0 40 static double getAlphaNorm(const std::vector <double> &data, unsigned int alpha );
cannam@34 41
cannam@7 42 static void circShift( double* data, int length, int shift);
cannam@34 43
cannam@54 44 static int getMax( double* data, unsigned int length, double* max = 0 );
cannam@54 45 static int getMax( const std::vector<double> &data, double* max = 0 );
cannam@7 46 static int compareInt(const void * a, const void * b);
cannam@34 47
cannam@34 48 enum NormaliseType {
cannam@34 49 NormaliseNone,
cannam@34 50 NormaliseUnitSum,
cannam@34 51 NormaliseUnitMax
cannam@34 52 };
cannam@34 53
cannam@34 54 static void normalise(double *data, int length,
cannam@34 55 NormaliseType n = NormaliseUnitMax);
cannam@34 56
cannam@34 57 static void normalise(std::vector<double> &data,
cannam@34 58 NormaliseType n = NormaliseUnitMax);
cannam@54 59
cannam@54 60 // moving mean threshholding:
cannam@54 61 static void adaptiveThreshold(std::vector<double> &data);
cannam@55 62
cannam@55 63 static bool isPowerOfTwo(int x);
cannam@55 64 static int nextPowerOfTwo(int x); // e.g. 1300 -> 2048, 2048 -> 2048
cannam@55 65 static int previousPowerOfTwo(int x); // e.g. 1300 -> 1024, 2048 -> 2048
cannam@55 66 static int nearestPowerOfTwo(int x); // e.g. 1300 -> 1024, 1700 -> 2048
cannam@0 67 };
cannam@0 68
cannam@0 69 #endif