summaryrefslogtreecommitdiff
path: root/sndobj/SinAnal.h
diff options
context:
space:
mode:
authorJohn Glover <glover.john@gmail.com>2010-10-18 17:32:05 +0100
committerJohn Glover <glover.john@gmail.com>2010-10-18 17:32:05 +0100
commit30755b92afeae5a5a32860b4f4297180f6d3398d (patch)
treec9332a65adc6a27016678fccee6ce979d87fed07 /sndobj/SinAnal.h
parent58a7c36c5a219d8306f276db157097ac30782079 (diff)
downloadsimpl-30755b92afeae5a5a32860b4f4297180f6d3398d.tar.gz
simpl-30755b92afeae5a5a32860b4f4297180f6d3398d.tar.bz2
simpl-30755b92afeae5a5a32860b4f4297180f6d3398d.zip
Moved project over to Git
Diffstat (limited to 'sndobj/SinAnal.h')
-rw-r--r--sndobj/SinAnal.h98
1 files changed, 98 insertions, 0 deletions
diff --git a/sndobj/SinAnal.h b/sndobj/SinAnal.h
new file mode 100644
index 0000000..e8f9f43
--- /dev/null
+++ b/sndobj/SinAnal.h
@@ -0,0 +1,98 @@
+
+////////////////////////////////////////////////////////////////////////
+// This file is part of the SndObj library
+//
+// This program is free software; you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation; either version 2 of the License, or
+// (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// Copyright (c)Victor Lazzarini, 1997-2004
+// See License.txt for a disclaimer of all warranties
+// and licensing information
+
+#ifndef _SINANAL_H
+#define _SINANAL_H
+
+#include "SndObj.h"
+#include "PVA.h"
+
+class SinAnal : public SndObj {
+
+ protected:
+
+ float** m_bndx; // bin indexes
+ float** m_pkmags; // peak mags
+ float** m_adthresh; // thresholds
+ unsigned int** m_tstart; // start times
+ unsigned int** m_lastpk; // end times
+ unsigned int** m_trkid; // track ids
+
+ float* m_phases; // phases
+ float* m_freqs; // frequencies
+ float* m_mags; // magnitudes
+ float* m_bins; // track bin indexes
+ int* m_trndx; // track IDs
+
+ float* m_binmax; // peak bin indexes
+ float* m_magmax; // peak mags
+ float* m_diffs; // differences
+
+ int* m_maxix; // max peak locations
+ bool* m_contflag; // continuation flags
+
+ int m_numbins; // number of bins
+ int m_maxtracks; // max number of tracks
+ float m_startupThresh; // startup threshold
+ float m_thresh; // threshold
+
+ int m_tracks; // tracks in a frame
+ int m_prev;
+ int m_cur;
+ int m_accum; // ID counter
+ unsigned int m_timecount;
+ int m_minpoints; // minimun number of points in track
+ int m_maxgap; // max gap (in points) between consecutive points
+ int m_numpeaks; // number of peaks found in peak detection
+
+ private:
+
+ void sinanalysis();
+ int peakdetection();
+
+ public:
+
+ SinAnal();
+ SinAnal(SndObj* input, float threshold, int maxtracks, int minpoints=1,
+ int maxgap=3, float sr=DEF_SR);
+ SinAnal(SndObj* input, int numbins, float threshold, int maxtracks, int minpoints=1,
+ int maxgap=3, float sr=DEF_SR);
+ ~SinAnal();
+
+ virtual int GetTrackID(int track){ return m_trndx[track]; }
+ virtual int GetTracks(){ return m_tracks;}
+
+ int Set(char* mess, float value);
+ int Connect(char* mess, void* input);
+
+ void SetThreshold(float threshold){ m_thresh = threshold; }
+ void SetIFGram(SndObj* input);
+ void SetMaxTracks(int maxtracks);
+
+ int FindPeaks();
+ void SetPeaks(int numamps, float* amps, int numfreqs, float* freqs,
+ int numphases, float* phases);
+ void PartialTracking();
+ short DoProcess();
+};
+
+#endif