diff options
author | unknown <serg@sergbook.mysql.com> | 2003-03-29 20:40:03 +0300 |
---|---|---|
committer | unknown <serg@sergbook.mysql.com> | 2003-03-29 20:40:03 +0300 |
commit | 7e13ac1242b8e9f229b76687622bc1f5de301b92 (patch) | |
tree | d630bf005775ec8f06785632bfda2f75fa29bc16 /myisam/ftbench/Ereport.pl | |
parent | f33c97281a9861467553bbaaa28a0b205dfcd291 (diff) | |
download | mariadb-git-7e13ac1242b8e9f229b76687622bc1f5de301b92.tar.gz |
ft benchmark suite: initial checkin
BitKeeper/etc/ignore:
Added myisam/ftbench/data myisam/ftbench/t to the ignore list
Diffstat (limited to 'myisam/ftbench/Ereport.pl')
-rwxr-xr-x | myisam/ftbench/Ereport.pl | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/myisam/ftbench/Ereport.pl b/myisam/ftbench/Ereport.pl new file mode 100755 index 00000000000..aac06503849 --- /dev/null +++ b/myisam/ftbench/Ereport.pl @@ -0,0 +1,53 @@ +#!/usr/bin/perl + +die "Use: $0 eval_output qrels_file\n" unless @ARGV==2; + +open(EOUT,$eout=shift) || die "Cannot open $eout: $!"; +open(RELJ,$relj=shift) || die "Cannot open $relj: $!"; + +$_=<EOUT>; +die "$eout must start with a number!\n "unless /^[1-9][0-9]*\n/; +$ndocs=$_+0; + +$qid=0; +$relj_str=<RELJ>; +$eout_str=<EOUT>; + +while(!eof(RELJ) || !eof(EOUT)) { + ++$qid; + %dq=(); + $A=$B=$AB=0; + $Ravg=$Pavg=0; + + while($relj_str =~ /^0*$qid\s+(\d+)/) { + ++$A; + $dq{$1+0}=1; + last unless $relj_str=<RELJ>; + } + # Favg measure = 1/(a/Pavg+(1-a)/Ravg) +sub Favg { my $a=shift; $Pavg*$Ravg ? 1/($a/$Pavg+(1-$a)/$Ravg) : 0; } + # F0 : a=0 -- ignore precision + # F5 : a=0.5 + # F1 : a=1 -- ignore recall + while($eout_str =~ /^$qid\s+(\d+)\s+(\d+\.\d+)/) { + $B++; + $AB++ if $dq{$1+0}; + $Ravg+=$AB; + $Pavg+=$AB/$B; + last unless $eout_str=<EOUT>; + } + next unless $A; + + $Ravg/=$B*$A if $B; + $Pavg/=$B if $B; + + write; +format= +@##### @#.####### +$qid, Favg(0.5) +. +} + +exit 0; + + |