relax_tagger.h
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00028
00029 #ifndef _RELAX_TAGGER
00030 #define _RELAX_TAGGER
00031
00032 #include <list>
00033 #include <string>
00034
00035 #include "fries/language.h"
00036 #include "freeling/tagger.h"
00037 #include "freeling/relax.h"
00038 #include "freeling/constraint_grammar.h"
00039
00040 #include "regexp-pcre++.h"
00041
00042
00043 #define USER_RE "^u\\.([0-9]+)=(.+)$"
00044
00045
00053
00054 class relax_tagger : public POS_tagger {
00055 private:
00057 relax solver;
00059 constraint_grammar c_gram;
00060
00061
00062 RegEx RE_user;
00063
00066 bool CheckCondition(const sentence &, sentence::const_iterator, int,
00067 const condition &, std::list<std::list<std::pair<int,int> > > &);
00070 bool CheckWordMatchCondition(const std::list<std::string> &, bool, int, sentence::const_iterator,
00071 std::list<std::pair<int,int> > &);
00073 bool check_possible_matching(const std::string &, word::const_iterator,
00074 sentence::const_iterator);
00076 bool check_match(const std::string &, const std::string &) const;
00077
00078 public:
00080 relax_tagger(const std::string &, int, double, double, bool, unsigned int);
00081
00083 void analyze(std::list<sentence> &);
00085 std::list<sentence> analyze(const std::list<sentence> &);
00086 };
00087
00088
00089 #endif