| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
 | #!/usr/bin/env ruby
require 'zipf'
require 'trollop'
def get_context kbest_lists, references, n
  a = []
  kbest_lists.each_index { |i|
    a << BLEU::get_counts(kbest_lists[i][0].s, references[i], n, 1)
  }
  return a
end
def main
  cfg = Trollop::options do
    opt :kbest_lists, "kbest lists", :type => :string, :required => true
    opt :references, "reference", :type => :string, :required => true
    opt :n, "N for BLEU", :type => :int, :default => 4
    opt :weight, "how much to weigh single translations", :type => :int, :default => 1
    opt :debug, "debug mode", :type => :bool, :default => false
  end
  debug = cfg[:debug]
  n = cfg[:n]
  kbest_lists = read_kbest_lists cfg[:kbest_lists]
  references = ReadFile.readlines_strip cfg[:references]
  context = get_context kbest_lists, references, n
  kbest_lists.each_with_index { |kbest,j|
    scores = []
    max_score = -1.0/0
    max_idx = -1
    kbest.each_index { |i|
      context_cp = context.dup
      context_cp[j] = BLEU::get_counts kbest[i].s, references[j], n, cfg[:weight]
      score = BLEU::hbleu_(context_cp, n, debug)
      scores << score
      if score > max_score
        max_score = score
        max_idx = i
      end
      STDERR.write "#{i} #{kbest[i]}\t#{score}\n---\n" if debug
    }
    puts "#{references[j]}"
    puts "BLEU=#{scores[0]} ||| #{kbest[0]}"
    puts "BLEU=#{max_score} ||| #{kbest[max_idx]}"
    puts
    STDERR.write "\n" if debug
  }
end
main
 |