summaryrefslogtreecommitdiff
path: root/realtime/rt/decoder.py
diff options
context:
space:
mode:
authorMichael Denkowski <mdenkows@cs.cmu.edu>2013-09-02 15:09:19 -0700
committerMichael Denkowski <mdenkows@cs.cmu.edu>2013-09-02 15:09:19 -0700
commite6f15583081547a4adc2fca7f2ed96cb515a48f5 (patch)
tree1905387d7969798fc59a73df0e9e72944ed77c11 /realtime/rt/decoder.py
parente078ac74f3499298742174a06f915b58f2d4cbdb (diff)
Use kbest_cut_mira stream as decoder
Diffstat (limited to 'realtime/rt/decoder.py')
-rw-r--r--realtime/rt/decoder.py16
1 files changed, 12 insertions, 4 deletions
diff --git a/realtime/rt/decoder.py b/realtime/rt/decoder.py
index f4fea0e2..786bc07a 100644
--- a/realtime/rt/decoder.py
+++ b/realtime/rt/decoder.py
@@ -8,6 +8,11 @@ class Decoder:
def close(self):
self.decoder.stdin.close()
+ def decode(self, sentence, grammar):
+ input = '<seg grammar="{g}">{s}</seg>\n'.format(i=id, s=sentence, g=grammar)
+ self.decoder.stdin.write(input)
+ return self.decoder.stdout.readline().strip()
+
class CdecDecoder(Decoder):
def __init__(self, config, weights):
@@ -16,8 +21,11 @@ class CdecDecoder(Decoder):
decoder_cmd = [decoder, '-c', config, '-w', weights]
self.decoder = util.popen_io(decoder_cmd)
- def decode(self, sentence, grammar):
- input = '<seg grammar="{g}">{s}</seg>\n'.format(i=id, s=sentence, g=grammar)
- self.decoder.stdin.write(input)
- return self.decoder.stdout.readline().strip()
+class MIRADecoder(Decoder):
+ def __init__(self, config, weights):
+ cdec_root = os.path.dirname(os.path.dirname(os.path.dirname(__file__)))
+ mira = os.path.join(cdec_root, 'training', 'mira', 'kbest_cut_mira')
+ # optimizer=2 step=0.001 best=500, k=500, uniq, stream
+ mira_cmd = [mira, '-c', config, '-w', weights, '-o', '2', '-C', '0.001', '-b', '500', '-k', '500', '-u', '-t']
+ self.decoder = util.popen_io(mira_cmd)