summaryrefslogtreecommitdiff
path: root/sms/sms.i
diff options
context:
space:
mode:
Diffstat (limited to 'sms/sms.i')
-rw-r--r--sms/sms.i702
1 files changed, 342 insertions, 360 deletions
diff --git a/sms/sms.i b/sms/sms.i
index e091312..d33c280 100644
--- a/sms/sms.i
+++ b/sms/sms.i
@@ -1,4 +1,4 @@
-%module pysms
+%module simplsms
%{
#include "sms.h"
#define SWIG_FILE_WITH_INIT
@@ -9,7 +9,6 @@
%init
%{
import_array();
- sms_init(); /* initialize the library (makes some tables, seeds the random number generator, etc */
%}
%exception
@@ -23,24 +22,24 @@
}
/* apply all numpy typemaps to various names in sms.h */
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeWindow, double* pWindow)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeWaveform, double* pWaveform)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(long sizeSound, double* pSound)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeFft, double* pArray)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeFft, double* pFftBuffer)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeFreq, double* pFreq)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeAmp, double* pAmp)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeMag, double* pMag)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizePhase, double* pPhase)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeRes, double* pRes)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeCepstrum, double* pCepstrum)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeEnv, double* pEnv)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeTrack, double* pTrack)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeArray, double* pArray)};
-%apply (int DIM1, double* IN_ARRAY1) {(int sizeInArray, double* pInArray)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeOutArray, double* pOutArray)};
-%apply (int DIM1, double* INPLACE_ARRAY1) {(int sizeHop, double* pSynthesis)};
-%apply (int DIM1, double* IN_ARRAY1)
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeWindow, double* pWindow)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeWaveform, double* pWaveform)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(long sizeSound, double* pSound)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeFft, double* pArray)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeFft, double* pFftBuffer)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeFreq, double* pFreq)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeAmp, double* pAmp)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeMag, double* pMag)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizePhase, double* pPhase)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeRes, double* pRes)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeCepstrum, double* pCepstrum)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeEnv, double* pEnv)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeTrack, double* pTrack)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeArray, double* pArray)};
+%apply(int DIM1, double* IN_ARRAY1) {(int sizeInArray, double* pInArray)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeOutArray, double* pOutArray)};
+%apply(int DIM1, double* INPLACE_ARRAY1) {(int sizeHop, double* pSynthesis)};
+%apply(int DIM1, double* IN_ARRAY1)
{
(int numamps, double* amps),
(int numfreqs, double* freqs),
@@ -55,17 +54,16 @@
%include "sms.h"
-
/* overload the functions that will be wrapped to fit numpy typmaps (defined below)
* by renaming the wrapped names back to originals
*/
-%rename (sms_detectPeaks) simplsms_detectPeaks;
-%rename (sms_spectrum) simplsms_spectrum;
-%rename (sms_spectrumMag) simplsms_spectrumMag;
-%rename (sms_windowCentered) simplsms_windowCentered;
-%rename (sms_invSpectrum) simplsms_invSpectrum;
-%rename (sms_dCepstrum) simplsms_dCepstrum;
-%rename (sms_synthesize) simplsms_synthesize_wrapper;
+%rename(sms_detectPeaks) simplsms_detectPeaks;
+%rename(sms_spectrum) simplsms_spectrum;
+%rename(sms_spectrumMag) simplsms_spectrumMag;
+%rename(sms_windowCentered) simplsms_windowCentered;
+%rename(sms_invSpectrum) simplsms_invSpectrum;
+%rename(sms_dCepstrum) simplsms_dCepstrum;
+%rename(sms_synthesize) simplsms_synthesize_wrapper;
%inline
%{
@@ -76,8 +74,8 @@
int allocated;
} SMS_File;
- void simplsms_dCepstrum( int sizeCepstrum, sfloat *pCepstrum, int sizeFreq, sfloat *pFreq, int sizeMag, sfloat *pMag,
- sfloat fLambda, int iSamplingRate)
+ void simplsms_dCepstrum(int sizeCepstrum, sfloat *pCepstrum, int sizeFreq, sfloat *pFreq, int sizeMag, sfloat *pMag,
+ sfloat fLambda, int iSamplingRate)
{
sms_dCepstrum(sizeCepstrum,pCepstrum, sizeFreq, pFreq, pMag,
fLambda, iSamplingRate);
@@ -98,23 +96,23 @@
pPeakStruct->nPeaksFound = sms_detectPeaks(sizeMag, pMag, pPhase, pPeakStruct->pSpectralPeaks, pAnalParams);
return pPeakStruct->nPeaksFound;
}
- int simplsms_spectrum( int sizeWaveform, sfloat *pWaveform, int sizeWindow, sfloat *pWindow,
- int sizeMag, sfloat *pMag, int sizePhase, sfloat *pPhase)
+ int simplsms_spectrum(int sizeWaveform, sfloat *pWaveform, int sizeWindow, sfloat *pWindow,
+ int sizeMag, sfloat *pMag, int sizePhase, sfloat *pPhase, sfloat *pFftBuffer)
{
- return(sms_spectrum(sizeWindow, pWaveform, pWindow, sizeMag, pMag, pPhase));
+ return sms_spectrum(sizeWindow, pWaveform, pWindow, sizeMag, pMag, pPhase, pFftBuffer);
}
- int simplsms_spectrumMag( int sizeWaveform, sfloat *pWaveform, int sizeWindow, sfloat *pWindow,
- int sizeMag, sfloat *pMag)
+ int simplsms_spectrumMag(int sizeWaveform, sfloat *pWaveform, int sizeWindow, sfloat *pWindow,
+ int sizeMag, sfloat *pMag, sfloat *pFftBuffer)
{
- return(sms_spectrumMag(sizeWindow, pWaveform, pWindow, sizeMag, pMag));
+ return sms_spectrumMag(sizeWindow, pWaveform, pWindow, sizeMag, pMag, pFftBuffer);
}
- int simplsms_invSpectrum( int sizeWaveform, sfloat *pWaveform, int sizeWindow, sfloat *pWindow,
- int sizeMag, sfloat *pMag, int sizePhase, sfloat *pPhase)
+ int simplsms_invSpectrum(int sizeWaveform, sfloat *pWaveform, int sizeWindow, sfloat *pWindow,
+ int sizeMag, sfloat *pMag, int sizePhase, sfloat *pPhase, sfloat *pFftBuffer)
{
- return(sms_invSpectrum(sizeWaveform, pWaveform, pWindow, sizeMag, pMag, pPhase));
+ return sms_invSpectrum(sizeWaveform, pWaveform, pWindow, sizeMag, pMag, pPhase, pFftBuffer);
}
void simplsms_windowCentered(int sizeWaveform, sfloat *pWaveform, int sizeWindow,
- sfloat *pWindow, int sizeFft, sfloat *pFftBuffer)
+ sfloat *pWindow, int sizeFft, sfloat *pFftBuffer)
{
if (sizeWaveform != sizeWindow)
{
@@ -132,405 +130,389 @@
}
sms_synthesize(pSmsData, pSynthesis, pSynthParams);
}
-
%}
%extend SMS_File
{
/* load an entire file to an internal numpy array */
- void load( char *pFilename )
+ void load(char *pFilename)
{
- int i;
- FILE *pSmsFile;
- $self->allocated = 0;
- sms_getHeader (pFilename, &$self->header, &pSmsFile);
- if(sms_errorCheck()) return;
-
- $self->smsData = calloc($self->header->nFrames, sizeof(SMS_Data));
- for( i = 0; i < $self->header->nFrames; i++ )
- {
- sms_allocFrameH ($self->header, &$self->smsData[i]);
- if(sms_errorCheck()) return;
- sms_getFrame (pSmsFile, $self->header, i, &$self->smsData[i]);
- if(sms_errorCheck()) return;
- }
- $self->allocated = 1;
- return;
+ int i;
+ FILE *pSmsFile;
+ $self->allocated = 0;
+ sms_getHeader (pFilename, &$self->header, &pSmsFile);
+ if(sms_errorCheck()) return;
+
+ $self->smsData = calloc($self->header->nFrames, sizeof(SMS_Data));
+ for(i = 0; i < $self->header->nFrames; i++)
+ {
+ sms_allocFrameH ($self->header, &$self->smsData[i]);
+ if(sms_errorCheck())
+ return;
+ sms_getFrame (pSmsFile, $self->header, i, &$self->smsData[i]);
+ if(sms_errorCheck())
+ return;
+ }
+ $self->allocated = 1;
}
- void close(void) /* todo: this should be in the destructor, no? */
+ void close() /* todo: this should be in the destructor, no? */
{
- int i;
- if(!$self->allocated)
- {
- sms_error("file not yet alloceted");
- return;
- }
- $self->allocated = 0;
- for( i = 0; i < $self->header->nFrames; i++)
- sms_freeFrame(&$self->smsData[i]);
- free($self->smsData);
+ int i;
+ if(!$self->allocated)
+ {
+ sms_error("file not yet alloceted");
return;
+ }
+ $self->allocated = 0;
+ for(i = 0; i < $self->header->nFrames; i++)
+ sms_freeFrame(&$self->smsData[i]);
+ free($self->smsData);
}
/* return a pointer to a frame, which can be passed around to other libsms functions */
void getFrame(int i, SMS_Data *frame)
{
- if(i < 0 || i >= $self->header->nFrames)
- {
- sms_error("index is out of file boundaries");
- return;
- }
- frame = &$self->smsData[i];
+ if(i < 0 || i >= $self->header->nFrames)
+ {
+ sms_error("index is out of file boundaries");
+ return;
+ }
+ frame = &$self->smsData[i];
}
- void getTrack(int track, int sizeFreq, sfloat *pFreq, int sizeAmp,
- sfloat *pAmp)
+ void getTrack(int track, int sizeFreq, sfloat *pFreq, int sizeAmp, sfloat *pAmp)
{
- /* fatal error protection first */
- if(!$self->allocated)
- {
- sms_error("file not yet alloceted");
- return ;
- }
- if(track >= $self->header->nTracks)
- {
- sms_error("desired track is greater than number of tracks in file");
- return;
- }
- if(sizeFreq != sizeAmp)
- {
- sms_error("freq and amp arrays are different in size");
- return;
- }
- /* make sure arrays are big enough, or return less data */
- int nFrames = MIN (sizeFreq, $self->header->nFrames);
- int i;
- for( i=0; i < nFrames; i++)
- {
- pFreq[i] = $self->smsData[i].pFSinFreq[track];
- pAmp[i] = $self->smsData[i].pFSinAmp[track];
- }
+ /* fatal error protection first */
+ if(!$self->allocated)
+ {
+ sms_error("file not yet alloceted");
+ return;
+ }
+ if(track >= $self->header->nTracks)
+ {
+ sms_error("desired track is greater than number of tracks in file");
+ return;
+ }
+ if(sizeFreq != sizeAmp)
+ {
+ sms_error("freq and amp arrays are different in size");
+ return;
+ }
+ /* make sure arrays are big enough, or return less data */
+ int nFrames = MIN(sizeFreq, $self->header->nFrames);
+ int i;
+ for(i=0; i < nFrames; i++)
+ {
+ pFreq[i] = $self->smsData[i].pFSinFreq[track];
+ pAmp[i] = $self->smsData[i].pFSinAmp[track];
+ }
}
// TODO turn into getTrackP - and check if phase exists
void getTrack(int track, int sizeFreq, sfloat *pFreq, int sizeAmp,
- sfloat *pAmp, int sizePhase, sfloat *pPhase)
+ sfloat *pAmp, int sizePhase, sfloat *pPhase)
{
- /* fatal error protection first */
- if(!$self->allocated)
- {
- sms_error("file not yet alloceted");
- return ;
- }
- if(track >= $self->header->nTracks)
- {
- sms_error("desired track is greater than number of tracks in file");
- return;
- }
- if(sizeFreq != sizeAmp)
- {
- sms_error("freq and amp arrays are different in size");
- return;
- }
- /* make sure arrays are big enough, or return less data */
- int nFrames = MIN (sizeFreq, $self->header->nFrames);
- int i;
- for( i=0; i < nFrames; i++)
- {
- pFreq[i] = $self->smsData[i].pFSinFreq[track];
- pAmp[i] = $self->smsData[i].pFSinFreq[track];
- }
- if($self->header->iFormat < SMS_FORMAT_HP) return;
-
- if(sizePhase != sizeFreq || sizePhase != sizeAmp)
- {
- sms_error("phase array and freq/amp arrays are different in size");
- return;
- }
- for( i=0; i < nFrames; i++)
- pPhase[i] = $self->smsData[i].pFSinPha[track];
-
+ /* fatal error protection first */
+ if(!$self->allocated)
+ {
+ sms_error("file not yet alloceted");
return;
+ }
+ if(track >= $self->header->nTracks)
+ {
+ sms_error("desired track is greater than number of tracks in file");
+ return;
+ }
+ if(sizeFreq != sizeAmp)
+ {
+ sms_error("freq and amp arrays are different in size");
+ return;
+ }
+ /* make sure arrays are big enough, or return less data */
+ int nFrames = MIN (sizeFreq, $self->header->nFrames);
+ int i;
+ for(i=0; i < nFrames; i++)
+ {
+ pFreq[i] = $self->smsData[i].pFSinFreq[track];
+ pAmp[i] = $self->smsData[i].pFSinFreq[track];
+ }
+ if($self->header->iFormat < SMS_FORMAT_HP)
+ return;
+
+ if(sizePhase != sizeFreq || sizePhase != sizeAmp)
+ {
+ sms_error("phase array and freq/amp arrays are different in size");
+ return;
+ }
+ for(i=0; i < nFrames; i++)
+ pPhase[i] = $self->smsData[i].pFSinPha[track];
}
void getFrameDet(int i, int sizeFreq, sfloat *pFreq, int sizeAmp, sfloat *pAmp)
{
- if(!$self->allocated)
- {
- sms_error("file not yet alloceted");
- return ;
- }
- if(i >= $self->header->nFrames)
- {
- sms_error("index is greater than number of frames in file");
- return;
- }
- int nTracks = $self->smsData[i].nTracks;
- if(sizeFreq > nTracks)
- {
- sms_error("index is greater than number of frames in file");
- return;
- }
- if(sizeFreq != sizeAmp)
- {
- sms_error("freq and amp arrays are different in size");
- return;
- }
- memcpy(pFreq, $self->smsData[i].pFSinFreq, sizeof(sfloat) * nTracks);
- memcpy(pAmp, $self->smsData[i].pFSinAmp, sizeof(sfloat) * nTracks);
-
- if($self->header->iFormat < SMS_FORMAT_HP) return;
-
+ if(!$self->allocated)
+ {
+ sms_error("file not yet alloceted");
+ return;
+ }
+ if(i >= $self->header->nFrames)
+ {
+ sms_error("index is greater than number of frames in file");
+ return;
+ }
+ int nTracks = $self->smsData[i].nTracks;
+ if(sizeFreq > nTracks)
+ {
+ sms_error("index is greater than number of frames in file");
return;
+ }
+ if(sizeFreq != sizeAmp)
+ {
+ sms_error("freq and amp arrays are different in size");
+ return;
+ }
+ memcpy(pFreq, $self->smsData[i].pFSinFreq, sizeof(sfloat) * nTracks);
+ memcpy(pAmp, $self->smsData[i].pFSinAmp, sizeof(sfloat) * nTracks);
}
void getFrameDetP(int i, int sizeFreq, sfloat *pFreq, int sizeAmp,
- sfloat *pAmp, int sizePhase, sfloat *pPhase)
+ sfloat *pAmp, int sizePhase, sfloat *pPhase)
{
- if(!$self->allocated)
- {
- sms_error("file not yet alloceted");
- return ;
- }
- if($self->header->iFormat < SMS_FORMAT_HP)
- {
- sms_error("file does not contain a phase component in Deterministic (iFormat < SMS_FORMAT_HP)");
- return;
- }
- if(i >= $self->header->nFrames)
- {
- sms_error("index is greater than number of frames in file");
- return;
- }
- int nTracks = $self->smsData[i].nTracks;
- if(sizeFreq > nTracks)
- {
- sms_error("index is greater than number of frames in file");
- return;
- }
- if(sizeFreq != sizeAmp)
- {
- sms_error("freq and amp arrays are different in size");
- return;
- }
- memcpy(pFreq, $self->smsData[i].pFSinFreq, sizeof(sfloat) * nTracks);
- memcpy(pAmp, $self->smsData[i].pFSinAmp, sizeof(sfloat) * nTracks);
-
- if(sizePhase != sizeFreq || sizePhase != sizeAmp)
- {
- sms_error("phase array and freq/amp arrays are different in size");
- return;
- }
- memcpy(pPhase, $self->smsData[i].pFSinPha, sizeof(sfloat) * nTracks);
-
+ if(!$self->allocated)
+ {
+ sms_error("file not yet alloceted");
+ return;
+ }
+ if($self->header->iFormat < SMS_FORMAT_HP)
+ {
+ sms_error("file does not contain a phase component in Deterministic (iFormat < SMS_FORMAT_HP)");
+ return;
+ }
+ if(i >= $self->header->nFrames)
+ {
+ sms_error("index is greater than number of frames in file");
+ return;
+ }
+ int nTracks = $self->smsData[i].nTracks;
+ if(sizeFreq > nTracks)
+ {
+ sms_error("index is greater than number of frames in file");
return;
+ }
+ if(sizeFreq != sizeAmp)
+ {
+ sms_error("freq and amp arrays are different in size");
+ return;
+ }
+ memcpy(pFreq, $self->smsData[i].pFSinFreq, sizeof(sfloat) * nTracks);
+ memcpy(pAmp, $self->smsData[i].pFSinAmp, sizeof(sfloat) * nTracks);
+
+ if(sizePhase != sizeFreq || sizePhase != sizeAmp)
+ {
+ sms_error("phase array and freq/amp arrays are different in size");
+ return;
+ }
+ memcpy(pPhase, $self->smsData[i].pFSinPha, sizeof(sfloat) * nTracks);
}
void getFrameRes(int i, int sizeRes, sfloat *pRes)
{
-
- if(!$self->allocated)
- {
- sms_error("file not yet alloceted");
- return ;
- }
- if($self->header->iStochasticType < 1)
- {
- sms_error("file does not contain a stochastic component");
- return ;
- }
- int nCoeff = sizeRes;
- if($self->header->nStochasticCoeff > sizeRes)
- nCoeff = $self->header->nStochasticCoeff; // return what you can
-
- memcpy(pRes, $self->smsData[i].pFStocCoeff, sizeof(sfloat) * nCoeff);
+ if(!$self->allocated)
+ {
+ sms_error("file not yet alloceted");
return;
+ }
+ if($self->header->iStochasticType < 1)
+ {
+ sms_error("file does not contain a stochastic component");
+ return;
+ }
+ int nCoeff = sizeRes;
+ if($self->header->nStochasticCoeff > sizeRes)
+ nCoeff = $self->header->nStochasticCoeff; // return what you can
+
+ memcpy(pRes, $self->smsData[i].pFStocCoeff, sizeof(sfloat) * nCoeff);
}
void getFrameEnv(int i, int sizeEnv, sfloat *pEnv)
{
-
- if(!$self->allocated)
- {
- sms_error("file not yet alloceted");
- return ;
- }
- if($self->header->iEnvType < 1)
- {
- sms_error("file does not contain a spectral envelope");
- return ;
- }
- int nCoeff = sizeEnv;
- if($self->header->nStochasticCoeff > sizeEnv)
- nCoeff = $self->header->nEnvCoeff; // return what you can
-
- memcpy(pEnv, $self->smsData[i].pSpecEnv, sizeof(sfloat) * nCoeff);
+ if(!$self->allocated)
+ {
+ sms_error("file not yet alloceted");
return;
+ }
+ if($self->header->iEnvType < 1)
+ {
+ sms_error("file does not contain a spectral envelope");
+ return;
+ }
+ int nCoeff = sizeEnv;
+ if($self->header->nStochasticCoeff > sizeEnv)
+ nCoeff = $self->header->nEnvCoeff; // return what you can
+
+ memcpy(pEnv, $self->smsData[i].pSpecEnv, sizeof(sfloat) * nCoeff);
}
}
%extend SMS_AnalParams
{
- SMS_AnalParams()
- {
- SMS_AnalParams *s = (SMS_AnalParams *)malloc(sizeof(SMS_AnalParams));
- sms_initAnalParams(s);
- return s;
- }
+ SMS_AnalParams()
+ {
+ SMS_AnalParams *s = (SMS_AnalParams *)malloc(sizeof(SMS_AnalParams));
+ sms_initAnalParams(s);
+ return s;
+ }
}
%extend SMS_SynthParams
{
- SMS_SynthParams()
- {
- SMS_SynthParams *s = (SMS_SynthParams *)malloc(sizeof(SMS_SynthParams));
- sms_initSynthParams(s);
- return s;
- }
+ SMS_SynthParams()
+ {
+ SMS_SynthParams *s = (SMS_SynthParams *)malloc(sizeof(SMS_SynthParams));
+ sms_initSynthParams(s);
+ return s;
+ }
}
%extend SMS_SpectralPeaks
{
- SMS_SpectralPeaks(int n)
+ SMS_SpectralPeaks(int n)
+ {
+ SMS_SpectralPeaks *s = (SMS_SpectralPeaks *)malloc(sizeof(SMS_SpectralPeaks));
+ s->nPeaks = n;
+ if((s->pSpectralPeaks = (SMS_Peak *)calloc (s->nPeaks, sizeof(SMS_Peak))) == NULL)
{
- SMS_SpectralPeaks *s = (SMS_SpectralPeaks *)malloc(sizeof(SMS_SpectralPeaks));
- s->nPeaks = n;
- if ((s->pSpectralPeaks =
- (SMS_Peak *)calloc (s->nPeaks, sizeof(SMS_Peak))) == NULL)
- {
- sms_error("could not allocate memory for spectral peaks");
- return(NULL);
- }
- s->nPeaksFound = 0;
- return s;
+ sms_error("could not allocate memory for spectral peaks");
+ return NULL;
}
- void getFreq( int sizeArray, sfloat *pArray )
+ s->nPeaksFound = 0;
+ return s;
+ }
+ void getFreq(int sizeArray, sfloat *pArray )
+ {
+ if(sizeArray < $self->nPeaksFound)
{
- if(sizeArray < $self->nPeaksFound)
- {
- sms_error("numpy array not big enough");
- return;
- }
- int i;
- for (i = 0; i < $self->nPeaksFound; i++)
- pArray[i] = $self->pSpectralPeaks[i].fFreq;
-
+ sms_error("numpy array not big enough");
+ return;
}
- void getMag( int sizeArray, sfloat *pArray )
+ int i;
+ for(i = 0; i < $self->nPeaksFound; i++)
+ pArray[i] = $self->pSpectralPeaks[i].fFreq;
+ }
+ void getMag( int sizeArray, sfloat *pArray )
+ {
+ if(sizeArray < $self->nPeaksFound)
{
- if(sizeArray < $self->nPeaksFound)
- {
- sms_error("numpy array not big enough");
- return;
- }
- int i;
- for (i = 0; i < $self->nPeaksFound; i++)
- pArray[i] = $self->pSpectralPeaks[i].fMag;
+ sms_error("numpy array not big enough");
+ return;
}
- void getPhase( int sizeArray, sfloat *pArray )
+ int i;
+ for(i = 0; i < $self->nPeaksFound; i++)
+ pArray[i] = $self->pSpectralPeaks[i].fMag;
+ }
+ void getPhase( int sizeArray, sfloat *pArray )
+ {
+ if(sizeArray < $self->nPeaksFound)
{
- if(sizeArray < $self->nPeaksFound)
- {
- sms_error("numpy array not big enough");
- return;
- }
- int i;
- for (i = 0; i < $self->nPeaksFound; i++)
- pArray[i] = $self->pSpectralPeaks[i].fPhase;
-
+ sms_error("numpy array not big enough");
+ return;
}
+ int i;
+ for(i = 0; i < $self->nPeaksFound; i++)
+ pArray[i] = $self->pSpectralPeaks[i].fPhase;
+ }
}
%extend SMS_Data
{
- void getSinAmp(int sizeArray, sfloat *pArray)
+ void getSinAmp(int sizeArray, sfloat *pArray)
+ {
+ if(sizeArray < $self->nTracks)
{
- if(sizeArray < $self->nTracks)
- {
- sms_error("numpy array not big enough");
- return;
- }
- int i;
- for (i = 0; i < $self->nTracks; i++)
- pArray[i] = $self->pFSinAmp[i];
+ sms_error("numpy array not big enough");
+ return;
}
- void getSinFreq(int sizeArray, sfloat *pArray)
+ int i;
+ for(i = 0; i < $self->nTracks; i++)
+ pArray[i] = $self->pFSinAmp[i];
+ }
+ void getSinFreq(int sizeArray, sfloat *pArray)
+ {
+ if(sizeArray < $self->nTracks)
{
- if(sizeArray < $self->nTracks)
- {
- sms_error("numpy array not big enough");
- return;
- }
- int i;
- for (i = 0; i < $self->nTracks; i++)
- pArray[i] = $self->pFSinFreq[i];
+ sms_error("numpy array not big enough");
+ return;
}
- void getSinPhase(int sizeArray, sfloat *pArray)
+ int i;
+ for(i = 0; i < $self->nTracks; i++)
+ pArray[i] = $self->pFSinFreq[i];
+ }
+ void getSinPhase(int sizeArray, sfloat *pArray)
+ {
+ if(sizeArray < $self->nTracks)
{
- if(sizeArray < $self->nTracks)
- {
- sms_error("numpy array not big enough");
- return;
- }
- int i;
- for (i = 0; i < $self->nTracks; i++)
- pArray[i] = $self->pFSinPha[i];
+ sms_error("numpy array not big enough");
+ return;
}
- void getSinEnv(int sizeArray, sfloat *pArray)
+ int i;
+ for(i = 0; i < $self->nTracks; i++)
+ pArray[i] = $self->pFSinPha[i];
+ }
+ void getSinEnv(int sizeArray, sfloat *pArray)
+ {
+ if(sizeArray < $self->nEnvCoeff)
{
- if(sizeArray < $self->nEnvCoeff)
- {
- sms_error("numpy array not big enough");
- return;
- }
- int i;
- for (i = 0; i < $self->nEnvCoeff; i++)
- pArray[i] = $self->pSpecEnv[i];
+ sms_error("numpy array not big enough");
+ return;
}
- void setSinAmp(int sizeArray, sfloat *pArray)
+ int i;
+ for(i = 0; i < $self->nEnvCoeff; i++)
+ pArray[i] = $self->pSpecEnv[i];
+ }
+ void setSinAmp(int sizeArray, sfloat *pArray)
+ {
+ if(sizeArray < $self->nTracks)
{
- if(sizeArray < $self->nTracks)
- {
- sms_error("numpy array not big enough");
- return;
- }
- int i;
- for (i = 0; i < $self->nTracks; i++)
- $self->pFSinAmp[i] = pArray[i];
-
+ sms_error("numpy array not big enough");
+ return;
}
- void setSinFreq(int sizeArray, sfloat *pArray)
+ int i;
+ for (i = 0; i < $self->nTracks; i++)
+ $self->pFSinAmp[i] = pArray[i];
+ }
+ void setSinFreq(int sizeArray, sfloat *pArray)
+ {
+ if(sizeArray < $self->nTracks)
{
- if(sizeArray < $self->nTracks)
- {
- sms_error("numpy array not big enough");
- return;
- }
- int i;
- for (i = 0; i < $self->nTracks; i++)
- $self->pFSinFreq[i] = pArray[i];
+ sms_error("numpy array not big enough");
+ return;
}
- void setSinPha(int sizeArray, sfloat *pArray)
+ int i;
+ for(i = 0; i < $self->nTracks; i++)
+ $self->pFSinFreq[i] = pArray[i];
+ }
+ void setSinPha(int sizeArray, sfloat *pArray)
+ {
+ if(sizeArray < $self->nTracks)
{
- if(sizeArray < $self->nTracks)
- {
- sms_error("numpy array not big enough");
- return;
- }
- int i;
- for (i = 0; i < $self->nTracks; i++)
- $self->pFSinPha[i] = pArray[i];
+ sms_error("numpy array not big enough");
+ return;
}
+ int i;
+ for(i = 0; i < $self->nTracks; i++)
+ $self->pFSinPha[i] = pArray[i];
+ }
}
%extend SMS_ModifyParams
{
- /* no need to return an error code, if sms_error is called, it will throw an exception in python */
- void setSinEnv(int sizeArray, sfloat *pArray)
+ /* no need to return an error code, if sms_error is called, it will throw an exception in python */
+ void setSinEnv(int sizeArray, sfloat *pArray)
+ {
+ if(!$self->ready)
{
- if(!$self->ready)
- {
- sms_error("modify parameter structure has not been initialized");
- return;
- }
- if(sizeArray != $self->sizeSinEnv)
- {
- sms_error("numpy array is not equal to envelope size");
- return;
- }
- memcpy($self->sinEnv, pArray, sizeof(sfloat) * $self->sizeSinEnv);
+ sms_error("modify parameter structure has not been initialized");
+ return;
+ }
+ if(sizeArray != $self->sizeSinEnv)
+ {
+ sms_error("numpy array is not equal to envelope size");
+ return;
}
+ memcpy($self->sinEnv, pArray, sizeof(sfloat) * $self->sizeSinEnv);
+ }
}
+