Key.cpp 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. /* ----------------------------------------------------------------- */
  2. /* The HMM-Based Singing Voice Synthesis System "Sinsy" */
  3. /* developed by Sinsy Working Group */
  4. /* http://sinsy.sourceforge.net/ */
  5. /* ----------------------------------------------------------------- */
  6. /* */
  7. /* Copyright (c) 2009-2015 Nagoya Institute of Technology */
  8. /* Department of Computer Science */
  9. /* */
  10. /* All rights reserved. */
  11. /* */
  12. /* Redistribution and use in source and binary forms, with or */
  13. /* without modification, are permitted provided that the following */
  14. /* conditions are met: */
  15. /* */
  16. /* - Redistributions of source code must retain the above copyright */
  17. /* notice, this list of conditions and the following disclaimer. */
  18. /* - Redistributions in binary form must reproduce the above */
  19. /* copyright notice, this list of conditions and the following */
  20. /* disclaimer in the documentation and/or other materials provided */
  21. /* with the distribution. */
  22. /* - Neither the name of the Sinsy working group nor the names of */
  23. /* its contributors may be used to endorse or promote products */
  24. /* derived from this software without specific prior written */
  25. /* permission. */
  26. /* */
  27. /* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND */
  28. /* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, */
  29. /* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF */
  30. /* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE */
  31. /* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS */
  32. /* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, */
  33. /* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED */
  34. /* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, */
  35. /* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON */
  36. /* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, */
  37. /* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY */
  38. /* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE */
  39. /* POSSIBILITY OF SUCH DAMAGE. */
  40. /* ----------------------------------------------------------------- */
  41. #include <algorithm>
  42. #include <stdexcept>
  43. #include "Key.h"
  44. #include "util_log.h"
  45. #include "util_string.h"
  46. namespace sinsy
  47. {
  48. namespace
  49. {
  50. /*!
  51. adjust fifths
  52. */
  53. size_t adjustFifths(int f)
  54. {
  55. while (f < 0) {
  56. f += 12;
  57. }
  58. while (12 <= f) {
  59. f -= 12;
  60. }
  61. return static_cast<size_t>(f);
  62. }
  63. }; // namespace
  64. /*!
  65. constructor
  66. */
  67. Key::Key() : fifths(0), origFifths(0)
  68. {
  69. }
  70. /*!
  71. constructor
  72. @param m mode
  73. @param f fifths
  74. */
  75. Key::Key(const Mode& m, int f) : mode(m), fifths(adjustFifths(f)), origFifths(f)
  76. {
  77. }
  78. /*!
  79. copy constructor
  80. */
  81. Key::Key(const Key& obj) : mode(obj.mode), fifths(obj.fifths), origFifths(obj.origFifths)
  82. {
  83. }
  84. /*!
  85. destructor
  86. */
  87. Key::~Key()
  88. {
  89. }
  90. /*!
  91. assignment operator
  92. */
  93. Key& Key::operator=(const Key & obj)
  94. {
  95. if (this != &obj) {
  96. this->mode = obj.mode;
  97. this->fifths = obj.fifths;
  98. this->origFifths = obj.origFifths;
  99. }
  100. return *this;
  101. }
  102. /*!
  103. equal operator
  104. */
  105. bool Key::operator==(const Key& obj) const
  106. {
  107. return (obj.mode == this->mode) && (obj.fifths == this->fifths) && (obj.origFifths == this->origFifths);
  108. }
  109. /*!
  110. not equal operator
  111. */
  112. bool Key::operator!=(const Key& obj) const
  113. {
  114. return !(obj == *this);
  115. }
  116. /*!
  117. get mode
  118. @return mode
  119. */
  120. const Mode& Key::getMode() const
  121. {
  122. return this->mode;
  123. }
  124. /*!
  125. get fifths
  126. @return fifths
  127. */
  128. size_t Key::getFifths() const
  129. {
  130. return this->fifths;
  131. }
  132. /*!
  133. get original fifths
  134. */
  135. int Key::getOrigFifths() const
  136. {
  137. return this->origFifths;
  138. }
  139. /*!
  140. set mode
  141. @param m mode
  142. */
  143. void Key::setMode(const Mode& m)
  144. {
  145. this->mode = m;
  146. }
  147. /*!
  148. set fifths
  149. */
  150. void Key::setFifths(int f)
  151. {
  152. this->origFifths = f;
  153. this->fifths = adjustFifths(f);
  154. }
  155. /*!
  156. to string
  157. */
  158. std::ostream& operator<<(std::ostream& os, const Key& key)
  159. {
  160. return os << "mode:" << key.getMode() << ", fifths:" << key.getFifths();
  161. }
  162. }; // namespace sinsy