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.

80 lines
2.3KB

  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. namespace juce
  20. {
  21. AudioProcessLoadMeasurer::AudioProcessLoadMeasurer() {}
  22. AudioProcessLoadMeasurer::~AudioProcessLoadMeasurer() {}
  23. void AudioProcessLoadMeasurer::reset()
  24. {
  25. reset (0, 0);
  26. }
  27. void AudioProcessLoadMeasurer::reset (double sampleRate, int blockSize)
  28. {
  29. cpuUsageMs = 0;
  30. xruns = 0;
  31. if (sampleRate > 0.0 && blockSize > 0)
  32. {
  33. msPerBlock = 1000.0 * blockSize / sampleRate;
  34. timeToCpuScale = (msPerBlock > 0.0) ? (1.0 / msPerBlock) : 0.0;
  35. }
  36. else
  37. {
  38. msPerBlock = 0;
  39. timeToCpuScale = 0;
  40. }
  41. }
  42. void AudioProcessLoadMeasurer::registerBlockRenderTime (double milliseconds)
  43. {
  44. const double filterAmount = 0.2;
  45. cpuUsageMs += filterAmount * (milliseconds - cpuUsageMs);
  46. if (milliseconds > msPerBlock)
  47. ++xruns;
  48. }
  49. double AudioProcessLoadMeasurer::getLoadAsProportion() const { return jlimit (0.0, 1.0, timeToCpuScale * cpuUsageMs); }
  50. double AudioProcessLoadMeasurer::getLoadAsPercentage() const { return 100.0 * getLoadAsProportion(); }
  51. int AudioProcessLoadMeasurer::getXRunCount() const { return xruns; }
  52. AudioProcessLoadMeasurer::ScopedTimer::ScopedTimer (AudioProcessLoadMeasurer& p)
  53. : owner (p), startTime (Time::getMillisecondCounterHiRes())
  54. {
  55. }
  56. AudioProcessLoadMeasurer::ScopedTimer::~ScopedTimer()
  57. {
  58. owner.registerBlockRenderTime (Time::getMillisecondCounterHiRes() - startTime);
  59. }
  60. } // namespace juce