Spaces:
Runtime error
Runtime error
/* | |
* PortAudio Portable Real-Time Audio Library | |
* Latest Version at: http://www.portaudio.com | |
* | |
* Copyright (c) 1999-2010 Phil Burk and Ross Bencina | |
* | |
* Permission is hereby granted, free of charge, to any person obtaining | |
* a copy of this software and associated documentation files | |
* (the "Software"), to deal in the Software without restriction, | |
* including without limitation the rights to use, copy, modify, merge, | |
* publish, distribute, sublicense, and/or sell copies of the Software, | |
* and to permit persons to whom the Software is furnished to do so, | |
* subject to the following conditions: | |
* | |
* The above copyright notice and this permission notice shall be | |
* included in all copies or substantial portions of the Software. | |
* | |
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | |
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | |
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. | |
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR | |
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF | |
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | |
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | |
*/ | |
/* | |
* The text above constitutes the entire PortAudio license; however, | |
* the PortAudio community also makes the following non-binding requests: | |
* | |
* Any person wishing to distribute modifications to the Software is | |
* requested to send the modifications to the original developer so that | |
* they can be incorporated into the canonical version. It is also | |
* requested that these non-binding requests be included along with the | |
* license above. | |
*/ | |
typedef struct PaQaSineGenerator_s | |
{ | |
double phase; | |
double phaseIncrement; | |
double frequency; | |
double amplitude; | |
} PaQaSineGenerator; | |
/** Container for a monophonic audio sample in memory. */ | |
typedef struct PaQaRecording_s | |
{ | |
/** Maximum number of frames that can fit in the allocated buffer. */ | |
int maxFrames; | |
float *buffer; | |
/** Actual number of valid frames in the buffer. */ | |
int numFrames; | |
int sampleRate; | |
} PaQaRecording; | |
typedef struct PaQaTestTone_s | |
{ | |
int samplesPerFrame; | |
int startDelay; | |
double sampleRate; | |
double frequency; | |
double amplitude; | |
} PaQaTestTone; | |
typedef struct PaQaAnalysisResult_s | |
{ | |
int valid; | |
/** Latency in samples from output to input. */ | |
double latency; | |
double amplitudeRatio; | |
double popAmplitude; | |
double popPosition; | |
double numDroppedFrames; | |
double droppedFramesPosition; | |
double numAddedFrames; | |
double addedFramesPosition; | |
} PaQaAnalysisResult; | |
/*================================================================*/ | |
/*================= General DSP Tools ============================*/ | |
/*================================================================*/ | |
/** | |
* Calculate Nth frequency of a series for use in testing multiple channels. | |
* Series should avoid harmonic overlap between channels. | |
*/ | |
double PaQa_GetNthFrequency( double baseFrequency, int index ); | |
void PaQa_EraseBuffer( float *buffer, int numFrames, int samplesPerFrame ); | |
void PaQa_MixSine( PaQaSineGenerator *generator, float *buffer, int numSamples, int stride ); | |
void PaQa_WriteSine( float *buffer, int numSamples, int stride, | |
double frequency, double amplitude ); | |
/** | |
* Generate a signal with a sharp edge in the middle that can be recognized despite some phase shift. | |
*/ | |
void PaQa_GenerateCrack( float *buffer, int numSamples, int stride ); | |
double PaQa_ComputePhaseDifference( double phase1, double phase2 ); | |
/** | |
* Measure the area under the curve by summing absolute value of each value. | |
*/ | |
double PaQa_MeasureArea( float *buffer, int numFrames, int stride ); | |
/** | |
* Measure slope of the positive zero crossings. | |
*/ | |
double PaQa_MeasureCrossingSlope( float *buffer, int numFrames ); | |
/** | |
* Prepare an oscillator that can generate a sine tone for testing. | |
*/ | |
void PaQa_SetupSineGenerator( PaQaSineGenerator *generator, double frequency, double amplitude, double frameRate ); | |
/*================================================================*/ | |
/*================= Recordings ===================================*/ | |
/*================================================================*/ | |
/** | |
* Allocate memory for containing a mono audio signal. Set up recording for writing. | |
*/ | |
int PaQa_InitializeRecording( PaQaRecording *recording, int maxSamples, int sampleRate ); | |
/** | |
* Free memory allocated by PaQa_InitializeRecording. | |
*/ | |
void PaQa_TerminateRecording( PaQaRecording *recording ); | |
/** | |
* Apply a biquad filter to the audio from the input recording and write it to the output recording. | |
*/ | |
void PaQa_FilterRecording( PaQaRecording *input, PaQaRecording *output, BiquadFilter *filter ); | |
int PaQa_SaveRecordingToWaveFile( PaQaRecording *recording, const char *filename ); | |
/** | |
* @param stride is the spacing of samples to skip in the input buffer. To use every samples pass 1. To use every other sample pass 2. | |
*/ | |
int PaQa_WriteRecording( PaQaRecording *recording, float *buffer, int numSamples, int stride ); | |
/** Write zeros into a recording. */ | |
int PaQa_WriteSilence( PaQaRecording *recording, int numSamples ); | |
int PaQa_RecordFreeze( PaQaRecording *recording, int numSamples ); | |
double PaQa_CorrelateSine( PaQaRecording *recording, double frequency, double frameRate, | |
int startFrame, int numSamples, double *phasePtr ); | |
double PaQa_FindFirstMatch( PaQaRecording *recording, float *buffer, int numSamples, double tolerance ); | |
/** | |
* Estimate the original amplitude of a clipped sine wave by measuring | |
* its average slope at the zero crossings. | |
*/ | |
double PaQa_MeasureSineAmplitudeBySlope( PaQaRecording *recording, | |
double frequency, double frameRate, | |
int startFrame, int numFrames ); | |
double PaQa_MeasureRootMeanSquare( float *buffer, int numFrames ); | |
/** | |
* Compare the amplitudes of these two signals. | |
* Return ratio of recorded signal over buffer signal. | |
*/ | |
double PaQa_CompareAmplitudes( PaQaRecording *recording, int startAt, float *buffer, int numSamples ); | |
/** | |
* Analyse a recording of a sine wave. | |
* Measure latency and look for dropped frames, etc. | |
*/ | |
int PaQa_AnalyseRecording( PaQaRecording *recording, PaQaTestTone *testTone, PaQaAnalysisResult *analysisResult ); | |