99 lines
2.8 KiB
C
Raw Normal View History

2012-04-21 23:13:50 +02:00
/* RetroArch - A frontend for libretro.
2014-01-01 01:50:59 +01:00
* Copyright (C) 2010-2014 - Hans-Kristian Arntzen
2014-09-17 19:07:40 +01:00
*
2012-04-21 23:13:50 +02:00
* RetroArch is free software: you can redistribute it and/or modify it under the terms
2012-02-25 01:47:23 +01:00
* of the GNU General Public License as published by the Free Software Found-
* ation, either version 3 of the License, or (at your option) any later version.
*
2012-04-21 23:13:50 +02:00
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
2012-02-25 01:47:23 +01:00
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
* PURPOSE. See the GNU General Public License for more details.
*
2012-04-21 23:31:57 +02:00
* You should have received a copy of the GNU General Public License along with RetroArch.
2012-02-25 01:47:23 +01:00
* If not, see <http://www.gnu.org/licenses/>.
*/
// Resampler that reads raw S16NE/stereo from stdin and outputs to stdout in S16NE/stereo.
// Used for testing and performance benchmarking.
2014-09-17 19:07:40 +01:00
#include "../resamplers/resampler.h"
#include "../audio_utils.h"
2012-02-25 01:47:23 +01:00
#include <stdio.h>
#include <stdlib.h>
2013-03-12 12:23:28 +01:00
#include <time.h>
2012-02-25 01:47:23 +01:00
2014-09-17 19:07:40 +01:00
#ifndef RESAMPLER_IDENT
#define RESAMPLER_IDENT "sinc"
#endif
2012-02-25 01:47:23 +01:00
int main(int argc, char *argv[])
{
2013-03-03 12:39:11 +01:00
srand(time(NULL));
2012-02-25 01:47:23 +01:00
int16_t input_i[1024];
int16_t output_i[1024 * 8];
2012-07-06 17:04:54 +01:00
float input_f[1024];
2012-02-25 01:47:23 +01:00
float output_f[1024 * 8];
double ratio_max_deviation = 0.0;
if (argc < 3 || argc > 4)
2012-02-25 01:47:23 +01:00
{
fprintf(stderr, "Usage: %s <in-rate> <out-rate> [ratio deviation] (max ratio: 8.0)\n", argv[0]);
2012-02-25 01:47:23 +01:00
return 1;
}
else if (argc == 4)
{
ratio_max_deviation = fabs(strtod(argv[3], NULL));
fprintf(stderr, "Ratio deviation: %.4f.\n", ratio_max_deviation);
}
2012-02-25 01:47:23 +01:00
double in_rate = strtod(argv[1], NULL);
double out_rate = strtod(argv[2], NULL);
double ratio = out_rate / in_rate;
if (ratio >= 7.99)
{
fprintf(stderr, "Ratio is too high.\n");
return 1;
}
2013-02-08 15:37:40 +01:00
const rarch_resampler_t *resampler = NULL;
void *re = NULL;
2014-09-17 19:07:40 +01:00
if (!rarch_resampler_realloc(&re, &resampler, RESAMPLER_IDENT, out_rate / in_rate))
2012-02-25 01:47:23 +01:00
{
fprintf(stderr, "Failed to allocate resampler ...\n");
return 1;
}
for (;;)
{
if (fread(input_i, sizeof(int16_t), 1024, stdin) != 1024)
break;
double uniform = (2.0 * rand()) / RAND_MAX - 1.0;
double rate_mod = 1.0 + ratio_max_deviation * uniform;
2012-11-07 23:42:23 +01:00
audio_convert_s16_to_float(input_f, input_i, 1024, 1.0f);
2012-02-25 01:47:23 +01:00
struct resampler_data data = {
.data_in = input_f,
.data_out = output_f,
.input_frames = sizeof(input_f) / (2 * sizeof(float)),
.ratio = ratio * rate_mod,
2012-02-25 01:47:23 +01:00
};
2013-02-08 15:37:40 +01:00
rarch_resampler_process(resampler, re, &data);
2012-02-25 01:47:23 +01:00
size_t output_samples = data.output_frames * 2;
2012-07-06 17:04:54 +01:00
2012-02-25 01:47:23 +01:00
audio_convert_float_to_s16(output_i, output_f, output_samples);
if (fwrite(output_i, sizeof(int16_t), output_samples, stdout) != output_samples)
break;
}
2013-02-08 15:37:40 +01:00
rarch_resampler_freep(&resampler, &re);
2012-02-25 01:47:23 +01:00
}