1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
|
// $Id$
/***********************************************************************
Moses - factored phrase-based language decoder
Copyright (C) 2006 University of Edinburgh
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 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 of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
***********************************************************************/
#include <iostream>
#include "LM/Factory.h"
#include "UserMessage.h"
#include "TypeDef.h"
#include "FactorCollection.h"
/////////////////////////////////////////////////
// for those using autoconf/automake
#if HAVE_CONFIG_H
#include "config.h"
#define LM_REMOTE 1
# ifdef HAVE_SRILM
# define LM_SRI 1
# else
# undef LM_SRI
# endif
# ifdef HAVE_IRSTLM
# define LM_IRST 1
# endif
# ifdef HAVE_RANDLM
# define LM_RAND 1
# endif
# ifdef HAVE_ORLM
# define LM_ORLM 1
# endif
# ifdef HAVE_DMAPLM
# define LM_DMAP
# endif
#endif
// include appropriate header
#ifdef LM_SRI
# include "LM/SRI.h"
#include "LM/ParallelBackoff.h"
#endif
#ifdef LM_IRST
# include "LM/IRST.h"
#endif
#ifdef LM_RAND
# include "LM/Rand.h"
#endif
#ifdef LM_ORLM
# include "LM/ORLM.h"
#endif
#ifdef LM_REMOTE
# include "LM/Remote.h"
#endif
#include "LM/Ken.h"
#ifdef LM_DMAP
# include "LM/DMapLM.h"
#endif
#include "LM/Base.h"
#include "LM/Joint.h"
using namespace std;
namespace Moses
{
namespace LanguageModelFactory
{
LanguageModel* CreateLanguageModel(LMImplementation lmImplementation
, const std::vector<FactorType> &factorTypes
, size_t nGramOrder
, const std::string &languageModelFile
, ScoreIndexManager &scoreIndexManager
, int dub )
{
if (lmImplementation == Ken || lmImplementation == LazyKen) {
return ConstructKenLM(languageModelFile, scoreIndexManager, factorTypes[0], lmImplementation == LazyKen);
}
LanguageModelImplementation *lm = NULL;
switch (lmImplementation) {
case RandLM:
#ifdef LM_RAND
lm = NewRandLM();
#endif
break;
case ORLM:
#ifdef LM_ORLM
lm = new LanguageModelORLM();
#endif
break;
case Remote:
#ifdef LM_REMOTE
lm = new LanguageModelRemote();
#endif
break;
case SRI:
#ifdef LM_SRI
lm = new LanguageModelSRI();
#endif
break;
case IRST:
#ifdef LM_IRST
lm = new LanguageModelIRST(dub);
#endif
break;
case Joint:
#ifdef LM_SRI
lm = new LanguageModelJoint(new LanguageModelSRI());
#endif
break;
case ParallelBackoff:
#ifdef LM_SRI
lm = NewParallelBackoff();
#endif
break;
case DMapLM:
#ifdef LM_DMAP
lm = new LanguageModelDMapLM();
#endif
break;
default:
break;
}
if (lm == NULL) {
UserMessage::Add("Language model type unknown. Probably not compiled into library");
return NULL;
} else {
switch (lm->GetLMType()) {
case SingleFactor:
if (! static_cast<LanguageModelSingleFactor*>(lm)->Load(languageModelFile, factorTypes[0], nGramOrder)) {
cerr << "single factor model failed" << endl;
delete lm;
lm = NULL;
}
break;
case MultiFactor:
if (! static_cast<LanguageModelMultiFactor*>(lm)->Load(languageModelFile, factorTypes, nGramOrder)) {
cerr << "multi factor model failed" << endl;
delete lm;
lm = NULL;
}
break;
}
}
return new LMRefCount(scoreIndexManager, lm);
}
}
}
|