2002-12-18 03:56:41 +00:00
|
|
|
#/**
|
|
|
|
# *******************************************************************************
|
2014-04-14 15:22:55 +00:00
|
|
|
# * Copyright (C) 2002-2014, International Business Machines Corporation and *
|
2002-12-18 03:56:41 +00:00
|
|
|
# * others. All Rights Reserved. *
|
|
|
|
# *******************************************************************************
|
|
|
|
# */
|
2002-11-13 20:44:53 +00:00
|
|
|
#
|
|
|
|
# ICU and Windows Collation performance test script
|
|
|
|
# Used in conjunction with the collperf test program.
|
|
|
|
# This script defines the locales and data files to be tested,
|
|
|
|
# runs the collperf program, and formats and prints the results.
|
|
|
|
#
|
|
|
|
# 7 June 2001 Andy Heninger
|
|
|
|
#
|
|
|
|
# ICU4J and Java Collator performance test script
|
|
|
|
# 2002-09-25 modified by Richard Liang
|
|
|
|
|
2003-02-14 18:55:10 +00:00
|
|
|
print "To run this performance test\n";
|
2014-04-14 15:22:55 +00:00
|
|
|
print "run perl collationperf.pl\n";
|
|
|
|
print "Running performance tests...\n";
|
2003-02-14 18:55:10 +00:00
|
|
|
|
2002-11-13 20:44:53 +00:00
|
|
|
#
|
|
|
|
# Map defines the set of data files to run in each locale
|
|
|
|
#
|
|
|
|
%dataFiles = (
|
2003-02-14 20:21:49 +00:00
|
|
|
"en_US", "TestNames_Latin.txt",
|
|
|
|
"da_DK", "TestNames_Latin.txt",
|
|
|
|
"de_DE", "TestNames_Latin.txt",
|
|
|
|
"de__PHONEBOOK", "TestNames_Latin.txt",
|
|
|
|
"fr_FR", "TestNames_Latin.txt",
|
|
|
|
"ja_JP", "TestNames_Latin.txt TestNames_Japanese_h.txt TestNames_Japanese_k.txt TestNames_Asian.txt",
|
|
|
|
"zh_CN", "TestNames_Latin.txt TestNames_Chinese.txt",
|
|
|
|
"zh_TW", "TestNames_Latin.txt TestNames_Chinese.txt",
|
|
|
|
"zh__PINYIN", "TestNames_Latin.txt TestNames_Chinese.txt",
|
|
|
|
"ru_RU", "TestNames_Latin.txt TestNames_Russian.txt",
|
|
|
|
"th", "TestNames_Latin.txt TestNames_Thai.txt",
|
|
|
|
"ko_KR", "TestNames_Latin.txt TestNames_Korean.txt",
|
2002-11-13 20:44:53 +00:00
|
|
|
);
|
|
|
|
|
2014-04-14 15:22:55 +00:00
|
|
|
if ($^O eq "MSWin32") {
|
|
|
|
$classPath = "out\\lib\\icu4j-perf-tests.jar;..\\icu4j.jar";
|
|
|
|
} else {
|
|
|
|
$classPath = "out/lib/icu4j-perf-tests.jar:../icu4j.jar";
|
|
|
|
}
|
2002-11-13 20:44:53 +00:00
|
|
|
|
|
|
|
#
|
|
|
|
# Outer loop runs through the locales to test
|
|
|
|
# (Edit this list dirctly to make changes)
|
|
|
|
#
|
|
|
|
foreach $locale (
|
2014-04-14 15:22:55 +00:00
|
|
|
"en_US",
|
|
|
|
"da_DK",
|
|
|
|
"de_DE",
|
|
|
|
"de__PHONEBOOK",
|
|
|
|
"fr_FR",
|
|
|
|
"ja_JP",
|
2002-11-13 20:44:53 +00:00
|
|
|
"zh_CN",
|
2014-04-14 15:22:55 +00:00
|
|
|
"zh_TW",
|
|
|
|
"zh__PINYIN",
|
2002-11-13 20:44:53 +00:00
|
|
|
"ko_KR",
|
2014-04-14 15:22:55 +00:00
|
|
|
"ru_RU",
|
|
|
|
"th",
|
2002-11-13 20:44:53 +00:00
|
|
|
)
|
|
|
|
{
|
|
|
|
#
|
|
|
|
# Inner loop runs over the set of data files specified for each locale.
|
|
|
|
# (Edit the %datafiles initialization, above, to make changes.
|
|
|
|
#
|
|
|
|
$ff = $dataFiles{$locale};
|
|
|
|
@ff = split(/[\s]+/, $ff);
|
|
|
|
foreach $data (@ff) {
|
|
|
|
|
|
|
|
#
|
|
|
|
# Run ICU Test for this (locale, data file) pair.
|
|
|
|
#
|
2014-04-14 15:22:55 +00:00
|
|
|
$iStrCol = `java -classpath $classPath com.ibm.icu.dev.test.perf.CollationPerformanceTest -terse -file data/collation/$data -locale $locale -loop 1000 -binsearch`;
|
2002-11-13 20:44:53 +00:00
|
|
|
$iStrCol =~s/[,\s]*//g; # whack off the leading " ," in the returned result.
|
2014-04-14 15:22:55 +00:00
|
|
|
doKeyTimes("java -classpath $classPath com.ibm.icu.dev.test.perf.CollationPerformanceTest -terse -file data/collation/$data -locale $locale -loop 1000 -keygen",
|
2002-11-13 20:44:53 +00:00
|
|
|
$iKeyGen, $iKeyLen);
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Run Windows test for this (locale, data file) pair. Only do if
|
|
|
|
# we are not on Windows 98/ME and we hava a windows langID
|
|
|
|
# for the locale.
|
|
|
|
#
|
|
|
|
$wStrCol = $wKeyGen = $wKeyLen = 0;
|
2014-04-14 15:22:55 +00:00
|
|
|
$wStrCol = `java -classpath $classPath com.ibm.icu.dev.test.perf.CollationPerformanceTest -terse -file data/collation/$data -locale $locale -loop 1000 -binsearch -java`;
|
2002-11-13 20:44:53 +00:00
|
|
|
$wStrCol =~s/[,\s]*//g; # whack off the leading " ," in the returned result.
|
2014-04-14 15:22:55 +00:00
|
|
|
doKeyTimes("java -classpath $classPath com.ibm.icu.dev.test.perf.CollationPerformanceTest -terse -file data/collation/$data -locale $locale -loop 1000 -keygen -java",
|
2002-11-13 20:44:53 +00:00
|
|
|
$wKeyGen, $wKeyLen);
|
|
|
|
|
|
|
|
$collDiff = $keyGenDiff = $keyLenDiff = 0;
|
|
|
|
if ($wKeyLen > 0) {
|
|
|
|
$collDiff = (($wStrCol - $iStrCol) / $iStrCol) * 100;
|
|
|
|
$keyGenDiff = (($wKeyGen - $iKeyGen) / $iKeyGen) * 100;
|
|
|
|
$keyLenDiff = (($wKeyLen - $iKeyLen) / $iKeyLen) * 100;
|
|
|
|
}
|
|
|
|
|
|
|
|
#
|
|
|
|
# Write the line of results for this (locale, data file).
|
|
|
|
#
|
|
|
|
write;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#
|
|
|
|
# doKeyGenTimes($Command_to_run, $time, $key_length)
|
|
|
|
# Do a key-generation test and return the time and key length/char values.
|
|
|
|
#
|
|
|
|
sub doKeyTimes($$$) {
|
2007-08-13 23:20:09 +00:00
|
|
|
# print "$_[0]\n";
|
2002-11-13 20:44:53 +00:00
|
|
|
local($x) = `$_[0]`; # execute the collperf command.
|
|
|
|
($_[1], $_[2]) = split(/\,/, $x); # collperf returns "time, keylength" string.
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Output Formats ...
|
|
|
|
#
|
|
|
|
#
|
|
|
|
format STDOUT_TOP =
|
|
|
|
-------- ICU -------- ------ JAVA ------- (JAVA - ICU)/ICU
|
|
|
|
Locale Data file strcoll keygen keylen strcoll keygen keylen coll keygen keylen
|
|
|
|
------------------------------------------------------------------------------------------------------------
|
|
|
|
.
|
|
|
|
|
|
|
|
format STDOUT =
|
|
|
|
@<<<<<<<<< @<<<<<<<<<<<<<<<<<<<<<<<<| @###### @#### @#.## |@##### @##### @#.## | @###% @###% @###%
|
|
|
|
$locale, $data, $iStrCol, $iKeyGen, $iKeyLen, $wStrCol, $wKeyGen, $wKeyLen, $collDiff, $keyGenDiff, $keyLenDiff
|
|
|
|
.
|