Main Page   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Related Pages  

UnorderedWindowNode.hpp

Go to the documentation of this file.
00001 /*==========================================================================
00002  * Copyright (c) 2004 University of Massachusetts.  All Rights Reserved.
00003  *
00004  * Use of the Lemur Toolkit for Language Modeling and Information Retrieval
00005  * is subject to the terms of the software license set forth in the LICENSE
00006  * file included with this software, and also available at
00007  * http://www.lemurproject.org/license.html
00008  *
00009  *==========================================================================
00010 */
00011 
00012 
00013 //
00014 // UnorderedWindowNode
00015 //
00016 // 26 January 2004 -- tds
00017 //
00018 
00019 #ifndef INDRI_UNORDEREDWINDOWNODE_HPP
00020 #define INDRI_UNORDEREDWINDOWNODE_HPP
00021 
00022 #include "indri/ListIteratorNode.hpp"
00023 #include <vector>
00024 #include <indri/greedy_vector>
00025 
00026 class UnorderedWindowNode : public ListIteratorNode {
00027 private:
00028   struct term_position {
00029     bool operator< ( const term_position& other ) const {
00030       return begin < other.begin;
00031     }
00032 
00033     int type;
00034     int begin;
00035     int end;
00036     int last; // index of previous entry of this type
00037   };
00038 
00039   int _windowSize;
00040   std::vector<ListIteratorNode*> _children;
00041   greedy_vector<Extent> _extents;
00042   std::string _name;
00043 
00044 public:
00045   UnorderedWindowNode( const std::string& name, std::vector<ListIteratorNode*>& children );
00046   UnorderedWindowNode( const std::string& name, std::vector<ListIteratorNode*>& children, int windowSize );
00047   int nextCandidateDocument();
00048   void prepare( int documentID );
00049   const greedy_vector<Extent>& extents();
00050   const std::string& getName() const;
00051   void annotate( Annotator& annotator, int documentID, int begin, int end );
00052 };
00053 
00054 #endif // INDRI_UNORDEREDWINDOWNODE_HPP

Generated on Wed Nov 3 12:59:07 2004 for Lemur Toolkit by doxygen1.2.18