Browse Source

added GNU libunistring benchmark

pull/16/head
Steven G. Johnson 10 years ago
parent
commit
a39c1a6ea2
  1. 7
      .gitignore
  2. 8
      bench/Makefile
  3. 60
      bench/unistring.c

7
.gitignore

@ -10,5 +10,8 @@
*.dSYM
*.txt
*.out
bench
icu
bench/bench
bench/icu
bench/unistring

8
bench/Makefile

@ -26,8 +26,14 @@ icu: icu.o util.o
icu.out: $(DATAFILES) icu
./icu $(DATAFILES) > $@
unistring: unistring.o util.o
$(CC) $(CFLAGS) $(LDFLAGS) -o $@ unistring.o util.o -lunistring
unistring.out: $(DATAFILES) unistring
./unistring $(DATAFILES) > $@
.c.o:
$(CC) $(CPPFLAGS) -I.. $(CFLAGS) -c -o $@ $<
clean:
rm -rf *.o *.txt bench *.out icu
rm -rf *.o *.txt bench *.out icu unistring

60
bench/unistring.c

@ -0,0 +1,60 @@
/* comparitive benchmark of GNU libunistring */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* libunistring */
#include <unistr.h>
#include <uninorm.h>
#include "util.h"
int main(int argc, char **argv)
{
int i;
uninorm_t nf = UNINORM_NFKC;
for (i = 1; i < argc; ++i) {
if (!strcmp(argv[i], "-nfkc")) {
nf = UNINORM_NFKC;
continue;
}
if (!strcmp(argv[i], "-nfkd")) {
nf = UNINORM_NFKD;
continue;
}
if (!strcmp(argv[i], "-nfc")) {
nf = UNINORM_NFC;
continue;
}
if (!strcmp(argv[i], "-nfd")) {
nf = UNINORM_NFD;
continue;
}
if (argv[i][0] == '-') {
fprintf(stderr, "unrecognized option: %s\n", argv[i]);
return EXIT_FAILURE;
}
size_t len;
uint8_t *src = readfile(argv[i], &len);
if (!src) {
fprintf(stderr, "error reading %s\n", argv[i]);
return EXIT_FAILURE;
}
size_t destlen;
uint8_t *dest;
mytime start = gettime();
for (int i = 0; i < 100; ++i) {
dest = u8_normalize(nf, src, len, NULL, &destlen);
if (!dest) return EXIT_FAILURE;
free(dest);
}
printf("%s: %g\n", argv[i], elapsed(gettime(), start) / 100);
free(src);
}
return EXIT_SUCCESS;
}
Loading…
Cancel
Save