2012-04-21 23:13:50 +02:00
|
|
|
/* RetroArch - A frontend for libretro.
|
2013-01-01 01:37:37 +01:00
|
|
|
* Copyright (C) 2010-2013 - Hans-Kristian Arntzen
|
2011-02-06 12:57:12 +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
|
2011-02-06 12:57:12 +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;
|
2011-02-06 12:57:12 +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.
|
2011-02-06 12:57:12 +01:00
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2012-04-21 23:25:32 +02:00
|
|
|
#ifndef __RARCH_RESAMPLER_H
|
|
|
|
#define __RARCH_RESAMPLER_H
|
2011-02-06 12:57:12 +01:00
|
|
|
|
2012-07-06 17:36:37 +02:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
#include "../config.h"
|
|
|
|
#endif
|
|
|
|
|
2011-02-06 12:57:12 +01:00
|
|
|
#include <stddef.h>
|
2012-07-06 17:36:37 +02:00
|
|
|
#include <stdint.h>
|
2012-02-25 14:02:56 +01:00
|
|
|
#include <math.h>
|
2013-02-08 11:49:51 +01:00
|
|
|
#include "../boolean.h"
|
2012-02-25 14:02:56 +01:00
|
|
|
|
|
|
|
// M_PI is left out of ISO C99 :(
|
|
|
|
#ifndef M_PI
|
|
|
|
#define M_PI 3.14159265358979323846264338327
|
|
|
|
#endif
|
2011-02-06 12:57:12 +01:00
|
|
|
|
2012-07-06 17:36:37 +02:00
|
|
|
typedef float sample_t;
|
|
|
|
|
2012-02-23 23:19:23 +01:00
|
|
|
struct resampler_data
|
2011-02-06 12:57:12 +01:00
|
|
|
{
|
2012-07-06 17:36:37 +02:00
|
|
|
const sample_t *data_in;
|
|
|
|
sample_t *data_out;
|
2011-02-06 12:57:12 +01:00
|
|
|
|
2011-02-06 18:38:04 +01:00
|
|
|
size_t input_frames;
|
|
|
|
size_t output_frames;
|
|
|
|
|
2011-10-15 14:33:41 +02:00
|
|
|
double ratio;
|
2011-02-06 12:57:12 +01:00
|
|
|
};
|
|
|
|
|
2013-02-08 11:49:51 +01:00
|
|
|
typedef struct rarch_resampler
|
|
|
|
{
|
2013-02-13 12:15:09 +01:00
|
|
|
void *(*init)(double bandwidth_mod); // Bandwidth factor. Will be < 1.0 for downsampling, > 1.0 for upsamling. Corresponds to expected resampling ratio.
|
2013-02-08 11:49:51 +01:00
|
|
|
void (*process)(void *re, struct resampler_data *data);
|
|
|
|
void (*free)(void *re);
|
|
|
|
const char *ident;
|
|
|
|
} rarch_resampler_t;
|
|
|
|
|
|
|
|
extern const rarch_resampler_t hermite_resampler;
|
|
|
|
extern const rarch_resampler_t sinc_resampler;
|
|
|
|
|
|
|
|
// Reallocs resampler. Will free previous handle before allocating a new one.
|
|
|
|
// If ident is NULL, first resampler will be used.
|
2013-02-13 12:15:09 +01:00
|
|
|
bool rarch_resampler_realloc(void **re, const rarch_resampler_t **backend, const char *ident, double bw_ratio);
|
2013-02-08 11:49:51 +01:00
|
|
|
|
|
|
|
// Convenience macros.
|
|
|
|
// freep makes sure to set handles to NULL to avoid double-free in rarch_resampler_realloc.
|
|
|
|
#define rarch_resampler_freep(backend, handle) do { \
|
|
|
|
if (*(backend) && *(handle)) \
|
|
|
|
(*backend)->free(*handle); \
|
|
|
|
*backend = NULL; \
|
|
|
|
*handle = NULL; \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
#define rarch_resampler_process(backend, handle, data) do { \
|
|
|
|
(backend)->process(handle, data); \
|
|
|
|
} while(0)
|
2011-02-06 12:57:12 +01:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|