70 lines
2.7 KiB
C++
70 lines
2.7 KiB
C++
#ifndef cwAudioFileOps_h
|
|
#define cwAudioFileOps_h
|
|
|
|
namespace cw
|
|
{
|
|
namespace afop
|
|
{
|
|
|
|
// Generate a sine tone and write it to a file.
|
|
rc_t sine( const char* fn, double srate, unsigned bits, double hz, double gain, double secs );
|
|
rc_t sine( const object_t* cfg );
|
|
|
|
// Generate clicks (unit impulses) at the sample locations.
|
|
rc_t clicks( const char* fn, double srate, unsigned bits, double secs, const unsigned* clickSmpOffsArray, unsigned clickSmpOffsetN, double clickAmp = 0.9, double decay=0.7, double burstMs=10 );
|
|
|
|
// Parse the 'generate' paramter configuration and generate a file.
|
|
rc_t generate( const object_t* cfg );
|
|
|
|
// Mix a set of audio files.
|
|
rc_t mix( const char* fnV[], const float* gainV, unsigned srcN, const char* outFn, unsigned outBits );
|
|
rc_t mix( const object_t* cfg );
|
|
|
|
// Copy a time selection to an audio output file.
|
|
rc_t selectToFile( const char* srcFn, double beg0Sec, double beg1Sec, double end0Sec, double end1Sec, unsigned outBits, const char* outDir, const char* outFn );
|
|
rc_t selectToFile( const object_t* cfg );
|
|
|
|
|
|
// Arbitrary cross fader
|
|
typedef struct {
|
|
const char* srcFn; // source audio file name
|
|
double srcBegSec; // source clip begin
|
|
double srcEndSec; // source clip end
|
|
double srcBegFadeSec; // length of fade in (fade begins at srcBegSec and ends at srcBegSec+srcBegFadeSec)
|
|
double srcEndFadeSec; // length of fade out (fade begins at srcEndSec-srcEndFadeSec and ends at srcEndSec)
|
|
double dstBegSec; // clip output location
|
|
double gain; // scale the signal
|
|
} cutMixArg_t;
|
|
|
|
rc_t cutAndMix( const char* outFn, unsigned outBits, const char* srcDir, const cutMixArg_t* argL, unsigned argN );
|
|
rc_t cutAndMix( const object_t* cfg );
|
|
|
|
// Given a collection of overlapping tracks fade in/out sections of the tracks at specified times.
|
|
// This is a wrapper around cutAndMix()
|
|
typedef struct
|
|
{
|
|
const char* srcFn;
|
|
double srcBegSec;
|
|
double srcEndSec;
|
|
double fadeOutSec;
|
|
double gain;
|
|
} parallelMixArg_t;
|
|
|
|
rc_t parallelMix( const char* dstFn, unsigned dstBits, const char* srcDir, const parallelMixArg_t* argL, unsigned argN );
|
|
rc_t parallelMix( const object_t* cfg );
|
|
|
|
// Currawong on-line transform application
|
|
rc_t transformApp( const object_t* cfg );
|
|
|
|
// Convolve an impulse response from 'impulseRespnseFn' with 'srcFn'.
|
|
rc_t convolve( const char* dstFn, unsigned dstBits, const char* srcFn, const char* impulseResponseFn, float irScale=1 );
|
|
rc_t convolve( const object_t* cfg );
|
|
|
|
rc_t test( const object_t* cfg );
|
|
|
|
}
|
|
}
|
|
|
|
|
|
#endif
|