/usr/include/aubio/tempo/beattracking.h is in libaubio-dev 0.4.5-1build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 | /*
Copyright (C) 2003-2015 Matthew Davies and Paul Brossier <piem@aubio.org>
This file is part of aubio.
aubio is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
aubio is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with aubio. If not, see <http://www.gnu.org/licenses/>.
*/
/** \file
Beat tracking using a context dependant model
This file implements the causal beat tracking algorithm designed by Matthew
Davies and described in the following articles:
Matthew E. P. Davies and Mark D. Plumbley. Causal tempo tracking of audio.
In Proceedings of the International Symposium on Music Information Retrieval
(ISMIR), pages 164169, Barcelona, Spain, 2004.
Matthew E. P. Davies, Paul Brossier, and Mark D. Plumbley. Beat tracking
towards automatic musical accompaniment. In Proceedings of the Audio
Engeeniring Society 118th Convention, Barcelona, Spain, May 2005.
\example tempo/test-beattracking.c
*/
#ifndef AUBIO_BEATTRACKING_H
#define AUBIO_BEATTRACKING_H
#ifdef __cplusplus
extern "C" {
#endif
/** beat tracking object */
typedef struct _aubio_beattracking_t aubio_beattracking_t;
/** create beat tracking object
\param winlen length of the onset detection window
\param hop_size number of onset detection samples [512]
\param samplerate samplerate of the input signal
*/
aubio_beattracking_t * new_aubio_beattracking(uint_t winlen, uint_t hop_size,
uint_t samplerate);
/** track the beat
\param bt beat tracking object
\param dfframes current input detection function frame, smoothed by
adaptive median threshold.
\param out stored detected beat locations
*/
void aubio_beattracking_do (aubio_beattracking_t * bt, const fvec_t * dfframes,
fvec_t * out);
/** get current beat period in samples
\param bt beat tracking object
Returns the currently observed period, in samples, or 0 if no consistent
value is found.
*/
smpl_t aubio_beattracking_get_period (const aubio_beattracking_t * bt);
/** get current beat period in seconds
\param bt beat tracking object
Returns the currently observed period, in seconds, or 0 if no consistent
value is found.
*/
smpl_t aubio_beattracking_get_period_s (const aubio_beattracking_t * bt);
/** get current tempo in bpm
\param bt beat tracking object
Returns the currently observed tempo, in beats per minutes, or 0 if no
consistent value is found.
*/
smpl_t aubio_beattracking_get_bpm(const aubio_beattracking_t * bt);
/** get current tempo confidence
\param bt beat tracking object
Returns the confidence with which the tempo has been observed, 0 if no
consistent value is found.
*/
smpl_t aubio_beattracking_get_confidence(const aubio_beattracking_t * bt);
/** delete beat tracking object
\param p beat tracking object
*/
void del_aubio_beattracking(aubio_beattracking_t * p);
#ifdef __cplusplus
}
#endif
#endif /* AUBIO_BEATTRACKING_H */
|