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 ); | |