diff options
| author | Avneesh Saluja <asaluja@gmail.com> | 2013-03-28 18:28:16 -0700 | 
|---|---|---|
| committer | Avneesh Saluja <asaluja@gmail.com> | 2013-03-28 18:28:16 -0700 | 
| commit | 3d8d656fa7911524e0e6885647173474524e0784 (patch) | |
| tree | 81b1ee2fcb67980376d03f0aa48e42e53abff222 /decoder/ff_external.cc | |
| parent | be7f57fdd484e063775d7abf083b9fa4c403b610 (diff) | |
| parent | 96fedabebafe7a38a6d5928be8fff767e411d705 (diff) | |
fixed conflicts
Diffstat (limited to 'decoder/ff_external.cc')
| -rw-r--r-- | decoder/ff_external.cc | 60 | 
1 files changed, 60 insertions, 0 deletions
| diff --git a/decoder/ff_external.cc b/decoder/ff_external.cc new file mode 100644 index 00000000..dea0e20f --- /dev/null +++ b/decoder/ff_external.cc @@ -0,0 +1,60 @@ +#include "ff_external.h" + +#include <dlfcn.h> + +#include "stringlib.h" +#include "hg.h" + +using namespace std; + +ExternalFeature::ExternalFeature(const string& param) { +  size_t pos = param.find(' '); +  string nparam; +  string file = param; +  if (pos < param.size()) { +    nparam = Trim(param.substr(pos + 1)); +    file = param.substr(0, pos); +  } +  if (file.size() < 1) { +    cerr << "External requires a path to a dynamic library!\n"; +    abort(); +  } +  lib_handle = dlopen(file.c_str(), RTLD_LAZY); +  if (!lib_handle) { +    cerr << "dlopen reports: " << dlerror() << endl; +    cerr << "Did you provide a full path to the dynamic library?\n"; +    abort(); +  } +  FeatureFunction* (*fn)(const string&) = +    (FeatureFunction* (*)(const string&))(dlsym(lib_handle, "create_ff")); +  if (!fn) { +    cerr << "dlsym reports: " << dlerror() << endl; +    abort(); +  } +  ff_ext = (*fn)(nparam); +  SetStateSize(ff_ext->StateSize()); +} + +ExternalFeature::~ExternalFeature() { +  delete ff_ext; +  dlclose(lib_handle); +} + +void ExternalFeature::PrepareForInput(const SentenceMetadata& smeta) { +  ff_ext->PrepareForInput(smeta); +} + +void ExternalFeature::FinalTraversalFeatures(const void* context, +                                             SparseVector<double>* features) const { +  ff_ext->FinalTraversalFeatures(context, features); +} + +void ExternalFeature::TraversalFeaturesImpl(const SentenceMetadata& smeta, +                                     const Hypergraph::Edge& edge, +                                     const std::vector<const void*>& ant_contexts, +                                     SparseVector<double>* features, +                                     SparseVector<double>* estimated_features, +                                     void* context) const { +  ff_ext->TraversalFeaturesImpl(smeta, edge, ant_contexts, features, estimated_features, context); +} + | 
