|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include "Alignment.h" |
|
|
|
#include "phrase-extract/syntax-common/exception.h" |
|
|
|
#include <algorithm> |
|
#include <cassert> |
|
#include <cstdlib> |
|
|
|
namespace MosesTraining |
|
{ |
|
|
|
void ReadAlignment(const std::string &s, Alignment &a) |
|
{ |
|
const std::string digits = "0123456789"; |
|
|
|
a.clear(); |
|
|
|
std::string::size_type begin = 0; |
|
while (true) { |
|
std::string::size_type end = s.find("-", begin); |
|
if (end == std::string::npos) { |
|
return; |
|
} |
|
int src = std::atoi(s.substr(begin, end-begin).c_str()); |
|
if (end+1 == s.size()) { |
|
throw Syntax::Exception("Target index missing"); |
|
} |
|
|
|
begin = end+1; |
|
end = s.find_first_not_of(digits, begin+1); |
|
int tgt; |
|
if (end == std::string::npos) { |
|
tgt = std::atoi(s.substr(begin).c_str()); |
|
a.push_back(std::make_pair(src, tgt)); |
|
return; |
|
} else { |
|
tgt = std::atoi(s.substr(begin, end-begin).c_str()); |
|
a.push_back(std::make_pair(src, tgt)); |
|
} |
|
begin = end+1; |
|
} |
|
} |
|
|
|
void FlipAlignment(Alignment &a) |
|
{ |
|
for (Alignment::iterator p = a.begin(); p != a.end(); ++p) { |
|
std::swap(p->first, p->second); |
|
} |
|
} |
|
|
|
} |
|
|