languagemodelfactory.cpp.svn-base

来自「解码器是基于短语的统计机器翻译系统的核心模块」· SVN-BASE 代码 · 共 125 行

SVN-BASE
125
字号
// $Id$/***********************************************************************Moses - factored phrase-based language decoderCopyright (C) 2006 University of EdinburghThis library is free software; you can redistribute it and/ormodify it under the terms of the GNU Lesser General PublicLicense as published by the Free Software Foundation; eitherversion 2.1 of the License, or (at your option) any later version.This library is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNULesser General Public License for more details.You should have received a copy of the GNU Lesser General PublicLicense along with this library; if not, write to the Free SoftwareFoundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA***********************************************************************/#include "LanguageModelFactory.h"#include "UserMessage.h"#include "TypeDef.h"#include "FactorCollection.h"// include appropriate header#ifdef LM_SRI#  include "LanguageModelSRI.h"#endif#ifdef LM_IRST#  include "LanguageModelIRST.h"#endif#include "LanguageModelInternal.h"#include "LanguageModelSkip.h"#include "LanguageModelJoint.h"namespace LanguageModelFactory{	LanguageModel* CreateLanguageModel(LMImplementation lmImplementation, const std::vector<FactorType> &factorTypes                                        , size_t nGramOrder, const std::string &languageModelFile, float weight, FactorCollection &factorCollection)	{	  LanguageModel *lm = NULL;	  switch (lmImplementation)	  {	  	case SRI:				#ifdef LM_SRI				  lm = new LanguageModelSRI(true);				#elif LM_INTERNAL					lm = new LanguageModelInternal(true);				#elif LM_IRST					// shouldn't really do this. the 2 lm are not compatible					lm = new LanguageModelIRST(true);			  #endif			  break;			case IRST:				#ifdef LM_IRST	     		lm = new LanguageModelIRST(true);				#elif LM_SRI					// shouldn't really do this. the 2 lm are not compatible				  lm = new LanguageModelSRI(true);				#elif LM_INTERNAL					// shouldn't really do this. the 2 lm are not compatible					lm = new LanguageModelInternal(true);			  #endif				break;			case Skip:				#ifdef LM_SRI	     		lm = new LanguageModelSkip(new LanguageModelSRI(false), true);				#elif LM_INTERNAL     			lm = new LanguageModelSkip(new LanguageModelInternal(false), true);				#elif LM_IRST					// shouldn't really do this. the 2 lm are not compatible	     		lm = new LanguageModelSkip(new LanguageModelIRST(false), true);				#endif				break;			case Joint:				#ifdef LM_SRI	     		lm = new LanguageModelJoint(new LanguageModelSRI(false), true);				#elif LM_INTERNAL	     		lm = new LanguageModelJoint(new LanguageModelInternal(false), true);				#elif LM_IRST					// shouldn't really do this. the 2 lm are not compatible	     		lm = new LanguageModelJoint(new LanguageModelIRST(false), true);				#endif				break;	  	case Internal:				#ifdef LM_INTERNAL					lm = new LanguageModelInternal(true);			  #endif			  break;	  }	  	  if (lm == NULL)	  {	  	UserMessage::Add("Language model type unknown. Probably not compiled into library");	  }	  else	  {	  	switch (lm->GetLMType())	  	{	  	case SingleFactor:	  		if (! static_cast<LanguageModelSingleFactor*>(lm)->Load(languageModelFile, factorCollection, factorTypes[0], weight, nGramOrder))				{					delete lm;					lm = NULL;				}	  		break;	  		  	case MultiFactor:  			if (! static_cast<LanguageModelMultiFactor*>(lm)->Load(languageModelFile, factorCollection, factorTypes, weight, nGramOrder))				{					delete lm;					lm = NULL;				}  			break;	  	}	  }	  	  return lm;	}}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?