aboutsummaryrefslogtreecommitdiff
path: root/src/xtract_window_private.h
diff options
context:
space:
mode:
authorJamie Bullock <jamie@postlude.co.uk>2007-12-28 19:34:51 +0000
committerJamie Bullock <jamie@postlude.co.uk>2007-12-28 19:34:51 +0000
commit2e66bd6092fe93ca7fa953c4af9d0e16bbf69905 (patch)
tree0879cd510f23690e40ed4c01262bf301bfc38d15 /src/xtract_window_private.h
parent0c2e564c15c583a5274271a0bbacb237b180d500 (diff)
downloadLibXtract-2e66bd6092fe93ca7fa953c4af9d0e16bbf69905.tar.gz
LibXtract-2e66bd6092fe93ca7fa953c4af9d0e16bbf69905.tar.bz2
LibXtract-2e66bd6092fe93ca7fa953c4af9d0e16bbf69905.zip
- Added new helper functions: xtract_windowed() and xtract_features_from_subframes()
- Added windowing functions (window.c)
Diffstat (limited to 'src/xtract_window_private.h')
-rw-r--r--src/xtract_window_private.h98
1 files changed, 98 insertions, 0 deletions
diff --git a/src/xtract_window_private.h b/src/xtract_window_private.h
new file mode 100644
index 0000000..661b92f
--- /dev/null
+++ b/src/xtract_window_private.h
@@ -0,0 +1,98 @@
+/* libxtract feature extraction library
+ *
+ * Copyright (C) 2006 Jamie Bullock
+ *
+ * This program 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 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program 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 this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+ * USA.
+ */
+
+/* xtract_window_private.h: declares window generation functions */
+
+#define PI 3.1415926535897931
+
+/** \brief generate a Gaussian window
+ *
+ * \param *window a pointer to an array to contain the window data
+ * \param N the number of elements in the array pointed to by *window
+ * \param sd the standard deviation of the "distribution" represented by the Gaussian curve. The higher the value of sd, the wider the curve. Generally sd <= 0.5
+ *
+ */
+void gauss(float *window, const int N, const float sd);
+
+/** \brief generate a Hamming window
+ *
+ * \param *window a pointer to an array to contain the window data
+ * \param N the number of elements in the array pointed to by *window
+ *
+ */
+void hamming(float *window, const int N);
+
+/** \brief generate a Hann window
+ *
+ * \param *window a pointer to an array to contain the window data
+ * \param N the number of elements in the array pointed to by *window
+ *
+ */
+void hann(float *window, const int N);
+
+/** \brief generate a Bartlett window
+ *
+ * \param *window a pointer to an array to contain the window data
+ * \param N the number of elements in the array pointed to by *window
+ *
+ */
+void bartlett(float *window, const int N);
+
+/** \brief generate a Triangular window
+ *
+ * \param *window a pointer to an array to contain the window data
+ * \param N the number of elements in the array pointed to by *window
+ *
+ */
+void triangular(float *window, const int N);
+
+/** \brief generate a Bartlett-Hann window
+ *
+ * \param *window a pointer to an array to contain the window data
+ * \param N the number of elements in the array pointed to by *window
+ *
+ */
+void bartlett_hann(float *window, const int N);
+
+/** \brief generate a Blackman window
+ *
+ * \param *window a pointer to an array to contain the window data
+ * \param N the number of elements in the array pointed to by *window
+ *
+ */
+void blackman(float *window, const int N);
+
+/** \brief generate a Kaiser window
+ *
+ * \param *window a pointer to an array to contain the window data
+ * \param N the number of elements in the array pointed to by *window
+ * \param alpha The larger the value of |alpha|, the narrower the window becomes
+ *
+ */
+void kaiser(float *window, const int N, const float alpha);
+
+/** \brief generate a Blackman-Harris window
+ *
+ * \param *window a pointer to an array to contain the window data
+ * \param N the number of elements in the array pointed to by *window
+ *
+ */
+void blackman_harris(float *window, const int N);
+