2012-02-20 04:46:08 +04:00
|
|
|
#ifndef MERT_TER_BEST_SHIFT_STRUCT_H_
|
|
|
|
#define MERT_TER_BEST_SHIFT_STRUCT_H_
|
2011-08-16 20:21:31 +04:00
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string>
|
|
|
|
#include <sstream>
|
|
|
|
#include "tools.h"
|
|
|
|
#include "terShift.h"
|
|
|
|
#include "terAlignment.h"
|
|
|
|
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
using namespace Tools;
|
|
|
|
|
|
|
|
namespace TERCpp
|
|
|
|
{
|
|
|
|
class bestShiftStruct
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
public:
|
|
|
|
|
|
|
|
// alignmentStruct();
|
|
|
|
// alignmentStruct (int _start, int _end, int _moveto, int _newloc);
|
|
|
|
// alignmentStruct (int _start, int _end, int _moveto, int _newloc, vector<string> _shifted);
|
|
|
|
// string toString();
|
|
|
|
// int distance() ;
|
|
|
|
// bool leftShift();
|
|
|
|
// int size();
|
|
|
|
// alignmentStruct operator=(alignmentStruct t);
|
|
|
|
// string vectorToString(vector<string> vec);
|
|
|
|
|
|
|
|
// int start;
|
|
|
|
// int end;
|
|
|
|
// int moveto;
|
|
|
|
// int newloc;
|
|
|
|
terShift m_best_shift;
|
|
|
|
terAlignment m_best_align;
|
|
|
|
bool m_empty;
|
|
|
|
// vector<string> nwords; // The words we shifted
|
|
|
|
// char* alignment ; // for pra_more output
|
|
|
|
// vector<vecInt> aftershift; // for pra_more output
|
|
|
|
// This is used to store the cost of a shift, so we don't have to
|
|
|
|
// calculate it multiple times.
|
|
|
|
// double cost;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
2011-11-12 02:59:50 +04:00
|
|
|
|
2012-02-20 04:46:08 +04:00
|
|
|
#endif // MERT_TER_BEST_SHIFT_STRUCT_H_
|