1 #include <ngram_model.h>
6 #include "test_macros.h"
13 test_lm_vals(ngram_model_t *model)
18 TEST_EQUAL(ngram_wid(model, "<UNK>"), 0);
19 TEST_EQUAL(strcmp(ngram_word(model, 0), "<UNK>"), 0);
20 TEST_EQUAL(ngram_wid(model, "absolute"), 13);
21 TEST_EQUAL(strcmp(ngram_word(model, 13), "absolute"), 0);
23 TEST_EQUAL_LOG(ngram_score(model, "<UNK>", NULL), -75346);
24 TEST_EQUAL_LOG(ngram_bg_score(model, ngram_wid(model, "<UNK>"),
25 NGRAM_INVALID_WID, &n_used), -75346);
26 TEST_EQUAL(n_used, 1);
27 TEST_EQUAL_LOG(ngram_score(model, "sphinxtrain", NULL), -64208);
28 TEST_EQUAL_LOG(ngram_bg_score(model, ngram_wid(model, "sphinxtrain"),
29 NGRAM_INVALID_WID, &n_used), -64208);
30 TEST_EQUAL(n_used, 1);
31 printf("FOO %d\n", ngram_score(model, "huggins", "david", NULL));
32 printf("FOO %d\n", ngram_score(model, "daines", "huggins", "david", NULL));
34 TEST_EQUAL_LOG(ngram_score(model, "huggins", "david", NULL), -831);
36 TEST_EQUAL_LOG(ngram_score(model, "daines", "huggins", "david", NULL), -9450);
41 main(int argc, char *argv[])
46 /* Initialize a logmath object to pass to ngram_read */
47 lmath = logmath_init(1.0001, 0, 0);
49 /* Convert ARPA to DMP */
50 E_INFO("Converting ARPA to DMP\n");
51 model = ngram_model_read(NULL, LMDIR "/100.arpa.bz2", NGRAM_ARPA, lmath);
53 TEST_EQUAL(0, ngram_model_write(model, "100.tmp.DMP", NGRAM_DMP));
54 ngram_model_free(model);
56 /* Convert DMP to ARPA */
57 E_INFO("Converting DMP to ARPA\n");
58 model = ngram_model_read(NULL, LMDIR "/100.arpa.DMP", NGRAM_DMP, lmath);
60 TEST_EQUAL(0, ngram_model_write(model, "100.tmp.arpa", NGRAM_ARPA));
61 ngram_model_free(model);
63 /* Test converted DMP */
64 E_INFO("Testing converted DMP\n");
65 model = ngram_model_read(NULL, "100.tmp.DMP", NGRAM_DMP, lmath);
67 ngram_model_free(model);
69 /* Test converted ARPA */
70 E_INFO("Testing converted ARPA\n");
71 model = ngram_model_read(NULL, "100.tmp.arpa", NGRAM_ARPA, lmath);
73 ngram_model_free(model);
75 /* Convert DMP back to ARPA*/
76 E_INFO("Converting ARPA back to DMP\n");
77 model = ngram_model_read(NULL, "100.tmp.arpa", NGRAM_ARPA, lmath);
79 TEST_EQUAL(0, ngram_model_write(model, "100.tmp.DMP", NGRAM_DMP));
80 ngram_model_free(model);
82 /* Convert ARPA back to DMP */
83 E_INFO("Converting DMP back to ARPA\n");
84 model = ngram_model_read(NULL, "100.tmp.DMP", NGRAM_DMP, lmath);
86 TEST_EQUAL(0, ngram_model_write(model, "100.tmp.arpa", NGRAM_ARPA));
87 ngram_model_free(model);