// fstext/pre-determinize.h // Copyright 2009-2011 Microsoft Corporation // See ../../COPYING for clarification regarding multiple authors // // 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 // // THIS CODE IS PROVIDED *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY // KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED // WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, // MERCHANTABLITY OR NON-INFRINGEMENT. // See the Apache 2 License for the specific language governing permissions and // limitations under the License. #ifndef KALDI_FSTEXT_PRE_DETERMINIZE_H_ #define KALDI_FSTEXT_PRE_DETERMINIZE_H_ #include #include #include #include #include #include #include "base/kaldi-common.h" namespace fst { /* PreDeterminize inserts extra symbols on the input side of an FST as necessary to ensure that, after epsilon removal, it will be compactly determinizable by the determinize* algorithm. By compactly determinizable we mean that no original FST state is represented in more than one determinized state). Caution: this code is now only used in testing. The new symbols start from the value "first_new_symbol", which should be higher than the largest-numbered symbol currently in the FST. The new symbols added are put in the array syms_out, which should be empty at start. */ template void PreDeterminize(MutableFst *fst, typename Arc::Label first_new_symbol, vector *syms_out); /* CreateNewSymbols is a helper function used inside PreDeterminize, and is also useful when you need to add a number of extra symbols to a different vocabulary from the one modified by PreDeterminize. */ template void CreateNewSymbols(SymbolTable *inputSymTable, int nSym, std::string prefix, vector