summaryrefslogtreecommitdiff
path: root/src/sms/stocAnalysis.c
diff options
context:
space:
mode:
authorJohn Glover <glover.john@gmail.com>2011-06-24 18:17:23 +0100
committerJohn Glover <glover.john@gmail.com>2011-06-24 18:17:23 +0100
commit416bd737074a287ea47106c73ea6bcfde40a75a8 (patch)
tree74562303d4f4f2f2e010f7e13cba41dc4852b50c /src/sms/stocAnalysis.c
parentd26519464dcbf8c3682348167c29454961facefe (diff)
downloadsimpl-416bd737074a287ea47106c73ea6bcfde40a75a8.tar.gz
simpl-416bd737074a287ea47106c73ea6bcfde40a75a8.tar.bz2
simpl-416bd737074a287ea47106c73ea6bcfde40a75a8.zip
Change to using distutils.
Currently only builds the simplsndobj module
Diffstat (limited to 'src/sms/stocAnalysis.c')
-rw-r--r--src/sms/stocAnalysis.c55
1 files changed, 55 insertions, 0 deletions
diff --git a/src/sms/stocAnalysis.c b/src/sms/stocAnalysis.c
new file mode 100644
index 0000000..802e41c
--- /dev/null
+++ b/src/sms/stocAnalysis.c
@@ -0,0 +1,55 @@
+/*
+ * Copyright (c) 2008 MUSIC TECHNOLOGY GROUP (MTG)
+ * UNIVERSITAT POMPEU FABRA
+ *
+ *
+ * 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, M 02111-1307 USA
+ *
+ */
+/*! \file stocAnalysis.c
+ * \brief stochastic analysis using spectral analysis and approximation
+ */
+#include "sms.h"
+
+/*! \brief main function for the stochastic analysis
+ * \param sizeWindow size of buffer
+ * \param pResidual pointer to residual signal
+ * \param pWindow pointer to windowing array
+ * \param pSmsData pointer to output SMS data
+ * \param pAnalParams point to analysis parameters
+ * \return 0 on success, -1 on error
+ */
+int sms_stocAnalysis(int sizeWindow, sfloat *pResidual, sfloat *pWindow,
+ SMS_Data *pSmsData, SMS_AnalParams* pAnalParams)
+{
+ int i;
+ sfloat fMag = 0.0;
+
+ sms_spectrumMag(sizeWindow, pResidual, pWindow, pAnalParams->sizeStocMagSpectrum,
+ pAnalParams->stocMagSpectrum, pAnalParams->fftBuffer);
+
+ sms_spectralApprox(pAnalParams->stocMagSpectrum, pAnalParams->sizeStocMagSpectrum,
+ pAnalParams->sizeStocMagSpectrum, pSmsData->pFStocCoeff,
+ pSmsData->nCoeff, pSmsData->nCoeff,
+ pAnalParams->approxEnvelope);
+
+ /* get energy of spectrum */
+ for(i = 0; i < pAnalParams->sizeStocMagSpectrum; i++)
+ fMag += (pAnalParams->stocMagSpectrum[i] * pAnalParams->stocMagSpectrum[i]);
+
+ *pSmsData->pFStocGain = fMag / pAnalParams->sizeStocMagSpectrum;
+ return 0;
+}
+