mirror of
https://github.com/moses-smt/mosesdecoder.git
synced 2025-01-01 08:21:47 +03:00
3172abca21
git-svn-id: https://mosesdecoder.svn.sourceforge.net/svnroot/mosesdecoder/trunk@1990 1f5c12ca-751b-0410-a591-d2e778427230
30 lines
563 B
C++
30 lines
563 B
C++
#include <cassert>
|
|
#include <iostream>
|
|
#include "Ngram.h"
|
|
|
|
using namespace std;
|
|
Vocab vocab;
|
|
Ngram* ngram = NULL;
|
|
|
|
extern "C" {
|
|
|
|
void srilm_init(const char* fname, int order) {
|
|
cerr << "Loading " << order << "-gram LM: " << fname << endl;
|
|
File file(fname, "r", 0);
|
|
assert(file);
|
|
ngram = new Ngram(vocab, order);
|
|
ngram->read(file, false);
|
|
cerr << "Done\n";
|
|
}
|
|
|
|
int srilm_getvoc(const char* word) {
|
|
return vocab.getIndex((VocabString)word);
|
|
}
|
|
|
|
float srilm_wordprob(int w, int* context) {
|
|
return (float)ngram->wordProb(w, (VocabIndex*)context);
|
|
}
|
|
|
|
}
|
|
|