PhonemeLabeler.cpp 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  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 "PhonemeLabeler.h"
  42. #include "util_log.h"
  43. #include <stdexcept>
  44. namespace sinsy
  45. {
  46. const std::string PhonemeLabeler::BREATH_PHONEME = "br"; //!< breath
  47. /*!
  48. constructor
  49. */
  50. PhonemeLabeler::PhonemeLabeler(const PhonemeInfo& p) : phonemeInfo(p), idxInSyllable(0), numInSyllable(0), countFromPrevVowel(0), countToNextVowel(0)
  51. {
  52. }
  53. /*!
  54. destructor
  55. */
  56. PhonemeLabeler::~PhonemeLabeler()
  57. {
  58. }
  59. /*!
  60. set label
  61. */
  62. void PhonemeLabeler::setLabel(IPhonemeLabel& label, int overwriteEnableFlag) const
  63. {
  64. label.setType(phonemeInfo.getType());
  65. label.setName(phonemeInfo.getPhoneme());
  66. ScoreFlag flag(phonemeInfo.getScoreFlag());
  67. if (1 == overwriteEnableFlag) {
  68. unsetDisableFlag(flag);
  69. } else if (2 == overwriteEnableFlag) {
  70. setDisableFlag(flag);
  71. } else if (0 != overwriteEnableFlag) {
  72. throw std::invalid_argument("PhonemeLabeler::setLabel() Overwrite enable flag is invalid");
  73. }
  74. label.setFlag(getScoreFlagStr(flag));
  75. if (numInSyllable < idxInSyllable) {
  76. throw std::runtime_error("PhonemeLabeler::setLabel() numInSyllable < idxInSyllable");
  77. }
  78. label.setPositionInSyllable(idxInSyllable, numInSyllable);
  79. label.setCountFromPrevVowel(countFromPrevVowel);
  80. label.setCountToNextVowel(countToNextVowel);
  81. }
  82. /*!
  83. get score flag
  84. */
  85. ScoreFlag PhonemeLabeler::getScoreFlag() const
  86. {
  87. return phonemeInfo.getScoreFlag();
  88. }
  89. /*!
  90. set index in syllable
  91. */
  92. void PhonemeLabeler::setIdxInSyllable(size_t i)
  93. {
  94. idxInSyllable = i;
  95. }
  96. /*!
  97. set number in syllable
  98. */
  99. void PhonemeLabeler::setNumInSyllable(size_t n)
  100. {
  101. numInSyllable = n;
  102. }
  103. /*!
  104. get phoneme type
  105. */
  106. const std::string& PhonemeLabeler::getPhonemeType() const
  107. {
  108. return phonemeInfo.getType();
  109. }
  110. /*!
  111. set count from previous vowel
  112. */
  113. void PhonemeLabeler::setCountFromPrevVowel(size_t count)
  114. {
  115. this->countFromPrevVowel = count;
  116. }
  117. /*!
  118. set count to next vowel
  119. */
  120. void PhonemeLabeler::setCountToNextVowel(size_t count)
  121. {
  122. this->countToNextVowel = count;
  123. }
  124. }; // namespace sinsy