Blame mave.c

Packit Service d8d8ac
/**
Packit Service d8d8ac
 * @file mave.c
Packit Service d8d8ac
 * @note Copyright (C) 2011 Richard Cochran <richardcochran@gmail.com>
Packit Service d8d8ac
 *
Packit Service d8d8ac
 * This program is free software; you can redistribute it and/or modify
Packit Service d8d8ac
 * it under the terms of the GNU General Public License as published by
Packit Service d8d8ac
 * the Free Software Foundation; either version 2 of the License, or
Packit Service d8d8ac
 * (at your option) any later version.
Packit Service d8d8ac
 *
Packit Service d8d8ac
 * This program is distributed in the hope that it will be useful,
Packit Service d8d8ac
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service d8d8ac
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service d8d8ac
 * GNU General Public License for more details.
Packit Service d8d8ac
 *
Packit Service d8d8ac
 * You should have received a copy of the GNU General Public License along
Packit Service d8d8ac
 * with this program; if not, write to the Free Software Foundation, Inc.,
Packit Service d8d8ac
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
Packit Service d8d8ac
 */
Packit Service d8d8ac
#include <stdlib.h>
Packit Service d8d8ac
#include <string.h>
Packit Service d8d8ac
Packit Service d8d8ac
#include "mave.h"
Packit Service d8d8ac
#include "filter_private.h"
Packit Service d8d8ac
Packit Service d8d8ac
struct mave {
Packit Service d8d8ac
	struct filter filter;
Packit Service d8d8ac
	int cnt;
Packit Service d8d8ac
	int len;
Packit Service d8d8ac
	int index;
Packit Service d8d8ac
	tmv_t sum;
Packit Service d8d8ac
	tmv_t *val;
Packit Service d8d8ac
};
Packit Service d8d8ac
Packit Service d8d8ac
static void mave_destroy(struct filter *filter)
Packit Service d8d8ac
{
Packit Service d8d8ac
	struct mave *m = container_of(filter, struct mave, filter);
Packit Service d8d8ac
	free(m->val);
Packit Service d8d8ac
	free(m);
Packit Service d8d8ac
}
Packit Service d8d8ac
Packit Service d8d8ac
static tmv_t mave_accumulate(struct filter *filter, tmv_t val)
Packit Service d8d8ac
{
Packit Service d8d8ac
	struct mave *m = container_of(filter, struct mave, filter);
Packit Service d8d8ac
Packit Service d8d8ac
	m->sum = tmv_sub(m->sum, m->val[m->index]);
Packit Service d8d8ac
	m->val[m->index] = val;
Packit Service d8d8ac
	m->index = (1 + m->index) % m->len;
Packit Service d8d8ac
	m->sum = tmv_add(m->sum, val);
Packit Service d8d8ac
	if (m->cnt < m->len) {
Packit Service d8d8ac
		m->cnt++;
Packit Service d8d8ac
	}
Packit Service d8d8ac
	return tmv_div(m->sum, m->cnt);
Packit Service d8d8ac
}
Packit Service d8d8ac
Packit Service d8d8ac
static void mave_reset(struct filter *filter)
Packit Service d8d8ac
{
Packit Service d8d8ac
	struct mave *m = container_of(filter, struct mave, filter);
Packit Service d8d8ac
Packit Service d8d8ac
	m->cnt = 0;
Packit Service d8d8ac
	m->index = 0;
Packit Service d8d8ac
	m->sum = tmv_zero();
Packit Service d8d8ac
	memset(m->val, 0, m->len * sizeof(*m->val));
Packit Service d8d8ac
}
Packit Service d8d8ac
Packit Service d8d8ac
struct filter *mave_create(int length)
Packit Service d8d8ac
{
Packit Service d8d8ac
	struct mave *m;
Packit Service d8d8ac
	m = calloc(1, sizeof(*m));
Packit Service d8d8ac
	if (!m) {
Packit Service d8d8ac
		return NULL;
Packit Service d8d8ac
	}
Packit Service d8d8ac
	m->filter.destroy = mave_destroy;
Packit Service d8d8ac
	m->filter.sample = mave_accumulate;
Packit Service d8d8ac
	m->filter.reset = mave_reset;
Packit Service d8d8ac
	m->val = calloc(1, length * sizeof(*m->val));
Packit Service d8d8ac
	if (!m->val) {
Packit Service d8d8ac
		free(m);
Packit Service d8d8ac
		return NULL;
Packit Service d8d8ac
	}
Packit Service d8d8ac
	m->len = length;
Packit Service d8d8ac
	return &m->filter;
Packit Service d8d8ac
}