FreeLing  4.0
lexical_chain.h
Go to the documentation of this file.
00001 
00002 //
00003 //    FreeLing - Open Source Language Analyzers
00004 //
00005 //    Copyright (C) 2014   TALP Research Center
00006 //                         Universitat Politecnica de Catalunya
00007 //
00008 //    This library is free software; you can redistribute it and/or
00009 //    modify it under the terms of the GNU Affero General Public
00010 //    License as published by the Free Software Foundation; either
00011 //    version 3 of the License, or (at your option) any later version.
00012 //
00013 //    This library is distributed in the hope that it will be useful,
00014 //    but WITHOUT ANY WARRANTY; without even the implied warranty of
00015 //    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00016 //    Affero General Public License for more details.
00017 //
00018 //    You should have received a copy of the GNU Affero General Public
00019 //    License along with this library; if not, write to the Free Software
00020 //    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
00021 //
00022 //    contact: Lluis Padro (padro@lsi.upc.es)
00023 //             TALP Research Center
00024 //             despatx C6.212 - Campus Nord UPC
00025 //             08034 Barcelona.  SPAIN
00026 //
00028 
00029 #ifndef _LEXCHAIN
00030 #define _LEXCHAIN
00031 
00032 #include "freeling/morfo/relation.h"
00033 #include "freeling/morfo/language.h"
00034 
00035 namespace freeling {
00036 
00041 
00042   class lexical_chain {
00043   public:
00044 
00046     lexical_chain(relation *r, const freeling::word &w, const freeling::sentence &s,
00047                   int n_paragraph, int n_sentence, int position);
00048 
00050     ~lexical_chain();
00051 
00054     bool compute_word(const freeling::word &w, const freeling::sentence &s, const freeling::document &doc,
00055                       int n_paragraph, int n_sentence, int position);
00056 
00058     double get_score();
00059 
00061     int get_number_of_words() const;
00062 
00064     const std::list<word_pos> &get_words() const;
00065 
00067     std::list<word_pos> get_ordered_words() const;
00068 
00070     std::wstring toString();
00071 
00072   private:
00074     double score;
00076     std::unordered_map<std::wstring, std::pair<int, word_pos*> > unique_words;
00078     std::list<word_pos> words;
00080     relation * rel;
00082     std::list<related_words> relations;
00083   };
00084 
00085 } // namespace
00086 
00087 #endif
00088