DISTRHO Kars
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.

159 lines
4.5KB

  1. /*
  2. * DISTRHO Kars Plugin, based on karplong by Chris Cannam.
  3. * Copyright (C) 2015-2022 Filipe Coelho <falktx@falktx.com>
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for any purpose with
  6. * or without fee is hereby granted, provided that the above copyright notice and this
  7. * permission notice appear in all copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD
  10. * TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN
  11. * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  12. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER
  13. * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
  14. * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. #ifndef DISTRHO_PLUGIN_KARS_HPP_INCLUDED
  17. #define DISTRHO_PLUGIN_KARS_HPP_INCLUDED
  18. #include "DistrhoPlugin.hpp"
  19. START_NAMESPACE_DISTRHO
  20. // -----------------------------------------------------------------------
  21. class DistrhoPluginKars : public Plugin
  22. {
  23. public:
  24. static const int kMaxNotes = 128;
  25. static const uint32_t kNoteNull = (uint32_t)-1;
  26. enum Parameters
  27. {
  28. paramSustain = 0,
  29. paramRelease,
  30. paramVolume,
  31. paramCount
  32. };
  33. DistrhoPluginKars();
  34. protected:
  35. // -------------------------------------------------------------------
  36. // Information
  37. const char* getLabel() const noexcept override
  38. {
  39. return "Kars";
  40. }
  41. const char* getDescription() const override
  42. {
  43. return "Simple karplus-strong plucked string synth.";
  44. }
  45. const char* getMaker() const noexcept override
  46. {
  47. return "falkTX";
  48. }
  49. const char* getHomePage() const override
  50. {
  51. return "https://github.com/DISTRHO/Kars";
  52. }
  53. const char* getLicense() const noexcept override
  54. {
  55. return "ISC";
  56. }
  57. uint32_t getVersion() const noexcept override
  58. {
  59. return d_version(1, 1, 0);
  60. }
  61. int64_t getUniqueId() const noexcept override
  62. {
  63. return d_cconst('D', 'K', 'r', 's');
  64. }
  65. // -------------------------------------------------------------------
  66. // Init
  67. void initAudioPort(bool input, uint32_t index, AudioPort& port) override;
  68. void initParameter(uint32_t index, Parameter& parameter) override;
  69. // -------------------------------------------------------------------
  70. // Internal data
  71. float getParameterValue(uint32_t index) const override;
  72. void setParameterValue(uint32_t index, float value) override;
  73. // -------------------------------------------------------------------
  74. // Process
  75. void activate() override;
  76. void run(const float**, float** outputs, uint32_t frames, const MidiEvent* midiEvents, uint32_t midiEventCount) override;
  77. void sampleRateChanged(double newSampleRate) override;
  78. // -------------------------------------------------------------------
  79. private:
  80. bool fSustain;
  81. float fRelease;
  82. float fVolume;
  83. double fSampleRate;
  84. uint32_t fBlockStart;
  85. struct Note {
  86. uint32_t on;
  87. uint32_t off;
  88. uint8_t velocity;
  89. float voice;
  90. float size;
  91. int sizei;
  92. float* wavetable;
  93. Note() noexcept
  94. : on(kNoteNull),
  95. off(kNoteNull),
  96. velocity(0),
  97. voice(0.0f),
  98. size(0.0f),
  99. wavetable(nullptr) {}
  100. ~Note() noexcept
  101. {
  102. if (wavetable != nullptr)
  103. {
  104. delete[] wavetable;
  105. wavetable = nullptr;
  106. }
  107. }
  108. void setSampleRate(const double sampleRate)
  109. {
  110. if (wavetable != nullptr)
  111. delete[] wavetable;
  112. const float frequency = 440.0f * std::pow(2.0f, (voice - 69.0f) / 12.0f);
  113. size = sampleRate / frequency;
  114. sizei = int(size)+1;
  115. wavetable = new float[sizei];
  116. std::memset(wavetable, 0, sizeof(float)*static_cast<size_t>(sizei));
  117. }
  118. } fNotes[kMaxNotes];
  119. void addSamples(float* out, int voice, uint32_t frames);
  120. DISTRHO_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(DistrhoPluginKars)
  121. };
  122. // -----------------------------------------------------------------------
  123. END_NAMESPACE_DISTRHO
  124. #endif // DISTRHO_PLUGIN_KARS_HPP_INCLUDED