X-Git-Url: https://git.aubio.org/?p=aubio.git;a=blobdiff_plain;f=src%2Fio%2Fioutils.c;h=55f7c4f0305f975675b3da256d4f1ca5b05ef71f;hp=cce93c679bde085675199f84013bcba47f105136;hb=efaeaf17c74bb4d4a28f92826a03fbc40e80efd5;hpb=33d02426605c9921044f569805734c5449854646;ds=sidebyside diff --git a/src/io/ioutils.c b/src/io/ioutils.c index cce93c67..55f7c4f0 100644 --- a/src/io/ioutils.c +++ b/src/io/ioutils.c @@ -19,6 +19,7 @@ */ #include "aubio_priv.h" +#include "fmat.h" uint_t aubio_io_validate_samplerate(const char_t *kind, const char_t *path, uint_t samplerate) @@ -51,3 +52,99 @@ aubio_io_validate_channels(const char_t *kind, const char_t *path, uint_t channe } return AUBIO_OK; } + +uint_t +aubio_source_validate_input_length(const char_t *kind, const char_t *path, + uint_t hop_size, uint_t read_data_length) +{ + uint_t length = hop_size; + if (hop_size < read_data_length) { + AUBIO_WRN("%s: partial read from %s, trying to read %d frames, but" + " hop_size is %d\n", kind, path, read_data_length, hop_size); + } else if (hop_size > read_data_length) { + AUBIO_WRN("%s: partial read from %s, trying to read %d frames into" + " a buffer of length %d\n", kind, path, hop_size, read_data_length); + length = read_data_length; + } + return length; +} + +uint_t +aubio_source_validate_input_channels(const char_t *kind, const char_t *path, + uint_t source_channels, uint_t read_data_height) +{ + uint_t channels = source_channels; + if (read_data_height < source_channels) { + AUBIO_WRN("%s: partial read from %s, trying to read %d channels," + " but found output of height %d\n", kind, path, source_channels, + read_data_height); + channels = read_data_height; + } else if (read_data_height > source_channels) { + // do not show a warning when trying to read into more channels than + // the input source. +#if 0 + AUBIO_WRN("%s: partial read from %s, trying to read %d channels," + " but found output of height %d\n", kind, path, source_channels, + read_data_height); +#endif + channels = source_channels; + } + return channels; +} + +void +aubio_source_pad_output (fvec_t *read_data, uint_t source_read) +{ + if (source_read < read_data->length) { + AUBIO_MEMSET(read_data->data + source_read, 0, read_data->length - + source_read); + } +} + +void +aubio_source_pad_multi_output (fmat_t *read_data, + uint_t source_channels, uint_t source_read) { + uint_t i; + if (source_read < read_data->length) { + for (i = 0; i < read_data->height; i++) { + AUBIO_MEMSET(read_data->data[i] + source_read, 0, + read_data->length - source_read); + } + } +} + +uint_t +aubio_sink_validate_input_length(const char_t *kind, const char_t *path, + uint_t max_size, uint_t write_data_length, uint_t write) +{ + uint_t can_write = write; + + if (write > max_size) { + AUBIO_WRN("%s: partial write to %s, trying to write %d frames," + " at most %d can be written at once\n", kind, path, write, max_size); + can_write = max_size; + } + + if (can_write > write_data_length) { + AUBIO_WRN("%s: partial write to %s, trying to write %d frames," + " but found input of length %d\n", kind, path, write, + write_data_length); + can_write = write_data_length; + } + + return can_write; +} + +uint_t +aubio_sink_validate_input_channels(const char_t *kind, const char_t *path, + uint_t sink_channels, uint_t write_data_height) +{ + uint_t channels = sink_channels; + if (write_data_height < sink_channels) { + AUBIO_WRN("%s: partial write to %s, trying to write %d channels," + " but found input of height %d\n", kind, path, sink_channels, + write_data_height); + channels = write_data_height; + } + return channels; +}