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 // WeightedExtentOrNode 00014 // 00015 // 8 April 2005 -- tds 00016 // 00017 00018 #ifndef INDRI_WEIGHTEDEXTENTORNODE_HPP 00019 #define INDRI_WEIGHTEDEXTENTORNODE_HPP 00020 00021 #include <vector> 00022 #include <string> 00023 #include "indri/greedy_vector" 00024 #include "indri/ListIteratorNode.hpp" 00025 namespace indri 00026 { 00027 namespace infnet 00028 { 00029 00030 class WeightedExtentOrNode : public ListIteratorNode { 00031 private: 00032 std::vector<ListIteratorNode*> _children; 00033 std::vector<double> _weights; 00034 indri::utility::greedy_vector<indri::index::Extent> _extents; 00035 std::string _name; 00036 00037 public: 00038 WeightedExtentOrNode( const std::string& name, std::vector<ListIteratorNode*>& children, const std::vector<double>& weights ); 00039 void prepare( lemur::api::DOCID_T documentID ); 00040 const indri::utility::greedy_vector<indri::index::Extent>& extents(); 00041 00042 void indexChanged( indri::index::Index& index ); 00043 lemur::api::DOCID_T nextCandidateDocument(); 00044 00045 const std::string& getName() const; 00046 void annotate( class Annotator& annotator, lemur::api::DOCID_T documentID, indri::index::Extent &extent ); 00047 }; 00048 } 00049 } 00050 00051 #endif // INDRI_WEIGHTEDEXTENTORNODE_HPP 00052