mosesdecoder/moses/Search.cpp

51 lines
1.2 KiB
C++
Raw Normal View History

#include "Manager.h"
#include "SearchCubePruning.h"
#include "SearchNormal.h"
#include "InputType.h"
2014-01-13 18:37:05 +04:00
#include "util/exception.hh"
namespace Moses
{
2015-12-07 19:07:11 +03:00
Search::Search(Manager& manager)
2013-08-07 17:18:12 +04:00
: m_manager(manager)
2015-12-07 19:07:11 +03:00
, m_source(manager.GetSource())
, m_options(*manager.options())
, m_inputPath()
, m_initialTransOpt()
2015-12-07 19:07:11 +03:00
, m_bitmaps(manager.GetSource().GetSize(), manager.GetSource().m_sourceCompleted)
2015-11-27 15:20:38 +03:00
, interrupted_flag(0)
{
m_initialTransOpt.SetInputPath(m_inputPath);
2016-05-27 12:39:42 +03:00
m_timer.start();
}
bool
Search::
out_of_time()
{
int const& timelimit = m_options.search.timeout;
2016-05-27 12:39:42 +03:00
if (timelimit > 0) {
double elapsed_time = GetUserTime();
if (elapsed_time > timelimit) {
VERBOSE(1,"Decoding is out of time (" << elapsed_time << ","
<< timelimit << ")" << std::endl);
interrupted_flag = 1;
return true;
}
2016-05-27 12:39:42 +03:00
}
int const& segment_timelimit = m_options.search.segment_timeout;
if (segment_timelimit > 0) {
double elapsed_time = m_timer.get_elapsed_time();
if (elapsed_time > segment_timelimit) {
VERBOSE(1,"Decoding for segment is out of time (" << elapsed_time << ","
<< segment_timelimit << ")" << std::endl);
interrupted_flag = 1;
return true;
}
2016-05-27 12:39:42 +03:00
}
return false;
}
}