jamie@254
|
1 /*
|
jamie@254
|
2 * Copyright (C) 2012 Jamie Bullock
|
jamie@254
|
3 *
|
jamie@254
|
4 * Permission is hereby granted, free of charge, to any person obtaining a copy
|
jamie@254
|
5 * of this software and associated documentation files (the "Software"), to
|
jamie@254
|
6 * deal in the Software without restriction, including without limitation the
|
jamie@254
|
7 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
jamie@254
|
8 * sell copies of the Software, and to permit persons to whom the Software is
|
jamie@254
|
9 * furnished to do so, subject to the following conditions:
|
jamie@254
|
10 *
|
jamie@254
|
11 * The above copyright notice and this permission notice shall be included in
|
jamie@254
|
12 * all copies or substantial portions of the Software.
|
jamie@254
|
13 *
|
jamie@254
|
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
jamie@254
|
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
jamie@254
|
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
jamie@254
|
17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
jamie@254
|
18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
jamie@254
|
19 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
jamie@254
|
20 * IN THE SOFTWARE.
|
jamie@254
|
21 *
|
jamie@254
|
22 */
|
jamie@254
|
23
|
jamie@254
|
24 /** \file xtract_stateful.h: declares functions that extract features that require stateful data to be retained between frames */
|
jamie@254
|
25 #ifndef XTRACT_STATEFUL_H
|
jamie@254
|
26 #define XTRACT_STATEFUL_H
|
jamie@254
|
27
|
jamie@254
|
28 #ifdef __cplusplus
|
jamie@254
|
29 extern "C" {
|
jamie@254
|
30 #endif
|
jamie@254
|
31
|
jamie@254
|
32 /**
|
jamie@254
|
33 * \defgroup stateful feature extraction functions and data structures
|
jamie@254
|
34 *
|
jamie@254
|
35 * Functions that extract a feature over multiple frames
|
jamie@254
|
36 *
|
jamie@254
|
37 * @{
|
jamie@254
|
38 */
|
jamie@254
|
39
|
jamie@254
|
40
|
jamie@254
|
41 #include <stdint.h>
|
jamie@254
|
42 #include <string.h>
|
jamie@254
|
43
|
jamie@254
|
44 typedef struct xtract_last_n_state_ xtract_last_n_state;
|
jamie@254
|
45
|
jamie@254
|
46 xtract_last_n_state *xtract_last_n_state_new(size_t capacity);
|
jamie@254
|
47 void xtract_last_n_state_delete(xtract_last_n_state *last_n_state);
|
jamie@254
|
48
|
jamie@254
|
49
|
jamie@254
|
50 /**
|
jamie@254
|
51 * Write a vector of the last N input values to `result`
|
jamie@254
|
52 *
|
jamie@254
|
53 * @param state a pointer to an xtract_peak_picker_state struct as allocated by xtract_peak_picker_state_new()
|
jamie@254
|
54 * @param data a pointer to a double representing the current input value
|
jamie@254
|
55 * @param N an integer representing 'N' the number of values to be written to *result
|
jamie@254
|
56 * @param argv a pointer to NULL
|
jamie@254
|
57 * @param result a pointer to an array of doubles representing the last N values, where the nth value is the current one. The array must have been allocated to size N elements and initialised by the caller
|
jamie@254
|
58 *
|
jamie@254
|
59 */
|
jamie@254
|
60 int xtract_last_n(const xtract_last_n_state *state, const double *data, const int N, const void *argv, double *result);
|
jamie@254
|
61
|
jamie@254
|
62 #ifdef __cplusplus
|
jamie@254
|
63 }
|
jamie@254
|
64 #endif
|
jamie@254
|
65
|
jamie@254
|
66 #endif
|