#ifndef _NGRAMS_FF_H_ #define _NGRAMS_FF_H_ #include <vector> #include <map> #include <string> #include "ff.h" struct NgramDetectorImpl; class NgramDetector : public FeatureFunction { public: // param = "filename.lm [-o n]" NgramDetector(const std::string& param); ~NgramDetector(); virtual void FinalTraversalFeatures(const void* context, SparseVector<double>* features) const; protected: virtual void TraversalFeaturesImpl(const SentenceMetadata& smeta, const Hypergraph::Edge& edge, const std::vector<const void*>& ant_contexts, SparseVector<double>* features, SparseVector<double>* estimated_features, void* out_context) const; private: NgramDetectorImpl* pimpl_; }; #endif