123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221 |
- /* ----------------------------------------------------------------- */
- /* The HMM-Based Singing Voice Synthesis System "Sinsy" */
- /* developed by Sinsy Working Group */
- /* http://sinsy.sourceforge.net/ */
- /* ----------------------------------------------------------------- */
- /* */
- /* Copyright (c) 2009-2015 Nagoya Institute of Technology */
- /* Department of Computer Science */
- /* */
- /* All rights reserved. */
- /* */
- /* Redistribution and use in source and binary forms, with or */
- /* without modification, are permitted provided that the following */
- /* conditions are met: */
- /* */
- /* - Redistributions of source code must retain the above copyright */
- /* notice, this list of conditions and the following disclaimer. */
- /* - Redistributions in binary form must reproduce the above */
- /* copyright notice, this list of conditions and the following */
- /* disclaimer in the documentation and/or other materials provided */
- /* with the distribution. */
- /* - Neither the name of the Sinsy working group nor the names of */
- /* its contributors may be used to endorse or promote products */
- /* derived from this software without specific prior written */
- /* permission. */
- /* */
- /* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND */
- /* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, */
- /* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF */
- /* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE */
- /* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS */
- /* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, */
- /* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED */
- /* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, */
- /* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON */
- /* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, */
- /* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY */
- /* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE */
- /* POSSIBILITY OF SUCH DAMAGE. */
- /* ----------------------------------------------------------------- */
- #include <fstream>
- #include "PhonemeTable.h"
- #include "StringTokenizer.h"
- #include "util_log.h"
- #include "util_string.h"
- namespace sinsy
- {
- /*!
- constructor
- */
- PhonemeTable::Result::Result() : syllable(NULL), phonemeList(NULL)
- {
- }
- /*!
- constructor
- */
- PhonemeTable::Result::Result(const std::string& s, const PhonemeList* p) : syllable(&s), phonemeList(p)
- {
- }
- /*!
- copy constructor
- */
- PhonemeTable::Result::Result(const Result& obj) : syllable(obj.syllable), phonemeList(obj.phonemeList)
- {
- }
- /*!
- destructor
- */
- PhonemeTable::Result::~Result()
- {
- }
- /*!
- assignment operator
- */
- PhonemeTable::Result& PhonemeTable::Result::operator=(const Result & obj)
- {
- this->syllable = obj.syllable;
- this->phonemeList = obj.phonemeList;
- return *this;
- }
- /*!
- return true if this result is valid
- */
- bool PhonemeTable::Result::isValid() const
- {
- return (NULL != syllable);
- }
- /*!
- get syllable
- */
- const std::string& PhonemeTable::Result::getSyllable() const
- {
- return (NULL == syllable) ? NULL_STR : *syllable;
- }
- /*!
- get phoneme list
- */
- const PhonemeTable::PhonemeList* PhonemeTable::Result::getPhonemeList() const
- {
- return phonemeList;
- }
- /*!
- get matched length
- */
- size_t PhonemeTable::Result::getMatchedLength() const
- {
- return (NULL == syllable) ? 0 : syllable->size();
- }
- /*!
- constructor
- */
- PhonemeTable::PhonemeTable()
- {
- }
- /*!
- destructor
- */
- PhonemeTable::~PhonemeTable()
- {
- clear();
- }
- /*!
- clear
- */
- void PhonemeTable::clear()
- {
- ConvertTable::iterator itr(convertTable.begin());
- ConvertTable::iterator itrEnd(convertTable.end());
- for (; itr != itrEnd; ++itr) {
- delete itr->second;
- }
- convertTable.clear();
- }
- /*!
- read from file
- @param fname phoneme table file path
- @param return true if success
- */
- bool PhonemeTable::read(const std::string& fname)
- {
- std::ifstream ifs(fname.c_str());
- if (!ifs) {
- ERR_MSG("Cannot open phoneme table file : " << fname);
- return false;
- }
- clear();
- std::string buffer;
- while (!ifs.eof()) {
- std::getline(ifs, buffer);
- StringTokenizer st(buffer, BLANK_STR);
- size_t sz(st.size());
- if (0 == sz) {
- continue;
- } else if (1 == sz) {
- ERR_MSG("Wrong phoneme table (value is needed after key) : " << fname);
- return false;
- }
- PhonemeList* pl(new PhonemeList);
- pl->reserve(sz - 1);
- for (size_t i(1); i < sz; ++i) {
- pl->push_back(st.at(i));
- }
- if (false == convertTable.insert(std::make_pair/*<std::string, PhonemeList*>*/(st.at(0), pl)).second) {
- ERR_MSG("Wrong phoneme table (some syllables have same name : " << st.at(0) << ") : " << fname);
- delete pl;
- return false;
- }
- }
- return true;
- }
- /*!
- find from table
- */
- PhonemeTable::Result PhonemeTable::find(const std::string& syllable) const
- {
- for (size_t sz(syllable.size()); 0 < sz ; --sz) {
- std::string s(syllable.substr(0, sz));
- ConvertTable::const_iterator itr(convertTable.find(s));
- if (convertTable.end() != itr) {
- return Result(itr->first, itr->second);
- }
- }
- return Result();
- }
- /*!
- return matched result
- */
- PhonemeTable::Result PhonemeTable::match(const std::string& syllable) const
- {
- ConvertTable::const_iterator itr(convertTable.find(syllable));
- if (convertTable.end() != itr) {
- return Result(itr->first, itr->second);
- }
- return Result();
- }
- }; // namespace sinsy
|