midi.cpp 1.2 KB

1234567891011121314151617181920212223242526272829303132333435
  1. /*
  2. Sekai - addons for the WORLD speech toolkit
  3. Copyright (C) 2016 Tobias Platen
  4. This program is free software: you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation, either version 3 of the License, or
  7. (at your option) any later version.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with this program. If not, see <http://www.gnu.org/licenses/>.
  14. */
  15. #include <math.h>
  16. const static double A4Frequency = 440.0;
  17. const static double A4Note = 69.0;
  18. // based on
  19. // https://github.com/haruneko/SimpleSynthesizer/blob/master/core/org/stand/util/MusicalNote.{h,cpp}
  20. double frequencyFromNote(float note) {
  21. if (note == 0) return 0;
  22. return pow(2.0, (note - A4Note) / 12.0) * A4Frequency;
  23. }
  24. float noteFromFrequency(double frequency) {
  25. if (frequency == 0) return 0;
  26. return A4Note + 12.0 * log2(frequency / A4Frequency);
  27. }