#ifndef NGRAMS_FF_H_ #define NGRAMS_FF_H_ #include #include #include #include "ff.h" class NgramDetectorImpl; class NgramDetector : public FeatureFunction { public: // param = "filename.lm [-o ] [-U ] [-B ] [-T ] [-4 <4-gram-prefix>] [-5 <5-gram-prefix>] [-S ] NgramDetector(const std::string& param); ~NgramDetector(); virtual void FinalTraversalFeatures(const void* context, SparseVector* features) const; protected: virtual void TraversalFeaturesImpl(const SentenceMetadata& smeta, const HG::Edge& edge, const std::vector& ant_contexts, SparseVector* features, SparseVector* estimated_features, void* out_context) const; private: NgramDetectorImpl* pimpl_; }; #endif