2010-04-08 21:16:10 +04:00
|
|
|
#include "Manager.h"
|
|
|
|
#include "SearchCubePruning.h"
|
|
|
|
#include "SearchNormal.h"
|
2015-10-26 12:20:08 +03:00
|
|
|
#include "InputType.h"
|
2014-01-13 18:37:05 +04:00
|
|
|
#include "util/exception.hh"
|
2010-04-08 21:16:10 +04:00
|
|
|
|
|
|
|
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())
|
2015-12-10 02:05:00 +03:00
|
|
|
, m_options(*manager.options())
|
2015-08-06 02:51:02 +03:00
|
|
|
, 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)
|
2013-08-07 13:28:28 +04:00
|
|
|
{
|
2013-08-13 23:36:32 +04:00
|
|
|
m_initialTransOpt.SetInputPath(m_inputPath);
|
2016-05-27 12:39:42 +03:00
|
|
|
m_timer.start();
|
2013-08-07 13:28:28 +04:00
|
|
|
}
|
|
|
|
|
2015-08-06 02:51:02 +03:00
|
|
|
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();
|
2016-05-29 18:44:31 +03:00
|
|
|
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();
|
2016-05-29 18:44:31 +03:00
|
|
|
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
|
|
|
}
|
2016-05-29 18:44:31 +03:00
|
|
|
return false;
|
2015-08-06 02:51:02 +03:00
|
|
|
}
|
|
|
|
|
2010-04-08 21:16:10 +04:00
|
|
|
}
|