// -*- mode: c++; indent-tabs-mode: nil; tab-width:2 -*- #pragma once #include #include "moses/ThreadPool.h" #include "moses/Manager.h" #include "moses/HypergraphOutput.h" #include "moses/IOWrapper.h" #include "moses/Manager.h" #include "moses/ChartManager.h" #include "moses/ContextScope.h" #include "moses/Syntax/F2S/Manager.h" #include "moses/Syntax/S2T/Manager.h" #include "moses/Syntax/T2S/Manager.h" #include #include #include #ifdef WITH_THREADS #include #include #endif namespace Moses { class InputType; class OutputCollector; /** Translates a sentence. * - calls the search (Manager) * - applies the decision rule * - outputs best translation and additional reporting **/ class TranslationTask : public Moses::Task { // no copying, no assignment TranslationTask(TranslationTask const& other) { } TranslationTask const& operator=(TranslationTask const& other) { return *this; } protected: AllOptions m_options; boost::weak_ptr m_self; // weak ptr to myself boost::shared_ptr m_scope; // sores local info // pointer to ContextScope, which stores context-specific information TranslationTask() { } ; TranslationTask(boost::shared_ptr const& source, boost::shared_ptr const& ioWrapper); // Yes, the constructor is protected. // // TranslationTasks can only be created through the creator // functions create(...). The creator functions set m_self to a // weak_pointer s.t m_self.get() == this. The public member function // self() can then be used to get a shared_ptr to the Task that // guarantees the existence of the Task while that pointer is live. // Depending on the use, case, that shared pointer can be kept alive // or copied into a weak pointer that can then be used e.g. as a // hash key for caching context-dependent information in feature // functions. When it is time to clean up the cache, the feature // function can determine (via a check on the weak pointer) if the // task is still live or not, or maintain a shared_ptr to ensure the // task stays alive till it's done with it. boost::shared_ptr > m_context; // SPTR const> m_context_weights; public: boost::shared_ptr self() { return m_self.lock(); } virtual boost::shared_ptr self() const { return m_self.lock(); } // creator functions static boost::shared_ptr create(); static boost::shared_ptr create(boost::shared_ptr const& source); static boost::shared_ptr create(boost::shared_ptr const& source, boost::shared_ptr const& ioWrapper); static boost::shared_ptr create(boost::shared_ptr const& source, boost::shared_ptr const& ioWrapper, boost::shared_ptr const& scope); ~TranslationTask(); /** Translate one sentence * gets called by main function implemented at end of this source file */ virtual void Run(); boost::shared_ptr GetSource() const { return m_source; } boost::shared_ptr GetIOWrapper() const { return m_ioWrapper; } boost::shared_ptr SetupManager(SearchAlgorithm algo = DefaultSearchAlgorithm); boost::shared_ptr const& GetScope() const { UTIL_THROW_IF2(m_scope == NULL, "No context scope!"); return m_scope; } boost::shared_ptr > GetContextWindow() const; void SetContextWindow(boost::shared_ptr > const& cw); // SPTR const> GetContextWeights() const; // void SetContextWeights(std::string const& context_weights); // void ReSetContextWeights(std::map const& new_weights); AllOptions const& options() const; protected: boost::shared_ptr m_source; boost::shared_ptr m_ioWrapper; void interpret_dlt(); }; } //namespace