/*---------------------------------------------------------------------------* * vocab.h * * * * Copyright 2007, 2008 Nuance Communciations, Inc. * * * * Licensed under the Apache License, Version 2.0 (the 'License'); * * you may not use this file except in compliance with the License. * * * * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * * * Unless required by applicable law or agreed to in writing, software * * distributed under the License is distributed on an 'AS IS' BASIS, * * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * * See the License for the specific language governing permissions and * * limitations under the License. * * * *---------------------------------------------------------------------------*/ /** FILE: vocab.h ** DATE MODIFIED: 31-Aug-07 ** DESCRIPTION: Container class for Nuance Vocabulary access ** ** All rights reserved */ #ifndef __vocab_h__ #define __vocab_h__ #include <vector> #include <string> #include "SR_Session.h" #include "SR_Vocabulary.h" //#include "srec_arb.h" #include "simapi.h" #define GENERIC_CONTEXT '_' #define SILENCE_CONTEXT '#' #define INTRA_SILENCE_CONTEXT '&' class Vocabulary { public: Vocabulary(); Vocabulary( std::string const & vocFileName ); ~Vocabulary(); SR_Vocabulary *getSRVocabularyHandle() { return m_hVocab; } private: SR_Vocabulary *m_hVocab; }; class AcousticModel { public: AcousticModel( std::string & arbFileName ); ~AcousticModel(); CA_Arbdata *getCAModelHandle() {return m_CA_Arbdata; } int getStateIndices(int id, std::vector<int> & stateIDs); private: CA_Arbdata* m_CA_Arbdata; }; class Pronunciation { public: typedef enum PelPosition {LEFT, RIGHT, MIDDLE}; Pronunciation(); // Pronunciation( Vocabulary & vocab ); int lookup( Vocabulary & vocab, std::string & phrase ); ~Pronunciation(); int addPron( std::string & s ); int getPronCount(); // returns number of prons bool getPron( int index, std::string &s ); void clear(); void print(); void printModelIDs(); int getPhonemeCount( int pronIndex ); bool getPhoneme( int pronIndex, int picIndex , std::string &phoneme ); int lookupModelIDs( AcousticModel &acoustic ); int getModelCount( int pronIndex ); // int getModelID( int pronIndex, int modelPos ); bool getPIC( int pronIndex, int picIndex, std::string &pic ); private: Vocabulary *m_pVocab; std::string m_Phrase; std::vector<std::string> m_Prons; std::vector< std::vector<int> > m_ModelIDs; }; #endif // __vocab_h__