https://github.com/wilkeraziz/mosesdecoder
Raw File
Tip revision: 2ec5207db1493a3580a4c2dc3aab4fc65ed528d5 authored by Hieu Hoang on 16 September 2015, 12:31:36 UTC
int warnings
Tip revision: 2ec5207
ChartTranslationOptionList.h
/***********************************************************************
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
***********************************************************************/

#pragma once

#include "ChartTranslationOptions.h"
#include "ChartParserCallback.h"
#include "StackVec.h"

#include <vector>

namespace Moses
{

class TargetPhraseCollection;
class WordsRange;
class InputType;
class InputPath;
class ChartCellLabel;

//! a vector of translations options for a specific range, in a specific sentence
class ChartTranslationOptionList : public ChartParserCallback
{
  friend std::ostream& operator<<(std::ostream&, const ChartTranslationOptionList&);

public:
  ChartTranslationOptionList(size_t ruleLimit, const InputType &input);
  ~ChartTranslationOptionList();

  const ChartTranslationOptions &Get(size_t i) const {
    return *m_collection[i];
  }

  ChartTranslationOptions &Get(size_t i) {
    return *m_collection[i];
  }

  //! number of translation options
  size_t GetSize() const {
    return m_size;
  }

  void Add(const TargetPhraseCollection &, const StackVec &,
           const WordsRange &);

  void AddPhraseOOV(TargetPhrase &phrase, std::list<TargetPhraseCollection*> &waste_memory, const WordsRange &range);

  bool Empty() const {
    return m_size == 0;
  }

  float GetBestScore(const ChartCellLabel *chartCell) const;

  void Clear();
  void ApplyThreshold();
  void EvaluateWithSourceContext(const InputType &input, const InputPath &inputPath, const ChartCellCollection &hypoStackColl);

private:
  typedef std::vector<ChartTranslationOptions*> CollType;

  struct ScoreThresholdPred {
    ScoreThresholdPred(float threshold) : m_thresholdScore(threshold) {}
    bool operator()(const ChartTranslationOptions *option)  {
      return option->GetEstimateOfBestScore() >= m_thresholdScore;
    }
    float m_thresholdScore;
  };

  void DeleteEmpty();
  void SwapTranslationOptions(size_t a, size_t b);

  CollType m_collection;
  size_t m_size;
  float m_scoreThreshold;
  const size_t m_ruleLimit;

};

}
back to top