The JUCE cross-platform C++ framework, with DISTRHO/KXStudio specific changes
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

74 lines
2.5KB

  1. /*
  2. ==============================================================================
  3. This file is part of the JUCE library.
  4. Copyright (c) 2017 - ROLI Ltd.
  5. JUCE is an open source library subject to commercial or open-source
  6. licensing.
  7. By using JUCE, you agree to the terms of both the JUCE 5 End-User License
  8. Agreement and JUCE 5 Privacy Policy (both updated and effective as of the
  9. 27th April 2017).
  10. End User License Agreement: www.juce.com/juce-5-licence
  11. Privacy Policy: www.juce.com/juce-5-privacy-policy
  12. Or: You may also use this code under the terms of the GPL v3 (see
  13. www.gnu.org/licenses).
  14. JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
  15. EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
  16. DISCLAIMED.
  17. ==============================================================================
  18. */
  19. /**
  20. A class which provides multiple windowing functions useful for filter design
  21. and spectrum analyzers
  22. */
  23. template <typename FloatType>
  24. struct WindowingFunction
  25. {
  26. enum WindowingMethod
  27. {
  28. rectangular = 0,
  29. triangular,
  30. hann,
  31. hamming,
  32. blackman,
  33. blackmanHarris,
  34. flatTop,
  35. kaiser,
  36. numWindowingMethods
  37. };
  38. //==============================================================================
  39. WindowingFunction (size_t size, WindowingMethod,
  40. bool normalize = true, FloatType beta = 0);
  41. //==============================================================================
  42. /** Fills the content of an array with a given windowing method table */
  43. void fillWindowingTables (size_t size, WindowingMethod type,
  44. bool normalize = true, FloatType beta = 0) noexcept;
  45. /** Fills the content of an array with a given windowing method table */
  46. static void fillWindowingTables (FloatType* samples, size_t size, WindowingMethod,
  47. bool normalize = true, FloatType beta = 0) noexcept;
  48. /** Multiply the content of a buffer with the given window */
  49. void multiplyWithWindowingTable (FloatType* samples, size_t size) noexcept;
  50. /** Returns the name of a given windowing method */
  51. static const char* getWindowingMethodName (WindowingMethod) noexcept;
  52. private:
  53. //==============================================================================
  54. Array<FloatType> windowTable;
  55. JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (WindowingFunction)
  56. };