mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2024-11-19 10:32:02 -05:00
5b9645bf09
git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/trunk@189 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
115 lines
3.3 KiB
C
115 lines
3.3 KiB
C
/*
|
|
* $Id$
|
|
patest1.c
|
|
Ring modulate the audio input with a 441hz sine wave for 20 seconds
|
|
using the Portable Audio api
|
|
Author: Ross Bencina <rossb@audiomulch.com>
|
|
Modifications:
|
|
April 5th, 2001 - PLB - Check for NULL inputBuffer.
|
|
*/
|
|
#include <stdio.h>
|
|
#include <math.h>
|
|
#include "portaudio.h"
|
|
#ifndef M_PI
|
|
#define M_PI (3.14159265)
|
|
#endif
|
|
typedef struct
|
|
{
|
|
float sine[100];
|
|
int phase;
|
|
int sampsToGo;
|
|
}
|
|
patest1data;
|
|
static int patest1Callback( void *inputBuffer, void *outputBuffer,
|
|
unsigned long bufferFrames,
|
|
PaTimestamp outTime, void *userData )
|
|
{
|
|
patest1data *data = (patest1data*)userData;
|
|
float *in = (float*)inputBuffer;
|
|
float *out = (float*)outputBuffer;
|
|
int framesToCalc = bufferFrames;
|
|
unsigned long i;
|
|
int finished = 0;
|
|
if(inputBuffer == NULL) return 0;
|
|
if( data->sampsToGo < bufferFrames )
|
|
{
|
|
finished = 1;
|
|
}
|
|
for( i=0; i<bufferFrames; i++ )
|
|
{
|
|
*out++ = *in++;
|
|
*out++ = *in++;
|
|
if( data->phase >= 100 )
|
|
data->phase = 0;
|
|
}
|
|
data->sampsToGo -= bufferFrames;
|
|
/* zero remainder of final buffer if not already done */
|
|
for( ; i<bufferFrames; i++ )
|
|
{
|
|
*out++ = 0; /* left */
|
|
*out++ = 0; /* right */
|
|
}
|
|
return finished;
|
|
}
|
|
int main(int argc, char* argv[]);
|
|
int main(int argc, char* argv[])
|
|
{
|
|
PaStream *stream;
|
|
PaError err;
|
|
patest1data data;
|
|
int i;
|
|
int inputDevice = Pa_GetDefaultInputDeviceID();
|
|
int outputDevice = Pa_GetDefaultOutputDeviceID();
|
|
/* initialise sinusoidal wavetable */
|
|
for( i=0; i<100; i++ )
|
|
data.sine[i] = sin( ((double)i/100.) * M_PI * 2. );
|
|
data.phase = 0;
|
|
data.sampsToGo = 44100 * 4; // 20 seconds
|
|
/* initialise portaudio subsytem */
|
|
Pa_Initialize();
|
|
err = Pa_OpenStream(
|
|
&stream,
|
|
inputDevice,
|
|
2, /* stereo input */
|
|
paFloat32, /* 32 bit floating point input */
|
|
NULL,
|
|
outputDevice,
|
|
2, /* stereo output */
|
|
paFloat32, /* 32 bit floating point output */
|
|
NULL,
|
|
44100.,
|
|
// 22050, /* half second buffers */
|
|
// 4, /* four buffers */
|
|
512, /* half second buffers */
|
|
0, /* four buffers */
|
|
paClipOff, /* we won't output out of range samples so don't bother clipping them */
|
|
patest1Callback,
|
|
&data );
|
|
if( err == paNoError )
|
|
{
|
|
err = Pa_StartStream( stream );
|
|
// printf( "Press any key to end.\n" );
|
|
// getc( stdin ); //wait for input before exiting
|
|
// Pa_AbortStream( stream );
|
|
|
|
printf( "Waiting for stream to complete...\n" );
|
|
|
|
while( Pa_StreamActive( stream ) )
|
|
Pa_Sleep(1000); /* sleep until playback has finished */
|
|
|
|
err = Pa_CloseStream( stream );
|
|
}
|
|
else
|
|
{
|
|
fprintf( stderr, "An error occured while opening the portaudio stream\n" );
|
|
if( err == paHostError )
|
|
fprintf( stderr, "Host error number: %d\n", Pa_GetHostError() );
|
|
else
|
|
fprintf( stderr, "Error number: %d\n", err );
|
|
}
|
|
Pa_Terminate();
|
|
printf( "bye\n" );
|
|
|
|
return 0;
|
|
}
|