aubio 0.4.9
cvec.h
Go to the documentation of this file.
1/*
2 Copyright (C) 2003-2015 Paul Brossier <piem@aubio.org>
3
4 This file is part of aubio.
5
6 aubio is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 3 of the License, or
9 (at your option) any later version.
10
11 aubio is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with aubio. If not, see <http://www.gnu.org/licenses/>.
18
19*/
20
21#ifndef AUBIO_CVEC_H
22#define AUBIO_CVEC_H
23
24#ifdef __cplusplus
25extern "C" {
26#endif
27
28/** \file
29
30 Vector of complex-valued data, stored in polar coordinates
31
32 This file specifies the ::cvec_t buffer type, which is used throughout aubio
33 to store complex data. Complex values are stored in terms of ::cvec_t.phas
34 and norm, within 2 vectors of ::smpl_t of size (size/2+1) each.
35
36 \example test-cvec.c
37
38*/
39
40/** Vector of real-valued phase and spectrum data
41
42 \code
43
44 uint_t buffer_size = 1024;
45
46 // create a complex vector of 512 values
47 cvec_t * input = new_cvec (buffer_size);
48
49 // set some values of the vector
50 input->norm[23] = 2.;
51 input->phas[23] = M_PI;
52 // ..
53
54 // compute the mean of the vector
55 mean = cvec_mean(input);
56
57 // destroy the vector
58 del_cvec (input);
59
60 \endcode
61
62 */
63typedef struct {
64 uint_t length; /**< length of buffer = (requested length)/2 + 1 */
65 smpl_t *norm; /**< norm array of size ::cvec_t.length */
66 smpl_t *phas; /**< phase array of size ::cvec_t.length */
67} cvec_t;
68
69/** cvec_t buffer creation function
70
71 This function creates a cvec_t structure holding two arrays of size
72 [length/2+1], corresponding to the norm and phase values of the
73 spectral frame. The length stored in the structure is the actual size of both
74 arrays, not the length of the complex and symmetrical vector, specified as
75 creation argument.
76
77 \param length the length of the buffer to create
78
79*/
81
82/** cvec_t buffer deletion function
83
84 \param s buffer to delete as returned by new_cvec()
85
86*/
88
89/** write norm value in a complex buffer
90
91 This is equivalent to:
92 \code
93 s->norm[position] = val;
94 \endcode
95
96 \param s vector to write to
97 \param val norm value to write in s->norm[position]
98 \param position sample position to write to
99
100*/
101void cvec_norm_set_sample (cvec_t *s, smpl_t val, uint_t position);
102
103/** write phase value in a complex buffer
104
105 This is equivalent to:
106 \code
107 s->phas[position] = val;
108 \endcode
109
110 \param s vector to write to
111 \param val phase value to write in s->phas[position]
112 \param position sample position to write to
113
114*/
115void cvec_phas_set_sample (cvec_t *s, smpl_t val, uint_t position);
116
117/** read norm value from a complex buffer
118
119 This is equivalent to:
120 \code
121 smpl_t foo = s->norm[position];
122 \endcode
123
124 \param s vector to read from
125 \param position sample position to read from
126
127*/
129
130/** read phase value from a complex buffer
131
132 This is equivalent to:
133 \code
134 smpl_t foo = s->phas[position];
135 \endcode
136
137 \param s vector to read from
138 \param position sample position to read from
139 \returns the value of the sample at position
140
141*/
143
144/** read norm data from a complex buffer
145
146 \code
147 smpl_t *data = s->norm;
148 \endcode
149
150 \param s vector to read from
151
152*/
154
155/** read phase data from a complex buffer
156
157 This is equivalent to:
158 \code
159 smpl_t *data = s->phas;
160 \endcode
161
162 \param s vector to read from
163
164*/
166
167/** print out cvec data
168
169 \param s vector to print out
170
171*/
172void cvec_print(const cvec_t *s);
173
174/** make a copy of a vector
175
176 \param s source vector
177 \param t vector to copy to
178
179*/
180void cvec_copy(const cvec_t *s, cvec_t *t);
181
182/** set all norm elements to a given value
183
184 \param s vector to modify
185 \param val value to set elements to
186
187*/
189
190/** set all norm elements to zero
191
192 \param s vector to modify
193
194*/
196
197/** set all norm elements to one
198
199 \param s vector to modify
200
201*/
203
204/** set all phase elements to a given value
205
206 \param s vector to modify
207 \param val value to set elements to
208
209*/
211
212/** set all phase elements to zero
213
214 \param s vector to modify
215
216*/
218
219/** set all phase elements to one
220
221 \param s vector to modify
222
223*/
225
226/** set all norm and phas elements to zero
227
228 \param s vector to modify
229
230*/
232
233/** take logarithmic magnitude
234
235 \param s input cvec to compress
236 \param lambda value to use for normalisation
237
238 \f$ S_k = log( \lambda * S_k + 1 ) \f$
239
240*/
241void cvec_logmag(cvec_t *s, smpl_t lambda);
242
243#ifdef __cplusplus
244}
245#endif
246
247#endif /* AUBIO_CVEC_H */
void cvec_phas_zeros(cvec_t *s)
set all phase elements to zero
void cvec_logmag(cvec_t *s, smpl_t lambda)
take logarithmic magnitude
smpl_t * cvec_norm_get_data(const cvec_t *s)
read norm data from a complex buffer
cvec_t * new_cvec(uint_t length)
cvec_t buffer creation function
void cvec_copy(const cvec_t *s, cvec_t *t)
make a copy of a vector
smpl_t * cvec_phas_get_data(const cvec_t *s)
read phase data from a complex buffer
void del_cvec(cvec_t *s)
cvec_t buffer deletion function
void cvec_phas_set_all(cvec_t *s, smpl_t val)
set all phase elements to a given value
void cvec_norm_zeros(cvec_t *s)
set all norm elements to zero
void cvec_norm_ones(cvec_t *s)
set all norm elements to one
void cvec_zeros(cvec_t *s)
set all norm and phas elements to zero
void cvec_phas_ones(cvec_t *s)
set all phase elements to one
smpl_t cvec_norm_get_sample(cvec_t *s, uint_t position)
read norm value from a complex buffer
void cvec_norm_set_all(cvec_t *s, smpl_t val)
set all norm elements to a given value
void cvec_phas_set_sample(cvec_t *s, smpl_t val, uint_t position)
write phase value in a complex buffer
void cvec_norm_set_sample(cvec_t *s, smpl_t val, uint_t position)
write norm value in a complex buffer
smpl_t cvec_phas_get_sample(cvec_t *s, uint_t position)
read phase value from a complex buffer
void cvec_print(const cvec_t *s)
print out cvec data
Vector of real-valued phase and spectrum data.
Definition: cvec.h:63
smpl_t * norm
norm array of size cvec_t.length
Definition: cvec.h:65
smpl_t * phas
phase array of size cvec_t.length
Definition: cvec.h:66
uint_t length
length of buffer = (requested length)/2 + 1
Definition: cvec.h:64
unsigned int uint_t
unsigned integer
Definition: types.h:60
float smpl_t
short sample format (32 or 64 bits)
Definition: types.h:41