diff options
author | Hieu Hoang <hieuhoang@gmail.com> | 2012-11-12 23:56:18 +0400 |
---|---|---|
committer | Hieu Hoang <hieuhoang@gmail.com> | 2012-11-12 23:56:18 +0400 |
commit | 5e3ef23cef6101d2c098eb3445f562e8f595655b (patch) | |
tree | b8c332b6fa82bae84ea4910967a10ba1b08a7107 /moses/ChartTranslationOptions.cpp | |
parent | 8c785cff2b1be3cccd76ea9026f71b649762dfc3 (diff) |
move moses/src/* to moses/
Diffstat (limited to 'moses/ChartTranslationOptions.cpp')
-rw-r--r-- | moses/ChartTranslationOptions.cpp | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/moses/ChartTranslationOptions.cpp b/moses/ChartTranslationOptions.cpp new file mode 100644 index 000000000..c55948a82 --- /dev/null +++ b/moses/ChartTranslationOptions.cpp @@ -0,0 +1,46 @@ +/*********************************************************************** + Moses - factored phrase-based language decoder + Copyright (C) 2010 Hieu Hoang + + 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 "ChartTranslationOptions.h" + +#include "ChartHypothesis.h" + +#include "ChartCellLabel.h" + +namespace Moses +{ + +float ChartTranslationOptions::CalcEstimateOfBestScore( + const TargetPhraseCollection &tpc, + const StackVec &stackVec) +{ + const TargetPhrase &targetPhrase = **(tpc.begin()); + float estimateOfBestScore = targetPhrase.GetFutureScore(); + for (StackVec::const_iterator p = stackVec.begin(); p != stackVec.end(); + ++p) { + const HypoList *stack = (*p)->GetStack().cube; + assert(stack); + assert(!stack->empty()); + const ChartHypothesis &bestHypo = **(stack->begin()); + estimateOfBestScore += bestHypo.GetTotalScore(); + } + return estimateOfBestScore; +} + +} |