|
<?php |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function show_analysis() { |
|
global $task,$user,$setup,$id,$set; |
|
global $dir; |
|
|
|
head("Analysis: $task ($user), Set $set, Run $id"); |
|
|
|
?><script> |
|
function show(field,sort,count,filter) { |
|
var url = '?analysis=' + field + '_show' |
|
+ '&setup=<?php print $setup ?>' |
|
+ '&id=<?php print $id ?>' |
|
+ '&set=<?php print $set ?>' |
|
+ '&sort=' + sort |
|
+ '&count=' + count |
|
+ '&filter=' + filter; |
|
new Ajax.Updater(field, url, { method: 'get', evalScripts: true }); |
|
} |
|
function ngram_show(type,order,count,sort,smooth) { |
|
var url = '?analysis=ngram_' + type + '_show' |
|
+ '&setup=<?php print $setup ?>' |
|
+ '&id=<?php print $id ?>' |
|
+ '&set=<?php print $set ?>' |
|
+ '&order=' + order |
|
+ '&smooth=' + smooth |
|
+ '&sort=' + sort |
|
+ '&count=' + count; |
|
var field = (type == "precision" ? "nGramPrecision" : "nGramRecall") + order; |
|
new Ajax.Updater(field, url, { method: 'get', evalScripts: true }); |
|
} |
|
function generic_show(field,parameters) { |
|
var url = '?analysis=' + field + '_show' |
|
+ '&setup=<?php print $setup ?>' |
|
+ '&id=<?php print $id ?>' |
|
+ '&set=<?php print $set ?>' |
|
+ '&' + parameters; |
|
new Ajax.Updater(field, url, { method: 'get', evalScripts: true }); |
|
} |
|
function highlight_phrase(sentence,phrase) { |
|
var input = "input-"+sentence+"-"+phrase; |
|
$(input).setStyle({ borderColor: 'red' }); |
|
var output = "output-"+sentence+"-"+phrase; |
|
$(output).setStyle({ borderColor: 'red' }); |
|
} |
|
function show_word_info(sentence,cc,tc,te) { |
|
var info = "info-"+sentence; |
|
document.getElementById(info).innerHTML = ''+cc+' occurrences in corpus, '+tc+' distinct translations, translation entropy: '+te; |
|
$(info).setStyle({ opacity: 1 }); |
|
} |
|
function lowlight_phrase(sentence,phrase) { |
|
var input = "input-"+sentence+"-"+phrase; |
|
$(input).setStyle({ borderColor: 'black' }); |
|
var output = "output-"+sentence+"-"+phrase; |
|
$(output).setStyle({ borderColor: 'black' }); |
|
} |
|
function hide_word_info(sentence) { |
|
var info = "info-"+sentence; |
|
$(info).setStyle({ opacity: 0 }); |
|
} |
|
function show_biconcor(sentence,phrase) { |
|
var div = "biconcor-"+sentence; |
|
var url = '?analysis=biconcor' |
|
+ '&setup=<?php print $setup ?>&id=<?php print get_biconcor_version($dir,$set,$id); ?>&set=<?php print $set ?>' |
|
+ '&sentence=' + sentence |
|
+ '&phrase=' + encodeURIComponent(phrase); |
|
document.getElementById(div).innerHTML = "<center><img src=\"spinner.gif\" width=48 height=48></center>"; |
|
$(div).setStyle({ borderStyle: 'solid', 'border-width': '3px', borderColor: 'black' }); |
|
new Ajax.Updater(div, url, { method: 'get', evalScripts: true }); |
|
} |
|
function close_biconcor(sentence) { |
|
var div = "biconcor-"+sentence; |
|
document.getElementById(div).innerHTML = ""; |
|
$(div).setStyle({ borderStyle: 'none', 'border-width': '0px', borderColor: 'white' }); |
|
} |
|
|
|
</script> |
|
</head> |
|
<body> |
|
<div id="nGramSummary"><?php ngram_summary() ?></div> |
|
<div id="CoverageDetails"></div> |
|
<div id="PrecisionByCoverage"></div> |
|
<div id="PrecisionRecallDetails"></div> |
|
<div id="bleu">(loading...)</div> |
|
<script language="javascript"> |
|
show('bleu','',5,''); |
|
</script> |
|
</body></html> |
|
<?php |
|
} |
|
|
|
function precision_by_coverage() { |
|
global $experiment,$evalset,$dir,$set,$id; |
|
$img_width = 1000; |
|
|
|
print "<h3>Precision of Input Words by Coverage</h3>"; |
|
print "The graphs display what ratio of words of a specific type are translated correctly (yellow), and what ratio is deleted (blue)."; |
|
print " The extend of the boxes is scaled on the x-axis by the number of tokens of the displayed type."; |
|
|
|
|
|
$data = file(get_current_analysis_filename("precision","precision-by-corpus-coverage")); |
|
$total = 0; |
|
$log_info = array(); |
|
for($i=0;$i<count($data);$i++) { |
|
$item = split("\t",$data[$i]); |
|
$info[$item[0]]["precision"] = $item[1]; |
|
$info[$item[0]]["delete"] = $item[2]; |
|
$info[$item[0]]["length"] = $item[3]; |
|
$info[$item[0]]["total"] = $item[4]; |
|
$total += $item[4]; |
|
$log_count = -1; |
|
if ($item[0]>0) { |
|
$log_count = (int) (log($item[0])/log(2)); |
|
} |
|
if (!array_key_exists($log_count,$log_info)) { |
|
$log_info[$log_count]["precision"] = 0; |
|
$log_info[$log_count]["delete"] = 0; |
|
$log_info[$log_count]["length"] = 0; |
|
$log_info[$log_count]["total"] = 0; |
|
} |
|
$log_info[$log_count]["precision"] += $item[1]; |
|
$log_info[$log_count]["delete"] += $item[2]; |
|
$log_info[$log_count]["length"] += $item[3]; |
|
$log_info[$log_count]["total"] += $item[4]; |
|
} |
|
print "<h4>By log<sub>2</sub>-count in the training corpus</h4>"; |
|
precision_by_coverage_graph("byCoverage",$log_info,$total,$img_width,SORT_NUMERIC); |
|
|
|
|
|
$d = dir("$dir/evaluation/$set.analysis.".get_precision_analysis_version($dir,$set,$id)); |
|
while (false !== ($file = $d->read())) { |
|
if (preg_match('/precision-by-corpus-coverage.(.+)$/',$file, $match)) { |
|
precision_by_coverage_factored($img_width,$total,$file,$match[1]); |
|
} |
|
} |
|
} |
|
|
|
function precision_by_coverage_factored($img_width,$total,$file,$factor_id) { |
|
global $dir,$set,$id; |
|
$data = file(get_current_analysis_filename("precision",$file)); |
|
for($i=0;$i<count($data);$i++) { |
|
$item = split("\t",$data[$i]); |
|
$factor = $item[0]; |
|
$count = $item[1]; |
|
$info_factored[$factor][$count]["precision"] = $item[2]; |
|
$info_factored[$factor][$count]["delete"] = $item[3]; |
|
$info_factored[$factor][$count]["length"] = $item[4]; |
|
$info_factored[$factor][$count]["total"] = $item[5]; |
|
$info_factored_sum[$factor]["precision"] += $item[2]; |
|
$info_factored_sum[$factor]["delete"] += $item[3]; |
|
$info_factored_sum[$factor]["length"] += $item[4]; |
|
$info_factored_sum[$factor]["total"] += $item[5]; |
|
$total_factored[$factor] += $item[5]; |
|
$log_count = -1; |
|
if ($count>0) { |
|
$log_count = (int) (log($count)/log(2)); |
|
} |
|
$log_info_factored[$factor][$log_count]["precision"] += $item[2]; |
|
$log_info_factored[$factor][$log_count]["delete"] += $item[3]; |
|
$log_info_factored[$factor][$log_count]["length"] += $item[4]; |
|
$log_info_factored[$factor][$log_count]["total"] += $item[5]; |
|
} |
|
print "<h4>By factor ".factor_name("input",$factor_id)."</h4>"; |
|
precision_by_coverage_graph("byFactor",$info_factored_sum,$total,$img_width,SORT_STRING); |
|
|
|
print "<h4>For each factor, by log<sub>2</sub>-count in the corpus</h4>"; |
|
foreach ($log_info_factored as $factor => $info) { |
|
if ($total_factored[$factor]/$total > 0.01) { |
|
print "<table style=\"display:inline;\"><tr><td align=center><font size=-2><b>$factor</b></font></td></tr><tr><td align=center>"; |
|
precision_by_coverage_graph("byCoverageFactor$factor",$info,$total_factored[$factor],10+2*$img_width*$total_factored[$factor]/$total,SORT_NUMERIC); |
|
print "</td></tr></table>"; |
|
} |
|
} |
|
} |
|
|
|
function precision_by_word($type) { |
|
global $dir,$set,$id; |
|
$byCoverage = -2; |
|
$byFactor = "false"; |
|
if ($type == "byCoverage") { |
|
$byCoverage = (int) $_GET["type"]; |
|
} |
|
else if ($type == "byFactor") { |
|
$byFactor = $_GET["type"]; |
|
} |
|
else if (preg_match("/byCoverageFactor(.+)/",$type,$match)) { |
|
$byCoverage = (int) $_GET["type"]; |
|
$byFactor = $match[1]; |
|
} |
|
|
|
$data = file(get_current_analysis_filename("precision","precision-by-input-word")); |
|
for($i=0;$i<count($data);$i++) { |
|
$line = rtrim($data[$i]); |
|
$item = split("\t",$line); |
|
|
|
|
|
$count = $item[4]; |
|
$log_count = -1; |
|
if ($count>0) { |
|
$log_count = (int) (log($count)/log(2)); |
|
} |
|
if ($byCoverage != -2 && $byCoverage != $log_count) { |
|
continue; |
|
} |
|
|
|
|
|
$word = $item[5]; |
|
if ($byFactor != "false" && $byFactor != $item[6]) { |
|
continue; |
|
} |
|
|
|
$info[$word]["precision"] = $item[0]; |
|
$info[$word]["delete"] = $item[1]; |
|
$info[$word]["length"] = $item[2]; |
|
$info[$word]["total"] = $item[3]; |
|
$total += $item[3]; |
|
} |
|
|
|
print "<table border=1><tr><td align=center>Count</td><td align=center colspan=2>Precision</td><td align=center colspan=2>Delete</td><td align=center>Length</td></tr>\n"; |
|
foreach ($info as $word => $wordinfo) { |
|
print "<tr><td align=center><a href=\"javascript:show('bleu','order',5,'".base64_encode($word)."')\">$word</a></td>"; |
|
printf("<td align=right>%.1f%s</td><td align=right><font size=-1>%.1f/%d</font></td>",$wordinfo["precision"]/$wordinfo["total"]*100,"%",$wordinfo["precision"],$wordinfo["total"]); |
|
printf("<td align=right>%.1f%s</td><td align=right><font size=-1>%d/%d</font></td>",$wordinfo["delete"]/$wordinfo["total"]*100,"%",$wordinfo["delete"],$wordinfo["total"]); |
|
printf("<td align=right>%.3f</td>",$wordinfo["length"]/$wordinfo["total"]); |
|
print "</tr>"; |
|
} |
|
print "</table>\n"; |
|
} |
|
|
|
function precision_by_coverage_latex($name,$log_info,$total,$img_width,$sort_type) { |
|
$keys = array_keys($log_info); |
|
sort($keys,$sort_type); |
|
|
|
$img_width /= 100; |
|
print "<div id=\"LatexToggle$name\" onClick=\"document.getElementById('Latex$name').style.display = 'block'; this.style.display = 'none';\" style=\"display:none;\"><font size=-2>(show LaTeX)</font></div>\n"; |
|
print "<div id=\"Latex$name\" style=\"display:none;\">\n"; |
|
print "<code>\\begin{tikzpicture}<br>"; |
|
|
|
print "% co-ordinates for precision<br>"; |
|
for($line=0;$line<=9;$line++) { |
|
$height = 1.8-$line/10*1.8; |
|
print "\\draw[thin,lightgray] (0.2,-$height) "; |
|
print "node[anchor=east,black] {".$line."0\\%} -- "; |
|
print "($img_width,-$height) ;<br>\n"; |
|
} |
|
print "% co-ordinates for deletion<br>\n"; |
|
for($line=0;$line<=3;$line++) { |
|
$height = 2+$line/10*1.80; |
|
print "\\draw[thin,lightgray] (0.2,-$height) "; |
|
if ($line != 0) { |
|
print "node[anchor=east,black] {".$line."0\\%} "; |
|
} |
|
print "-- ($img_width,-$height) ;<br>\n"; |
|
} |
|
|
|
print "% boxes<br>\n"; |
|
$total_so_far = 0; |
|
foreach ($keys as $i) { |
|
$prec_ratio = $log_info[$i]["precision"]/$log_info[$i]["total"]; |
|
$x = .2+($img_width-.2) * $total_so_far/$total; |
|
$y = 1.80-($prec_ratio*1.80); |
|
$width = $img_width * $log_info[$i]["total"]/$total; |
|
$height = $prec_ratio*1.80; |
|
|
|
$width += $x; |
|
$height += $y; |
|
|
|
print "\\filldraw[very thin,gray] ($x,-$y) rectangle($width,-$height) ;<br>"; |
|
print "\\draw[very thin,black] ($x,-$y) rectangle($width,-$height);<br>"; |
|
if ($width-$x>.1) { |
|
print "\\draw (".(($x+$width)/2).",-1.8) node[anchor=north,black] {".$i."};<br>"; |
|
} |
|
|
|
|
|
$del_ratio = $log_info[$i]["delete"]/$log_info[$i]["total"]; |
|
$height = $del_ratio*1.80; |
|
|
|
$height += 2; |
|
|
|
print "\\filldraw[very thin,lightgray] ($x,-2) rectangle($width,-$height);<br>\n"; |
|
print "\\draw[very thin,black] ($x,-2) rectangle($width,-$height);<br>\n"; |
|
|
|
$total_so_far += $log_info[$i]["total"]; |
|
} |
|
print "\\end{tikzpicture}</code>"; |
|
print "</div>"; |
|
} |
|
|
|
function precision_by_coverage_graph($name,$log_info,$total,$img_width,$sort_type) { |
|
|
|
$keys = array_keys($log_info); |
|
sort($keys,$sort_type); |
|
|
|
print "<div id=\"Toggle$name\" onClick=\"document.getElementById('Table$name').style.display = 'none'; document.getElementById('LatexToggle$name').style.display = 'none'; document.getElementById('Latex$name').style.display = 'none'; this.style.display = 'none';\" style=\"display:none;\"><font size=-2>(hide table)</font></div>\n"; |
|
precision_by_coverage_latex($name,$log_info,$total,$img_width,$sort_type); |
|
|
|
print "<div id=\"Table$name\" style=\"display:none;\">\n"; |
|
print "<table border=1><tr><td align=center>Count</td><td align=center colspan=2>Precision</td><td align=center colspan=2>Delete</td><td align=center>Length</td></tr>\n"; |
|
foreach ($keys as $i) { |
|
if (array_key_exists($i,$log_info)) { |
|
print "<tr><td align=center>$i</td>"; |
|
printf("<td align=right>%.1f%s</td><td align=right><font size=-1>%.1f/%d</font></td>",$log_info[$i]["precision"]/$log_info[$i]["total"]*100,"%",$log_info[$i]["precision"],$log_info[$i]["total"]); |
|
printf("<td align=right>%.1f%s</td><td align=right><font size=-1>%d/%d</font></td>",$log_info[$i]["delete"]/$log_info[$i]["total"]*100,"%",$log_info[$i]["delete"],$log_info[$i]["total"]); |
|
printf("<td align=right>%.3f</td>",$log_info[$i]["length"]/$log_info[$i]["total"]); |
|
print "<td><A HREF=\"javascript:generic_show('PrecisionByWord$name','type=$i')\">Ⓘ</A></td>"; |
|
print "</tr>"; |
|
} |
|
} |
|
print "</table><div id=\"PrecisionByWord$name\"></div></div>"; |
|
|
|
print "<div id=\"Graph$name\" onClick=\"document.getElementById('Table$name').style.display = 'block'; document.getElementById('LatexToggle$name').style.display = 'block'; document.getElementById('Toggle$name').style.display = 'block';\">"; |
|
print "<canvas id=\"$name\" width=$img_width height=300></canvas></div>"; |
|
print "<script language=\"javascript\"> |
|
var canvas = document.getElementById(\"$name\"); |
|
var ctx = canvas.getContext(\"2d\"); |
|
ctx.lineWidth = 0.5; |
|
ctx.font = '9px serif'; |
|
"; |
|
for($line=0;$line<=9;$line++) { |
|
$height = 180-$line/10*180; |
|
print "ctx.moveTo(20, $height);\n"; |
|
print "ctx.lineTo($img_width, $height);\n"; |
|
if ($line != 0) { |
|
print "ctx.fillText(\"${line}0\%\", 0, $height+4);"; |
|
} |
|
} |
|
for($line=0;$line<=3;$line++) { |
|
$height = 200+$line/10*180; |
|
print "ctx.moveTo(20, $height);\n"; |
|
print "ctx.lineTo($img_width, $height);\n"; |
|
if ($line != 0) { |
|
print "ctx.fillText(\"${line}0\%\", 0, $height+4);"; |
|
} |
|
} |
|
print "ctx.strokeStyle = \"rgb(100,100,100)\"; ctx.stroke();\n"; |
|
|
|
$total_so_far = 0; |
|
foreach ($keys as $i) { |
|
$prec_ratio = $log_info[$i]["precision"]/$log_info[$i]["total"]; |
|
$x = (int)(20+($img_width-20) * $total_so_far / $total); |
|
$y = (int)(180-($prec_ratio*180)); |
|
$width = (int)($img_width * $log_info[$i]["total"]/$total); |
|
$height = (int)($prec_ratio*180); |
|
print "ctx.fillStyle = \"rgb(200,200,0)\";"; |
|
print "ctx.fillRect ($x, $y, $width, $height);"; |
|
|
|
$del_ratio = $log_info[$i]["delete"]/$log_info[$i]["total"]; |
|
$height = (int)($del_ratio*180); |
|
print "ctx.fillStyle = \"rgb(100,100,255)\";"; |
|
print "ctx.fillRect ($x, 200, $width, $height);"; |
|
|
|
$total_so_far += $log_info[$i]["total"]; |
|
|
|
if ($width>3) { |
|
print "ctx.fillStyle = \"rgb(0,0,0)\";"; |
|
|
|
print "ctx.fillText(\"$i\", $x+$width/2-3, 190);"; |
|
|
|
} |
|
} |
|
print "</script>"; |
|
} |
|
|
|
|
|
function precision_recall_details() { |
|
?> |
|
<table width=100%> |
|
<tr> |
|
<td width=25% valign=top><div id="nGramPrecision1">(loading...)</div></td> |
|
<td width=25% valign=top><div id="nGramPrecision2">(loading...)</div></td> |
|
<td width=25% valign=top><div id="nGramPrecision3">(loading...)</div></td> |
|
<td width=25% valign=top><div id="nGramPrecision4">(loading...)</div></td> |
|
</tr><tr> |
|
<td width=25% valign=top><div id="nGramRecall1">(loading...)</div></td> |
|
<td width=25% valign=top><div id="nGramRecall2">(loading...)</div></td> |
|
<td width=25% valign=top><div id="nGramRecall3">(loading...)</div></td> |
|
<td width=25% valign=top><div id="nGramRecall4">(loading...)</div></td> |
|
</tr></table> |
|
<script language="javascript"> |
|
ngram_show('precision',1,5,'',0); |
|
ngram_show('precision',2,5,'',0); |
|
ngram_show('precision',3,5,'',0); |
|
ngram_show('precision',4,5,'',0); |
|
ngram_show('recall',1,5,'',0); |
|
ngram_show('recall',2,5,'',0); |
|
ngram_show('recall',3,5,'',0); |
|
ngram_show('recall',4,5,'',0); |
|
</script> |
|
<?php |
|
} |
|
|
|
|
|
function ngram_summary() { |
|
global $experiment,$evalset,$dir,$set,$id; |
|
|
|
|
|
$data = file(get_current_analysis_filename("basic","summary")); |
|
for($i=0;$i<count($data);$i++) { |
|
$item = split(": ",$data[$i]); |
|
$info[$item[0]] = $item[1]; |
|
} |
|
|
|
print "<table cellspacing=5 width=100%><tr><td valign=top align=center bgcolor=#eeeeee>"; |
|
|
|
print "<b>Precision of Output</b>\n"; |
|
$type = "precision"; |
|
print "<table><tr><td>$type</td><td>1-gram</td><td>2-gram</td><td>3-gram</td><td>4-gram</td></tr>\n"; |
|
printf("<tr><td>correct</td><td>%d</td><td>%d</td><td>%d</td><td>%d</td></tr>\n", |
|
$info["$type-1-correct"], |
|
$info["$type-2-correct"], |
|
$info["$type-3-correct"], |
|
$info["$type-4-correct"]); |
|
printf("<tr><td> </td><td>%.1f%s</td><td>%.1f%s</td><td>%.1f%s</td><td>%.1f%s</td></tr>\n", |
|
$info["$type-1-correct"]/$info["$type-1-total"]*100,'%', |
|
$info["$type-2-correct"]/$info["$type-2-total"]*100,'%', |
|
$info["$type-3-correct"]/$info["$type-3-total"]*100,'%', |
|
$info["$type-4-correct"]/$info["$type-4-total"]*100,'%'); |
|
printf("<tr><td>wrong</td><td>%d</td><td>%d</td><td>%d</td><td>%d</td></tr>\n", |
|
$info["$type-1-total"]-$info["$type-1-correct"], |
|
$info["$type-2-total"]-$info["$type-2-correct"], |
|
$info["$type-3-total"]-$info["$type-3-correct"], |
|
$info["$type-4-total"]-$info["$type-4-correct"]); |
|
print "</table>"; |
|
|
|
|
|
print "<A HREF=\"javascript:generic_show('PrecisionRecallDetails','')\">details</A> "; |
|
if (file_exists(get_current_analysis_filename("precision","precision-by-corpus-coverage"))) { |
|
print "| <A HREF=\"javascript:generic_show('PrecisionByCoverage','')\">precision of input by coverage</A> "; |
|
} |
|
|
|
print "</td><td valign=top valign=top align=center bgcolor=#eeeeee>"; |
|
|
|
$each_score = explode(" ; ",$experiment[$id]->result[$set]); |
|
$header = ""; |
|
$score_line = ""; |
|
for($i=0;$i<count($each_score);$i++) { |
|
if (preg_match('/([\d\(\)\.\s]+) (BLEU[\-c]*)/',$each_score[$i],$match) || |
|
preg_match('/([\d\(\)\.\s]+) (IBM[\-c]*)/',$each_score[$i],$match) || |
|
preg_match('/([\d\(\)\.\s]+) (METEOR[\-c]*)/',$each_score[$i],$match)) { |
|
$header .= "<td>$match[2]</td>"; |
|
$score_line .= "<td>$match[1]</td>"; |
|
} |
|
} |
|
print "<b>Metrics</b><table border=1><tr>".$header."</tr><tr>".$score_line."</tr></table>"; |
|
|
|
printf("<p>length-diff: %d (%.1f%s)",$info["precision-1-total"]-$info["recall-1-total"],($info["precision-1-total"]-$info["recall-1-total"])/$info["recall-1-total"]*100,"%"); |
|
|
|
|
|
if (file_exists(get_current_analysis_filename("coverage","corpus-coverage-summary"))) { |
|
print "</td><td valign=top align=center bgcolor=#eeeeee>"; |
|
print "<div id=\"CoverageSummary\">"; |
|
coverage_summary(); |
|
print "</div>"; |
|
} |
|
|
|
|
|
if (file_exists(get_current_analysis_filename("basic","segmentation")) || |
|
file_exists(get_current_analysis_filename("basic","rule"))) { |
|
print "</td><td valign=top align=center bgcolor=#eeeeee>"; |
|
print "<div id=\"SegmentationSummary\">"; |
|
segmentation_summary(); |
|
print "</div>"; |
|
} |
|
|
|
|
|
if (file_exists(get_current_analysis_filename("basic","rule"))) { |
|
print "</td><td valign=top align=center bgcolor=#eeeeee>"; |
|
print "<div id=\"RuleSummary\">"; |
|
rule_summary(); |
|
print "</div>"; |
|
} |
|
|
|
print "</td></tr></table>"; |
|
} |
|
|
|
|
|
function ngram_show($type) { |
|
global $set,$id,$dir; |
|
|
|
|
|
$order = $_GET['order']; |
|
$data = file(get_current_analysis_filename("basic","n-gram-$type.$order")); |
|
for($i=0;$i<count($data);$i++) { |
|
$item = split("\t",$data[$i]); |
|
$line["total"] = $item[0]; |
|
$line["correct"] = $item[1]; |
|
$line["ngram"] = $item[2]; |
|
$ngram[] = $line; |
|
} |
|
|
|
|
|
$sort = $_GET['sort']; |
|
$smooth = $_GET['smooth']; |
|
if ($sort == '') { |
|
$sort = 'ratio_worst'; |
|
$smooth = 1; |
|
} |
|
|
|
|
|
for($i=0;$i<count($ngram);$i++) { |
|
if ($sort == "abs_worst") { |
|
$ngram[$i]["index"] = $ngram[$i]["correct"] - $ngram[$i]["total"]; |
|
} |
|
else if ($sort == "ratio_worst") { |
|
$ngram[$i]["index"] = ($ngram[$i]["correct"] + $smooth) / ($ngram[$i]["total"] + $smooth); |
|
} |
|
} |
|
|
|
|
|
function cmp($a, $b) { |
|
if ($a["index"] == $b["index"]) { |
|
return 0; |
|
} |
|
return ($a["index"] < $b["index"]) ? -1 : 1; |
|
} |
|
|
|
usort($ngram, 'cmp'); |
|
|
|
|
|
$count = $_GET['count']; |
|
if ($count == 0) { $count = 5; } |
|
|
|
print "<B>$order-gram $type</B><br><font size=-1>sorted by "; |
|
if ($sort == "ratio_worst") { |
|
print "ratio "; |
|
print "smooth-$smooth "; |
|
print "<A HREF=\"javascript:ngram_show('$type',$order,$count,'ratio_worst',$smooth+1)\">+</A> "; |
|
print "<A HREF=\"javascript:ngram_show('$type',$order,$count,'ratio_worst',$smooth-1)\">-</A> "; |
|
} |
|
else { |
|
print "<A HREF=\"javascript:ngram_show('$type',$order,$count,'ratio_worst',1)\">ratio</A> "; |
|
} |
|
if ($sort == "abs_worst") { |
|
print "absolute "; |
|
} |
|
else { |
|
print "<A HREF=\"javascript:ngram_show('$type',$order,$count,'abs_worst',0)\">absolute</A> "; |
|
} |
|
print "showing $count "; |
|
if ($count < 9999) { |
|
print "<A HREF=\"javascript:ngram_show('$type',$order,$count+5,'$sort',$smooth)\">more</A> "; |
|
print "<A HREF=\"javascript:ngram_show('$type',$order,9999,'$sort',$smooth)\">all</A> "; |
|
} |
|
else { |
|
print "<A HREF=\"javascript:ngram_show('$type',$order,5,'$sort',$smooth)\">top5</A> "; |
|
} |
|
print "</font><br>\n"; |
|
|
|
print "<table width=100%>\n"; |
|
print "<tr><td>$order-gram</td><td>ok</td><td>x</td><td>ratio</td></tr>\n"; |
|
for($i=0;$i<$count && $i<count($ngram);$i++) { |
|
$line = $ngram[$i]; |
|
print "<tr><td>".$line["ngram"]."</td>"; |
|
print "<td>".$line["correct"]."</td>"; |
|
print "<td>".($line["total"]-$line["correct"])."</td>"; |
|
printf("<td>%.3f</td></tr>",$line["correct"]/$line["total"]); |
|
} |
|
print "</table>\n"; |
|
} |
|
|
|
|
|
function coverage_details() { |
|
global $dir,$set,$id; |
|
|
|
$count = array(); $token = array(); |
|
foreach (array("ttable","corpus") as $corpus) { |
|
foreach (array("token","type") as $b) { |
|
for($i=0;$i<=7;$i++) { |
|
foreach (array("6+","2-5","1","0") as $range) { |
|
$count[$corpus][$b][$i][$range] = 0; |
|
} |
|
$total[$corpus][$b][$i] = 0; |
|
} |
|
} |
|
$data = file(filename_fallback_to_factored(get_current_analysis_filename("coverage","$corpus-coverage-summary"))); |
|
for($i=0;$i<count($data);$i++) { |
|
$item = split("\t",$data[$i]); |
|
if ($item[1]>5) { |
|
$count[$corpus]["type"][$item[0]]["6+"] += $item[2]; |
|
$count[$corpus]["token"][$item[0]]["6+"] += $item[3]; |
|
} |
|
else if ($item[1]>1) { |
|
$count[$corpus]["type"][$item[0]]["2-5"] += $item[2]; |
|
$count[$corpus]["token"][$item[0]]["2-5"] += $item[3]; |
|
} |
|
else if ($item[1]==1) { |
|
$count[$corpus]["type"][$item[0]]["1"] += $item[2]; |
|
$count[$corpus]["token"][$item[0]]["1"] += $item[3]; |
|
} |
|
else { |
|
$count[$corpus]["type"][$item[0]]["0"] += $item[2]; |
|
$count[$corpus]["token"][$item[0]]["0"] += $item[3]; |
|
} |
|
$total[$corpus]["type"][$item[0]] += $item[2]; |
|
$total[$corpus]["token"][$item[0]] += $item[3]; |
|
} |
|
} |
|
print "<b>coverage</b><br>\n"; |
|
print "<table width=100%><tr>"; |
|
foreach (array("token","type") as $by) { |
|
for($i=1;$i<=4;$i++) { |
|
print "<td align=center><b>$i-gram ($by)</b><br>\n"; |
|
print "<table><tr><td></td><td>model</td><td>corpus</td></tr>\n"; |
|
foreach (array("0","1","2-5","6+") as $range) { |
|
print "<tr><td>$range</td>"; |
|
foreach (array("ttable","corpus") as $corpus) { |
|
printf("<td align=right nowrap>%d (%.1f%s)</td>",$count[$corpus][$by][$i][$range],100*$count[$corpus][$by][$i][$range]/($total[$corpus][$by][$i]+0.0001),"%"); |
|
} |
|
print "</tr>\n"; |
|
} |
|
print "</table></td>\n"; |
|
} |
|
print "</tr><tr>"; |
|
} |
|
print "</tr></table>\n"; |
|
|
|
$data = file(filename_fallback_to_factored(get_current_analysis_filename("coverage","ttable-unknown"))); |
|
for($i=0;$i<count($data);$i++) { |
|
list($word,$count) = split("\t",$data[$i]); |
|
$item["word"] = $word; |
|
$item["count"] = rtrim($count); |
|
$unknown[] = $item; |
|
} |
|
|
|
function cmp($a,$b) { |
|
if ($a["count"] > $b["count"]) { |
|
return -1; |
|
} |
|
else if ($a["count"] < $b["count"]) { |
|
return 1; |
|
} |
|
else { |
|
return strcmp($a["word"],$b["word"]); |
|
} |
|
} |
|
|
|
usort($unknown, 'cmp'); |
|
|
|
print "<b>unknown words (to model)</b><br>\n"; |
|
print "<table><tr><td valign=top><table>"; |
|
$state = 5; |
|
foreach ($unknown as $item) { |
|
if ($item["count"] < $state) { |
|
if ($state == 5) { print "</table>"; } |
|
print "</td><td valign=top><b>".$item["count"].":</b> "; |
|
$state = $item["count"]; |
|
if ($state == 1) { print "<font size=-1>"; } |
|
} |
|
else if ($state<5) { |
|
print ", "; |
|
} |
|
if ($state == 5) { |
|
print "<tr><td>".$item["count"]."</td><td>".$item["word"]."</td></tr>"; |
|
} |
|
else { |
|
print $item["word"]; |
|
} |
|
} |
|
print "</font></td></tr></table>\n"; |
|
} |
|
|
|
function filename_fallback_to_factored($file) { |
|
if (file_exists($file)) { |
|
return $file; |
|
} |
|
$path = pathinfo($file); |
|
$dh = opendir($path['dirname']); |
|
while (($factored_file = readdir($dh)) !== false) { |
|
if (strlen($factored_file) > strlen($path['basename']) && |
|
substr($factored_file,0,strlen($path['basename'])) == $path['basename'] && |
|
preg_match("/0/",substr($factored_file,strlen($path['basename'])))) { |
|
return $path['dirname']."/".$factored_file; |
|
} |
|
} |
|
|
|
return $file; |
|
} |
|
|
|
function factor_name($input_output,$factor_id) { |
|
global $dir,$set,$id; |
|
$file = get_current_analysis_filename("coverage","factor-names"); |
|
if (!file_exists($file)) { |
|
return $factor_id; |
|
} |
|
$in_out_names = file($file); |
|
$names = explode(",",trim($in_out_names[($input_output == "input")?0:1])); |
|
return "'".$names[$factor_id]."' ($factor_id)"; |
|
} |
|
|
|
|
|
function coverage_summary() { |
|
global $dir,$set,$id,$corpus; |
|
|
|
if (array_key_exists("by",$_GET)) { $by = $_GET['by']; } |
|
else { $by = 'token'; } |
|
|
|
$total = array(); $count = array(); |
|
foreach (array("ttable","corpus") as $corpus) { |
|
foreach (array("token","type") as $b) { |
|
foreach (array("6+","2-5","1","0") as $c) { |
|
$count[$corpus][$b][$c] = 0; |
|
} |
|
$total[$corpus][$b] = 0; |
|
} |
|
$data = file(filename_fallback_to_factored(get_current_analysis_filename("coverage","$corpus-coverage-summary"))); |
|
for($i=0;$i<count($data);$i++) { |
|
$item = split("\t",$data[$i]); |
|
if ($item[0] == 1) { |
|
if ($item[1]>5) { |
|
$count[$corpus]["type"]["6+"] += $item[2]; |
|
$count[$corpus]["token"]["6+"] += $item[3]; |
|
} |
|
else if ($item[1]>1) { |
|
$count[$corpus]["type"]["2-5"] += $item[2]; |
|
$count[$corpus]["token"]["2-5"] += $item[3]; |
|
} |
|
else if ($item[1]==1) { |
|
$count[$corpus]["type"]["1"] += $item[2]; |
|
$count[$corpus]["token"]["1"] += $item[3]; |
|
} |
|
else { |
|
$count[$corpus]["type"]["0"] += $item[2]; |
|
$count[$corpus]["token"]["0"] += $item[3]; |
|
} |
|
$total[$corpus]["type"] += $item[2]; |
|
$total[$corpus]["token"] += $item[3]; |
|
} |
|
} |
|
} |
|
|
|
print "<b>Coverage</b>\n"; |
|
print "<table><tr><td></td><td>model</td><td>corpus</td></tr>\n"; |
|
foreach (array("0","1","2-5","6+") as $range) { |
|
print "<tr><td>$range</td>"; |
|
foreach (array("ttable","corpus") as $corpus) { |
|
printf("<td align=right nowrap>%d (%.1f%s)</td>",$count[$corpus][$by][$range],100*$count[$corpus][$by][$range]/($total[$corpus][$by]+0.0001),"%"); |
|
} |
|
print "</tr>\n"; |
|
} |
|
print "</table>\n"; |
|
if ($by == 'token') { print "by token"; } else { |
|
print "<A HREF=\"javascript:generic_show('CoverageSummary','by=token')\">by token</A> "; |
|
} |
|
print " / "; |
|
if ($by == 'type') { print "by type"; } else { |
|
print "<A HREF=\"javascript:generic_show('CoverageSummary','by=type')\">by type</A> "; |
|
} |
|
print " / "; |
|
print "<div id=\"CoverageDetailsLink\"><A HREF=\"javascript:generic_show('CoverageDetails','')\">details</A></div> "; |
|
} |
|
|
|
|
|
|
|
function segmentation_summary() { |
|
global $dir,$set,$id; |
|
|
|
if (array_key_exists("by",$_GET)) { $by = $_GET['by']; } |
|
else { $by = 'word'; } |
|
|
|
$count = array(); |
|
for($i=0;$i<=4;$i++) { |
|
$count[$i] = array(); |
|
for($j=0;$j<=4;$j++) { |
|
$count[$i][$j] = 0; |
|
} |
|
} |
|
|
|
$total = 0; |
|
$file = get_current_analysis_filename("basic","segmentation"); |
|
if (file_exists($file)) { |
|
$data = file($file); |
|
for($i=0;$i<count($data);$i++) { |
|
list($in,$out,$c) = split("\t",$data[$i]); |
|
if ($by == "word") { $c *= $in; } |
|
if ($in>4) { $in = 4; } |
|
if ($out>4) { $out = 4; } |
|
$total += $c; |
|
$count[$in][$out] += $c; |
|
} |
|
} |
|
else { |
|
$data = file(get_current_analysis_filename("basic","rule")); |
|
for($i=0;$i<count($data);$i++) { |
|
$field = split("\t",$data[$i]); |
|
$type = $field[0]; |
|
$rule = $field[1]; |
|
if (count($field) > 2) { $c = $field[2]; } else { $c = 0; } |
|
if ($type == "rule") { |
|
list($rule_in,$in,$nt,$rule_out,$out) = split(":",$rule); |
|
if ($by == "word") { $c *= $in; } |
|
if ($in>4) { $in = 4; } |
|
if ($out>4) { $out = 4; } |
|
$total += $c; |
|
$count[$in][$out] += $c; |
|
} |
|
} |
|
} |
|
|
|
print "<b>Phrase Segmentation</b><br>\n"; |
|
print "<table>"; |
|
print "<tr><td></td><td align=center>1</td><td align=center>2</td><td align=center>3</td><td align=center>4+</td></tr>"; |
|
for($in=1;$in<=4;$in++) { |
|
print "<tr><td nowrap>$in".($in==4?"+":"")." to</td>"; |
|
for($out=1;$out<=4;$out++) { |
|
if (array_key_exists($in,$count) && |
|
array_key_exists($out,$count[$in])) { |
|
$c = $count[$in][$out]; |
|
} |
|
else { $c = 0; } |
|
printf("<td align=right nowrap>%d (%.1f%s)</td>",$c,100*$c/$total,"%"); |
|
} |
|
print "</tr>"; |
|
} |
|
print "</table>\n"; |
|
if ($by == 'word') { print "by word"; } else { |
|
print "<A HREF=\"javascript:generic_show('SegmentationSummary','by=word')\">by word</A> "; |
|
} |
|
print " / "; |
|
if ($by == 'phrase') { print "by phrase"; } else { |
|
print "<A HREF=\"javascript:generic_show('SegmentationSummary','by=phrase')\">by phrase</A> "; |
|
} |
|
} |
|
|
|
|
|
function rule_summary() { |
|
global $dir,$set,$id; |
|
$data = file(get_current_analysis_filename("basic","rule")); |
|
$rule = array(); $count = array(); $count_nt = array(); $count_w = array(); |
|
$nt_count = 0; $total = 0; |
|
foreach ($data as $item) { |
|
$field = split("\t",$item); |
|
$type = $field[0]; |
|
$d = $field[1]; |
|
if (count($field) > 2) { $d2 = $field[2]; } else { $d2 = 0; } |
|
if ($type == "sentence-count") { |
|
$sentence_count = $d; |
|
} |
|
else if ($type == "glue-rule") { |
|
$glue_rule = $d / $sentence_count; |
|
} |
|
else if ($type == "depth") { |
|
$depth = $d / $sentence_count; |
|
} |
|
else { |
|
list($rule_in,$word_in,$nt,$rule_out,$word_out) = split(":",$d); |
|
$rule_in = preg_replace("/a/","x",$rule_in); |
|
$rule_in = preg_replace("/b/","y",$rule_in); |
|
$rule_in = preg_replace("/c/","z",$rule_in); |
|
$rule_out = preg_replace("/a/","x",$rule_out); |
|
$rule_out = preg_replace("/b/","y",$rule_out); |
|
$rule_out = preg_replace("/c/","z",$rule_out); |
|
$nt_count += $d2 * $nt; |
|
if (!array_key_exists($d,$rule)) { $rule[$d] = 0; } |
|
$rule[$d] += $d2; |
|
if (!array_key_exists($nt,$count)) { $count[$nt] = 0; } |
|
$count[$nt] += $d2; |
|
$just_nt = preg_replace("/\d/","",$rule_in)."-".preg_replace("/\d/","",$rule_out); |
|
$no_wc = preg_replace("/\d/","W",$rule_in)."-".preg_replace("/\d/","",$rule_out); |
|
if ($just_nt == "-") { $just_nt = "lexical"; } |
|
if (!array_key_exists($just_nt,$count_nt)) { $count_nt[$just_nt] = 0; } |
|
$count_nt[$just_nt] += $d2; |
|
if (!array_key_exists($no_wc,$count_w)) { $count_w[$no_wc] = 0; } |
|
$count_w[$no_wc] += $d2; |
|
$total += $d2; |
|
} |
|
} |
|
print "<b>Rules</b><br>\n"; |
|
printf("glue rule: %.2f<br>\n",$glue_rule); |
|
printf("tree depth: %.2f<br>\n",$depth); |
|
printf("nt/rule: %.2f<br>\n",$nt_count/$total); |
|
print "<table>\n"; |
|
arsort($count_nt); |
|
$i=0; |
|
foreach ($count_nt as $rule => $count) { |
|
if ($i++ < 5) { printf("<tr><td>%s</td><td align=right>%d</td><td align=right>%.1f%s</td></tr>\n",$rule,$count,$count/$total*100,'%'); } |
|
} |
|
if (count($count_nt)>5) { print "<tr><td align=center>...</td><td align=center>...</td><td align=center>...</td></tr>\n"; } |
|
print "</table>\n"; |
|
} |
|
|
|
|
|
function bleu_show() { |
|
|
|
$count = $_GET['count']; |
|
if ($count == 0) { $count = 5; } |
|
|
|
$filter = ""; |
|
if (array_key_exists("filter",$_GET)) { |
|
$filter = base64_decode($_GET['filter']); |
|
} |
|
|
|
print "<b>annotated sentences</b><br><font size=-1>sorted by: "; |
|
|
|
if ($_GET['sort'] == "order" || $_GET['sort'] == "") { print "order "; } |
|
else { |
|
print "<A HREF=\"javascript:show('bleu','order',$count,'".base64_encode($filter)."')\">order</A> "; |
|
} |
|
if ($_GET['sort'] == "best") { print "best "; } |
|
else { |
|
print "<A HREF=\"javascript:show('bleu','best',$count,'".base64_encode($filter)."')\">best</A> "; |
|
} |
|
if ($_GET['sort'] == "25") { print "25% "; } |
|
else { |
|
print "<A HREF=\"javascript:show('bleu','25',$count,'".base64_encode($filter)."')\">25%</A> "; |
|
} |
|
if ($_GET['sort'] == "avg") { print "avg "; } |
|
else { |
|
print "<A HREF=\"javascript:show('bleu','avg',$count,'".base64_encode($filter)."')\">avg</A> "; |
|
} |
|
if ($_GET['sort'] == "75") { print "75% "; } |
|
else { |
|
print "<A HREF=\"javascript:show('bleu','75',$count,'".base64_encode($filter)."')\">75%</A> "; |
|
} |
|
if ($_GET['sort'] == "worst") { print "worst; "; } |
|
else { |
|
print "<A HREF=\"javascript:show('bleu','worst',$count,'".base64_encode($filter)."')\">worst</A>; "; |
|
} |
|
|
|
print "showing: $count "; |
|
print "<A HREF=\"javascript:show('bleu','" . $_GET['sort'] . "',5+$count,'".base64_encode($filter)."')\">more</A> "; |
|
print "<A HREF=\"javascript:show('bleu','" . $_GET['sort'] . "',9999,'".base64_encode($filter)."')\">all</A>"; |
|
|
|
if ($filter != "") { |
|
print "; filter: '$filter'"; |
|
} |
|
|
|
sentence_annotation($count,$filter); |
|
print "<p align=center><A HREF=\"javascript:show('bleu','" . $_GET['sort'] . "',5+$count,'".base64_encode($filter)."')\">5 more</A> | "; |
|
print "<A HREF=\"javascript:show('bleu','" . $_GET['sort'] . "',10+$count,'".base64_encode($filter)."')\">10 more</A> | "; |
|
print "<A HREF=\"javascript:show('bleu','" . $_GET['sort'] . "',20+$count,'".base64_encode($filter)."')\">20 more</A> | "; |
|
print "<A HREF=\"javascript:show('bleu','" . $_GET['sort'] . "',50+$count,'".base64_encode($filter)."')\">50 more</A> | "; |
|
print "<A HREF=\"javascript:show('bleu','" . $_GET['sort'] . "',100+$count,'".base64_encode($filter)."')\">100 more</A> | "; |
|
print "<A HREF=\"javascript:show('bleu','" . $_GET['sort'] . "',9999,'".base64_encode($filter)."')\">all</A> "; |
|
} |
|
|
|
|
|
function sentence_annotation($count,$filter) { |
|
global $set,$id,$dir,$biconcor; |
|
|
|
|
|
$filtered = array(); |
|
$file = get_current_analysis_filename("coverage","input-annotation"); |
|
if (file_exists($file)) { |
|
$input = file($file); |
|
|
|
if ($filter != "") { |
|
for($i=0;$i<count($input);$i++) { |
|
$item = explode("\t",$input[$i]); |
|
$word = explode(" ",$item[0]); |
|
$keep = 0; |
|
for($j=0;$j<count($word);$j++) { |
|
if ($word[$j] == $filter) { |
|
$keep = 1; |
|
} |
|
} |
|
if (!$keep) { $filtered[$i] = 1; } |
|
} |
|
} |
|
} |
|
|
|
|
|
$data = file(get_current_analysis_filename("basic","bleu-annotation")); |
|
for($i=0;$i<count($data);$i++) { |
|
$item = split("\t",$data[$i]); |
|
if (! array_key_exists($item[1],$filtered)) { |
|
$line["bleu"] = $item[0]; |
|
$line["id"] = $item[1]; |
|
$line["system"] = $item[2]; |
|
$line["reference"] = ""; |
|
for($j=3;$j<count($item);$j++) { |
|
if ($j>3) { $line["reference"] .= "<br>"; }; |
|
$line["reference"] .= $item[$j]; |
|
} |
|
$bleu[] = $line; |
|
} |
|
} |
|
|
|
|
|
global $sort; |
|
function cmp($a, $b) { |
|
global $sort; |
|
if ($sort == "order") { |
|
$a_idx = $a["id"]; |
|
$b_idx = $b["id"]; |
|
} |
|
else if ($sort == "worst" || $sort == "75") { |
|
$a_idx = $a["bleu"]; |
|
$b_idx = $b["bleu"]; |
|
if ($a_idx == $b_idx) { |
|
$a_idx = $b["id"]; |
|
$b_idx = $a["id"]; |
|
} |
|
} |
|
else if ($sort == "best" || $sort == "avg" || $sort == "25") { |
|
$a_idx = -$a["bleu"]; |
|
$b_idx = -$b["bleu"]; |
|
if ($a_idx == $b_idx) { |
|
$a_idx = $a["id"]; |
|
$b_idx = $b["id"]; |
|
} |
|
} |
|
if ($a_idx == $b_idx) { |
|
return 0; |
|
} |
|
return ($a_idx < $b_idx) ? -1 : 1; |
|
} |
|
$sort = $_GET['sort']; |
|
if ($sort == '') { |
|
$sort = "order"; |
|
} |
|
usort($bleu, 'cmp'); |
|
|
|
$offset = 0; |
|
if ($sort == "25" || $sort == "75") { |
|
$offset = (int) (count($bleu)/4); |
|
} |
|
else if ($sort == "avg") { |
|
$offset = (int) (count($bleu)/2); |
|
} |
|
|
|
$retained = array(); |
|
for($i=$offset;$i<$count+$offset && $i<count($bleu);$i++) { |
|
$line = $bleu[$i]; |
|
$retained[$line["id"]] = 1; |
|
} |
|
|
|
|
|
$file = get_current_analysis_filename("basic","segmentation-annotation"); |
|
if (file_exists($file)) { |
|
$data = file($file); |
|
for($i=0;$i<count($data);$i++) { |
|
if ($filter == "" || array_key_exists($i,$retained)) { |
|
$segment = 0; |
|
foreach (split(" ",$data[$i]) as $item) { |
|
list($in_start,$in_end,$out_start,$out_end) = split(":",$item); |
|
$segment++; |
|
$segmentation[$i]["input_start"][$in_start] = $segment; |
|
$segmentation[$i]["input_end"][$in_end] = $segment; |
|
$segmentation[$i]["output_start"][$out_start] = $segment; |
|
$segmentation[$i]["output_end"][$out_end+0] = $segment; |
|
} |
|
} |
|
} |
|
} |
|
|
|
|
|
$hierarchical = 0; |
|
$file = get_current_analysis_filename("basic","input-tree"); |
|
if (file_exists($file)) { |
|
$data = file($file); |
|
$span = 0; |
|
$last_sentence = -1; |
|
$nt_count = array(); |
|
for($i=0;$i<count($data);$i++) { |
|
list($sentence,$brackets,$nt,$words) = split("\t",$data[$i]); |
|
if ($sentence != $last_sentence) { $span = 0; } |
|
$last_sentence = $sentence; |
|
if (array_key_exists($sentence,$retained)) { |
|
$segmentation[$sentence][$span]["brackets"] = $brackets; |
|
|
|
$segmentation[$sentence][$span]["words"] = rtrim($words); |
|
if ($nt != "") { $nt_count[$nt]=1; } |
|
$span++; |
|
} |
|
} |
|
$hierarchical = 1; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
$file = get_current_analysis_filename("basic","output-tree"); |
|
if (file_exists($file)) { |
|
$data = file($file); |
|
$span = 0; |
|
$last_sentence = -1; |
|
$nt_count = array(); |
|
for($i=0;$i<count($data);$i++) { |
|
list($sentence,$brackets,$nt,$words) = split("\t",$data[$i]); |
|
if ($sentence != $last_sentence) { $span = 0; } |
|
$last_sentence = $sentence; |
|
if (array_key_exists($sentence,$retained)) { |
|
$segmentation_out[$sentence][$span]["brackets"] = $brackets; |
|
$segmentation_out[$sentence][$span]["nt"] = $nt; |
|
$segmentation_out[$sentence][$span]["words"] = rtrim($words); |
|
if ($nt != "") { $nt_count[$nt]=1; } |
|
$span++; |
|
} |
|
} |
|
|
|
if (count($nt_count) <= 2) { |
|
foreach ($segmentation_out as $sentence => $segmentation_span) { |
|
foreach ($segmentation_span as $span => $type) { |
|
$segmentation_out[$sentence][$span]["nt"]=""; |
|
} |
|
} |
|
} |
|
} |
|
$file = get_current_analysis_filename("basic","node"); |
|
if (file_exists($file)) { |
|
$data = file($file); |
|
$n = 0; |
|
$last_sentence = -1; |
|
for($i=0;$i<count($data);$i++) { |
|
list($sentence,$depth,$start_div,$end_div,$start_div_in,$end_div_in,$children) = split(" ",$data[$i]); |
|
if ($sentence != $last_sentence) { $n = 0; } |
|
$last_sentence = $sentence; |
|
if (array_key_exists($sentence,$retained)) { |
|
$node[$sentence][$n]['depth'] = $depth; |
|
$node[$sentence][$n]['start_div'] = $start_div; |
|
$node[$sentence][$n]['end_div'] = $end_div; |
|
$node[$sentence][$n]['start_div_in'] = $start_div_in; |
|
$node[$sentence][$n]['end_div_in'] = $end_div_in; |
|
$node[$sentence][$n]['children'] = rtrim($children); |
|
$n++; |
|
} |
|
} |
|
} |
|
|
|
|
|
if ($filter != "") { |
|
print " (".(count($input)-count($filtered))." retaining)"; |
|
} |
|
print "</font><BR>\n"; |
|
|
|
$biconcor = get_biconcor_version($dir,$set,$id); |
|
|
|
for($i=$offset;$i<$count+$offset && $i<count($bleu);$i++) { |
|
$line = $bleu[$i]; |
|
$search_graph_dir = get_current_analysis_filename("basic","search-graph"); |
|
if (file_exists($search_graph_dir) && file_exists($search_graph_dir."/graph.".$line["id"])) { |
|
$state = return_state_for_link(); |
|
print "<FONT SIZE=-1><A TARGET=_blank HREF=\"?$state&analysis=sgviz&set=$set&id=$id&sentence=".$line["id"]."\">show search graph</a></FONT><br>\n"; |
|
} |
|
|
|
if ($hierarchical) { |
|
annotation_hierarchical($line["id"],$segmentation[$line["id"]],$segmentation_out[$line["id"]],$node[$line["id"]]); |
|
} |
|
if ($input) { |
|
print "<div id=\"info-".$line["id"]."\" style=\"border-color:black; background:#ffff80; opacity:0; width:100%; border:1px;\">0 occ. in corpus, 0 translations, entropy: 0.00</div>\n"; |
|
if ($biconcor) { |
|
print "<div id=\"biconcor-".$line["id"]."\" class=\"biconcor\"><font size=-2>(click on input phrase for bilingual concordancer)</font></div>"; |
|
} |
|
if ($hierarchical) { |
|
sentence_annotation_hierarchical("#".$line["id"],$line["id"],$input[$line["id"]],$segmentation[$line["id"]],"in"); |
|
} |
|
else { |
|
print "<font size=-2>[#".$line["id"]."]</font> "; |
|
input_annotation($line["id"],$input[$line["id"]],$segmentation[$line["id"]],$filter); |
|
} |
|
} |
|
|
|
|
|
|
|
if ($hierarchical) { |
|
sentence_annotation_hierarchical($line["bleu"],$line["id"],$line["system"],$segmentation_out[$line["id"]],"out"); |
|
} |
|
else { |
|
print "<font size=-2>[".$line["bleu"]."]</font> "; |
|
output_annotation($line["id"],$line["system"],$segmentation[$line["id"]]); |
|
} |
|
print "<br><font size=-2>[ref]</font> ".$line["reference"]."<hr>"; |
|
} |
|
} |
|
|
|
function coverage($coverage_vector) { |
|
|
|
$coverage = array(); |
|
foreach (split(" ",$coverage_vector) as $item) { |
|
if (preg_match("/[\-:]/",$item)) { |
|
$field = preg_split("/[\-:]/",$item); |
|
$from = $field[0]; |
|
$to = $field[1]; |
|
if (count($field)>2){ $coverage[$from][$to]["corpus_count"]=$field[2]; } |
|
if (count($field)>3){ $coverage[$from][$to]["ttable_count"]=$field[3]; } |
|
if (count($field)>4){ $coverage[$from][$to]["ttabel_entropy"]=$field[4]; } |
|
} |
|
} |
|
|
|
return $coverage; |
|
} |
|
|
|
|
|
function input_annotation($sentence,$input,$segmentation,$filter) { |
|
global $biconcor; |
|
list($words,$coverage_vector) = split("\t",$input); |
|
|
|
|
|
$coverage = array(); |
|
foreach (split(" ",$coverage_vector) as $item) { |
|
if (preg_match("/[\-:]/",$item)) { |
|
list($from,$to,$corpus_count,$ttable_count,$ttable_entropy) = preg_split("/[\-:]/",$item); |
|
$coverage[$from][$to]["corpus_count"] = $corpus_count; |
|
$coverage[$from][$to]["ttable_count"] = $ttable_count; |
|
$coverage[$from][$to]["ttable_entropy"] = $ttable_entropy; |
|
} |
|
} |
|
$word = split(" ",$words); |
|
|
|
|
|
for($j=0;$j<count($word);$j++) { |
|
$box[] = array(); |
|
$separable[] = 1; |
|
} |
|
$max_level = 0; |
|
for($length=1;$length<=7;$length++) { |
|
for($from=0;$from<count($word)-($length-1);$from++) { |
|
$to = $from + ($length-1); |
|
if (array_key_exists($from,$coverage) && |
|
array_key_exists($to,$coverage[$from]) && |
|
array_key_exists("corpus_count",$coverage[$from][$to])) { |
|
$level=0; |
|
$available = 0; |
|
while(!$available) { |
|
$available = 1; |
|
$level++; |
|
for($j=$from;$j<=$to;$j++) { |
|
if (array_key_exists($level,$box) && |
|
array_key_exists($j,$box[$level])) { |
|
$available = 0; |
|
} |
|
} |
|
} |
|
for($j=$from;$j<=$to;$j++) { |
|
$box[$level][$j] = $to; |
|
} |
|
$max_level = max($max_level,$level); |
|
for($j=$from+1;$j<=$to;$j++) { |
|
$separable[$j] = 0; |
|
} |
|
} |
|
} |
|
} |
|
$separable[count($word)] = 1; |
|
|
|
|
|
$sep_start = 0; |
|
for($sep_end=1;$sep_end<=count($word);$sep_end++) { |
|
if ($separable[$sep_end] == 1) { |
|
|
|
print "<table cellpadding=1 cellspacing=0 border=0 style=\"display: inline-table;\">"; |
|
for($level=$max_level;$level>=1;$level--) { |
|
|
|
print "<tr style=\"height:5px;\">"; |
|
for($from=$sep_start;$from<$sep_end;$from++) { |
|
if (array_key_exists($from,$box[$level])) { |
|
$to = $box[$level][$from]; |
|
$size = $to - $from + 1; |
|
if ($size == 1) { |
|
print "<td><div style=\"height:0px; opacity:0; position:relative; z-index:-9;\">".$word[$from]; |
|
} |
|
else { |
|
$color = coverage_color($coverage[$from][$to]); |
|
$phrase = ""; |
|
$highlightwords = ""; |
|
$lowlightwords = ""; |
|
for($j=$from;$j<=$to;$j++) { |
|
if ($j>$from) { $phrase .= " "; } |
|
$phrase .= $word[$j]; |
|
$highlightwords .= " document.getElementById('inputword-$sentence-$j').style.backgroundColor='#ffff80';"; |
|
$lowlightwords .= " document.getElementById('inputword-$sentence-$j').style.backgroundColor='".coverage_color($coverage[$j][$j])."';"; |
|
} |
|
print "<td colspan=$size><div style=\"background-color: $color; height:3px;\" onmouseover=\"show_word_info($sentence,".$coverage[$from][$to]["corpus_count"].",".$coverage[$from][$to]["ttable_count"].",".$coverage[$from][$to]["ttable_entropy"]."); this.style.backgroundColor='#ffff80';$highlightwords\" onmouseout=\"hide_word_info($sentence); this.style.backgroundColor='$color';$lowlightwords;\"".($biconcor?" onclick=\"show_biconcor($sentence,'".base64_encode($phrase)."');\"":"").">"; |
|
} |
|
print "</div></td>"; |
|
$from += $size-1; |
|
} |
|
else { |
|
print "<td><div style=\"height:".($from==$to ? 0 : 3)."px;\"></div></td>"; |
|
} |
|
} |
|
print "</tr>\n"; |
|
} |
|
|
|
print "<tr><td colspan=".($sep_end-$sep_start)."><div style=\"position:relative; z-index:1;\">"; |
|
for($j=$sep_start;$j<$sep_end;$j++) { |
|
if ($segmentation && array_key_exists($j,$segmentation["input_start"])) { |
|
$id = $segmentation["input_start"][$j]; |
|
print "<span id=\"input-$sentence-$id\" style=\"border-color:#000000; border-style:solid; border-width:1px;\" onmouseover=\"highlight_phrase($sentence,$id);\" onmouseout=\"lowlight_phrase($sentence,$id);\">"; |
|
} |
|
if (array_key_exists($j,$coverage)) { |
|
$color = coverage_color($coverage[$j][$j]); |
|
$cc = $coverage[$j][$j]["corpus_count"]; |
|
$tc = $coverage[$j][$j]["ttable_count"]; |
|
$te = $coverage[$j][$j]["ttable_entropy"]; |
|
} |
|
else { |
|
$color = '#ffffff'; |
|
$cc = 0; $tc = 0; $te = 0; |
|
} |
|
print "<span id=\"inputword-$sentence-$j\" style=\"background-color: $color;\" onmouseover=\"show_word_info($sentence,$cc,$tc,$te); this.style.backgroundColor='#ffff80';\" onmouseout=\"hide_word_info($sentence); this.style.backgroundColor='$color';\"".($biconcor?" onclick=\"show_biconcor($sentence,'".base64_encode($word[$j])."');\"":"").">"; |
|
if ($word[$j] == $filter) { |
|
print "<b><font color=#ff0000>".$word[$j]."</font></b>"; |
|
} |
|
else { |
|
print $word[$j]; |
|
} |
|
print "</span>"; |
|
if ($segmentation && array_key_exists($j,$segmentation["input_end"])) { |
|
print "</span>"; |
|
} |
|
print " "; |
|
} |
|
print "</div></td></tr>\n"; |
|
print "</table>\n"; |
|
$sep_start = $sep_end; |
|
} |
|
} |
|
print "<br>"; |
|
} |
|
|
|
|
|
function coverage_color($phrase) { |
|
$corpus_count = 255 - 10 * log(1 + $phrase["corpus_count"]); |
|
if ($corpus_count < 128) { $corpus_count = 128; } |
|
$cc_color = dechex($corpus_count / 16) . dechex($corpus_count % 16); |
|
|
|
$ttable_count = 255 - 20 * log(1 + $phrase["ttable_count"]); |
|
if ($ttable_count < 128) { $ttable_count = 128; } |
|
$tc_color = dechex($ttable_count / 16) . dechex($ttable_count % 16); |
|
|
|
$ttable_entropy = 255 - 32 * $phrase["ttable_entropy"]; |
|
if ($ttable_entropy < 128) { $ttable_entropy = 128; } |
|
$te_color = dechex($ttable_entropy / 16) . dechex($ttable_entropy % 16); |
|
|
|
|
|
|
|
$color = "#". $te_color . $cc_color . $tc_color; |
|
|
|
|
|
|
|
|
|
return $color; |
|
} |
|
|
|
|
|
function output_annotation($sentence,$system,$segmentation) { |
|
|
|
$color = array("#c0c0c0","#e0e0ff","#b0b0ff","#8080ff","#4040ff"); |
|
$word = split(" ",$system); |
|
|
|
for($j=0;$j<count($word);$j++) { |
|
list($surface,$correct) = split("\|", $word[$j]); |
|
if ($segmentation && array_key_exists($j,$segmentation["output_start"])) { |
|
$id = $segmentation["output_start"][$j]; |
|
print "<span id=\"output-$sentence-$id\" style=\"border-color:#000000; border-style:solid; border-width:1px;\" onmouseover=\"highlight_phrase($sentence,$id);\" onmouseout=\"lowlight_phrase($sentence,$id);\">"; |
|
} |
|
print "<span style=\"background-color: $color[$correct]\">$surface</span>"; |
|
if ($segmentation && array_key_exists($j,$segmentation["output_end"])) { |
|
print "</span>"; |
|
} |
|
print " "; |
|
} |
|
} |
|
|
|
function annotation_hierarchical($sentence,$segmentation,$segmentation_out,$node) { |
|
print "<script language=\"javascript\">\n"; |
|
print "max_depth[$sentence] = ".strlen($segmentation[0]["brackets"]).";\n"; |
|
print "span_count_out[$sentence] = ".count($segmentation_out).";\n"; |
|
print "span_count_in[$sentence] = ".count($segmentation).";\n"; |
|
print "nodeIn[$sentence] = [];\n"; |
|
print "nodeOut[$sentence] = [];\n"; |
|
print "nodeChildren[$sentence] = [];\n"; |
|
for($n=0;$n<count($node);$n++) { |
|
print "nodeIn[$sentence].push({ start: ".$node[$n]['start_div_in'].", end: ".$node[$n]['end_div_in'].", depth: ".$node[$n]['depth']." });\n"; |
|
print "nodeOut[$sentence].push({ start: ".$node[$n]['start_div'].", end: ".$node[$n]['end_div'].", depth: ".$node[$n]['depth']." });\n"; |
|
print "nodeChildren[$sentence].push([".$node[$n]['children']."]);\n"; |
|
} |
|
print "</script>\n"; |
|
} |
|
|
|
function sentence_annotation_hierarchical($info,$sentence,$sequence,$segmentation,$in_out) { |
|
$In_Out = $in_out == "out" ? "Out" : "In"; |
|
|
|
|
|
$coverage = coverage($sequence); |
|
$word = preg_split("/\s/",$sequence); |
|
|
|
$color = array("#ffe0e0","#f0e0ff","#e0e0ff","#c0c0ff","#a0a0ff"); |
|
|
|
|
|
|
|
print "<table><tr><td>\n"; |
|
print "<div class=\"enclosing\"><font size=-2>[$info]</font></div>"; |
|
$word_count = 0; |
|
for($span=0;$span<count($segmentation);$span++) { |
|
print "<div class=\"enclosing\">"; |
|
for($depth=0;$depth<strlen($segmentation[$span]["brackets"]);$depth++) { |
|
$class = substr($segmentation[$span]["brackets"],$depth,1); |
|
$action = " id=\"$in_out-$sentence-$span-$depth\" onMouseOver=\"align$In_Out($sentence,$span,$depth);\" onMouseOut=\"unAlign($sentence);\""; |
|
if ($class == " ") { $class = "empty"; $action = ""; } |
|
else if ($class == "[") { $class = "opening"; } |
|
else if ($class == "]") { $class = "closing"; } |
|
else if ($class == "O") { $class = "leaf"; } |
|
else if ($class == "-") { $class = "continued"; } |
|
print "<div class=\"$class\"$action>"; |
|
} |
|
|
|
$words = $segmentation[$span]["words"]; |
|
|
|
|
|
if (array_key_exists("nt",$segmentation[$span]) && |
|
$segmentation[$span]["nt"] != "") { |
|
print $segmentation[$span]["nt"].": "; |
|
} |
|
|
|
|
|
else if($words == "") { |
|
print "<span style=\"opacity:0\">|</span>"; |
|
} |
|
|
|
$span_word = array(); |
|
if ($words != "") { $span_word = split(" ",$words); } |
|
for($w=0;$w<count($span_word);$w++) { |
|
if ($w > 0) { print " "; } |
|
if ($in_out == "in") { |
|
|
|
print $word[$word_count]; |
|
|
|
} |
|
else { |
|
list($surface,$correct) = split("\|", $word[$word_count]); |
|
|
|
print "<span style=\"background-color: $color[$correct]\">$surface</span>"; |
|
} |
|
$word_count++; |
|
} |
|
|
|
for($depth=0;$depth<strlen($segmentation[$span]["brackets"]);$depth++) { |
|
print "</div>"; |
|
} |
|
print "</div>"; |
|
} |
|
print "</td></tr></table>\n"; |
|
} |
|
|
|
function biconcor($query) { |
|
global $set,$id,$dir; |
|
$sentence = $_GET['sentence']; |
|
$biconcor = get_biconcor_version($dir,$set,$id); |
|
print "<center> |
|
<form method=\"get\" id=\"BiconcorForm\" onsubmit=\"return false;\"> |
|
<img src=\"close.gif\" width=17 height=17 onClick=\"close_biconcor($sentence);\"> |
|
<input width=20 id=\"BiconcorQuery\" value=\"$query\"> |
|
<input type=submit onclick=\"show_biconcor($sentence,Base64.encode(document.getElementById('BiconcorQuery').value));\" value=\"look up\"> |
|
</form> |
|
<div class=\"biconcor-content\">"; |
|
$cmd = "./biconcor -html -l $dir/model/biconcor.$biconcor -Q ".base64_encode($query)." 2>/dev/null"; |
|
|
|
system($cmd); |
|
|
|
print "</div></center>"; |
|
|
|
} |
|
|