2020-09-22 15:37:19 +00:00
|
|
|
#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 );
|
|
|
|
|
2021-02-21 13:49:11 +00:00
|
|
|
// 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 );
|
|
|
|
|
2020-09-22 15:37:19 +00:00
|
|
|
// 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 begSec, double endSec, unsigned outBits, const char* outDir, const char* outFn );
|
|
|
|
rc_t selectToFile( const object_t* cfg );
|
|
|
|
|
|
|
|
|
2020-10-04 14:50:43 +00:00
|
|
|
// Arbitrary cross fader
|
2020-09-22 15:37:19 +00:00
|
|
|
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
|
2020-10-04 14:50:43 +00:00
|
|
|
double gain; // scale the signal
|
2020-09-22 15:37:19 +00:00
|
|
|
} 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 );
|
|
|
|
|
2020-10-04 14:50:43 +00:00
|
|
|
// Given a collection of overlapping tracks fade in/out sections of the tracks at specified times.
|
|
|
|
// This is a wrapper around cutAndMix()
|
2020-09-22 15:37:19 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
const char* srcFn;
|
2020-10-04 14:50:43 +00:00
|
|
|
double srcBegSec;
|
|
|
|
double srcEndSec;
|
|
|
|
double fadeOutSec;
|
|
|
|
double gain;
|
2020-09-22 15:37:19 +00:00
|
|
|
} 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 );
|
|
|
|
|
2021-02-21 13:49:11 +00:00
|
|
|
// Currawong on-line transform application
|
2020-10-04 14:50:43 +00:00
|
|
|
rc_t transformApp( const object_t* cfg );
|
|
|
|
|
2021-02-21 13:49:11 +00:00
|
|
|
// Convolve an impulse response from 'impulseRespnseFn' with 'srcFn'.
|
2020-10-04 14:50:43 +00:00
|
|
|
rc_t convolve( const char* dstFn, unsigned dstBits, const char* srcFn, const char* impulseResponseFn, float irScale=1 );
|
|
|
|
rc_t convolve( const object_t* cfg );
|
|
|
|
|
2020-09-22 15:37:19 +00:00
|
|
|
rc_t test( const object_t* cfg );
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|