/
(8.D.2.8) WaveFileSink

(8.D.2.8) WaveFileSink

Overview

Captures the input wire audio samples and writes it into a multi-channel output .wav file

Discussion

The WaveFileSink module captures audio samples from the input pin and writes them to the output .wav file specified by the user. File writing happens in the deferred processing thread, if .isActive flag is TRUE, so as to not interrupt real-time processing. On the halting the current run, output .wav is available to the user.

Arguments

This module has one input pin. The output .wav will capture all the channels from the input pin, and will use the sample rate derived the input pin. The sampleSize (either 2 or 4 bytes) of the recorded audio is a module argument. The module is designed to work with both Native and Linux targets. The directoryName and baseName of the output.wav can also be specified as module arguments.

e.g.: if the baseName:RECORD then output .wav = RECORD.wav).

By prefixing or postfixing to the baseName, the output .wav file will be created with timestamp information appended to the file name.

e.g.: if # is prefixed in the baseName:#-RECORD then output .wav = YYYYMONDAY_HHMMSS-RECORD.wav).

e.g.: if # is postfixed in the baseName:RECORD-# then output .wav = RECORD-YYYYMONDAY_HHMMSS.wav).

Also note that and absolute paths for directoryName are not portable across Windows and Linux, but relative paths are.

e.g.: Linux full directoryName : /home/pi/AudioWeaver-8.0.0-Linux/AWECore/Audio will not work in Windows environment, and Windows full directoryName \Audio\ will not work in the Linux environment

e.g.: The following types of relative directoryName (relative to the current working directory) ../AWECore/Audio or ..\AudioWeaver\Audio are portable across Windows and Linux environment

Note that the current working directory in Windows is: \Bin\win32-vc142-rel (32 bit builds) or \Bin\x64-vc142-rel(64 bit builds)

The current working directory in Linux is the directory where the application is executed from

e.g.: if the package (AWECoreOS) is extracted on the target and the sample application Libtester is executed from ~/AWECoreOS/Bin, then the Bin directory is the current working directory in this case

The blockSize of the module will be derived from the input pin.

The cache size argument defines the size of the cache buffer that is allocated by the module to store the audio before issuing a fwrite in the deferred set call. This is a per channel configuration, internally the module will allocate a buffer that is cache size * number of channels. If the user notices that the overRunCtr counter is incrementing, indicating insufficient caching, then try increasing the cache size until no more over runs occur. To avoid circular wrap of cache buffer with in a block, the size of the cache buffer is aligned with the block size. i.e. the allocated cache buffer size is ceil(cache size/blockSize) * blockSize * number of channels

Supported File Formats

The WaveFileSink module creates an output .wav file of the following format:

    Chunk ID : RIFF

    WAVE ID : WAVE

    sub chunk1 ID : fmt

    sub chunk2 ID : data

    Format Tag : PCM (1)

Inspector Details

On double clicking the module, an inspector will show up on the canvas with the following information:

initDone : 0 indicates that initialization failed, 4 indicates that the file name initialization was successful, and 1 means that the file is writing successfully

isActive : Used to control start/pause. On pause, the module stops capturing the audio data from the input pin.

overRunCtr : This counter increments when the cache overflows. Increase the cacheSize argument to prevent over runs.

errorCode : Captures errors that arise in the module C code. To help debug the configuration

Error Codes

Possible ERROR codes, reported (Inspector -> errorCode). In this situation the module stays uninitialized (initDone = 0) and the .wav file is not created

E_WAVE_FILE_OPEN -1 : File fopen command error (output.wav)

E_WAVE_FILE_READ -2 : File fread command error (output.wav)

E_WAVE_FILE_WRITE -3 : File fwrite command error (output.wav)

E_WAVE_FILE_FSEEK -4 : File fseek command error (output.wav)

E_WAVE_FILE_EXISTS -5 : File already exits / File name already used by another module in the layout

E_WAVE_FILE_INVALID_DIR -6 : File fopen command error : No such file or directory

E_WAVE_FILE_NOT_EN_MEM -7 : File fopen command error : Out of memory

E_WAVE_FILE_ACC_DENIED -8 : File fopen command error : write permission is denied

E_WAVE_FILE_RO_FS -9 : File fopen command error : read-only file system and mode requires write access

Type Definition

typedef struct _ModuleWaveFileSink { ModuleInstanceDescriptor instance; // Common Audio Weaver module instance structure UINT32 cacheSize; // The size of the buffer that is used to store the audio samples captured from the input pin before the deferred set call issues a fwrite, defined in terms number of samples per channel (CACHESIZE * NUMCHANNELS) UINT32 sampleSize; // Size of the sample to be stored in the file (2 bytes / 4 bytes) INT32 isActive; // True means recording is active/started, false means recording is paused. Can be dynamically controlled in inspector INT32 initDone; // State variable, indicates initialization done state. Appears on the inspector UINT32 readIndex; // Current read-pointer of the cache memory UINT32 writeIndex; // Current write-pointer of the cache memory UINT32 fillLevel; // Current fill level in the cache UINT32 overRunCtr; // Counts the number of over runs, incremented when the cache overflows. Appears on the inspector INT32 errorCode; // Captures errors that could arise in the module C code. Appears on the inspector UINT32 totalNoSamples; // Total number of samples written into the output.wav INT32 fullFileSize; // Size of the array to hold the full file path for the output.wav file to be created INT32* fullFileName; // Complete file path for the output.wav file to be created fract32* cache; // The buffer used to store the audio samples from the input wire before the deferred set call issues a fwrite void * inFile; // File pointer to access the output wav file } ModuleWaveFileSinkClass;

Variables

Properties

Name

Type

Usage

isHidden

Default value

Range

Units

cacheSize

uint

const

0

2048

Unrestricted

 

sampleSize

uint

const

0

2

Unrestricted

 

isActive

int

parameter

0

1

Unrestricted

 

initDone

int

state

0

0

Unrestricted

 

readIndex

uint

state

0

0

Unrestricted

 

writeIndex

uint

state

0

0

Unrestricted

 

fillLevel

uint

state

0

0

Unrestricted

 

overRunCtr

uint

state

0

0

Unrestricted

 

errorCode

int

state

0

0

Unrestricted

 

totalNoSamples

uint

const

0

0

Unrestricted

 

fullFileSize

int

const

0

2

Unrestricted

 

fullFileName

int*

parameter

1

[1 x 2]

Unrestricted

 

cache

fract32*

state

0

[0 x 0]

Unrestricted

 

inFile

void *

const

0

 

Unrestricted

 

Pins

Input Pins

Name: in

Description: Input audio

Data type: fract32

Channel range: Unrestricted

Block size range: Unrestricted

Sample rate range: Unrestricted

Complex support: Real

MATLAB Usage

File Name: wave_file_sink_module.m

M = wave_file_sink_module(NAME, DIRECTORYNAME, BASENAME, CACHESIZE, SAMPLESIZE) WaveFileSink module captures the input data from the input pin and stores it on to a output.wav (RIFF) file. The audio data from the input pin is stored to a buffer (cache) by the process function and periodically written into the file in the deferred call. Output .wav file will be a wave file of PCM format only. User configurable sample width of 2 or 4 bytes for output .wav. Floating point data not supported. The data on the input pin is always of the type Fract32 This module is designed to work on Native and Linux targets