[glib] Added performance tests for UTF-8 decoding functions



commit 1b101a38730f151b70f0ada607dbd8e43778f980
Author: Mikhail Zabaluev <mikhail zabaluev gmail com>
Date:   Mon Mar 15 03:37:11 2010 +0200

    Added performance tests for UTF-8 decoding functions
    
    https://bugzilla.gnome.org/show_bug.cgi?id=619418

 glib/tests/Makefile.am        |    4 +
 glib/tests/utf8-performance.c |  202 +++++++++++++++++++++++++++++++++++++++++
 2 files changed, 206 insertions(+), 0 deletions(-)
---
diff --git a/glib/tests/Makefile.am b/glib/tests/Makefile.am
index 39816e5..513e3cf 100644
--- a/glib/tests/Makefile.am
+++ b/glib/tests/Makefile.am
@@ -73,6 +73,10 @@ gvariant_LDADD      = $(progs_ldadd)
 TEST_PROGS         += mem-overflow
 mem_overflow_LDADD  = $(progs_ldadd)
 
+TEST_PROGS              += utf8-performance
+utf8_performance_SOURCES = utf8-performance.c
+utf8_performance_LDADD   = $(progs_ldadd)
+
 TEST_PROGS         += utils
 utils_LDADD         = $(progs_ldadd)
 
diff --git a/glib/tests/utf8-performance.c b/glib/tests/utf8-performance.c
new file mode 100644
index 0000000..03b1442
--- /dev/null
+++ b/glib/tests/utf8-performance.c
@@ -0,0 +1,202 @@
+/* GLIB - Library of useful routines for C programming
+ *
+ * Copyright (C) 2010 Mikhail Zabaluev <mikhail zabaluev gmail com>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#include <string.h>
+
+#include <glib.h>
+
+#define NUM_ITERATIONS 500000
+
+static const char str_ascii[] =
+    "The quick brown fox jumps over the lazy dog";
+
+static const gchar str_latin1[] =
+    "Zwölf Boxkämpfer jagen Viktor quer über den gro�en Sylter Deich";
+
+/* Energizing GOELRO-talk in Russian, used by KDE */
+static const char str_cyrillic[] =
+    "ШиÑ?окаÑ? Ñ?лекÑ?Ñ?иÑ?икаÑ?иÑ? Ñ?жнÑ?Ñ? гÑ?беÑ?ний даÑ?Ñ? моÑ?нÑ?й Ñ?олÑ?ок подÑ?Ñ?мÑ? "
+    "Ñ?елÑ?Ñ?кого Ñ?озÑ?йÑ?Ñ?ва.";
+
+/* First sentence from the Wikipedia article:
+ * http://zh.wikipedia.org/w/index.php?title=%E6%B1%89%E5%AD%97&oldid=13053137 */
+static const char str_chinese[] =
+    "æ¼¢å­?ï¼?亦稱中æ??å­?ã??中å?½å­?ï¼?å?¨å?°ç?£å??被稱ç?ºå??å­?ï¼?æ?¯æ¼¢å­?æ??å??å??廣æ³?使ç?¨ç??ä¸?種æ??å­?ï¼?屬æ?¼è¡¨æ??æ??å­?ç??è©?ç´ é?³ç¯?æ??å­?";
+
+typedef int (* GrindFunc) (const char *, gsize);
+
+static int
+grind_get_char (const char *str, gsize len)
+{
+  gunichar acc = 0;
+  int i;
+  for (i = 0; i < NUM_ITERATIONS; i++)
+    {
+      const char *p = str;
+      while (*p) {
+	acc += g_utf8_get_char (p);
+	p = g_utf8_next_char (p);
+      }
+    }
+  return acc;
+}
+
+static int
+grind_get_char_validated (const char *str, gsize len)
+{
+  gunichar acc = 0;
+  int i;
+  for (i = 0; i < NUM_ITERATIONS; i++)
+    {
+      const char *p = str;
+      while (*p) {
+	acc += g_utf8_get_char_validated (p, -1);
+	p = g_utf8_next_char (p);
+      }
+    }
+  return acc;
+}
+
+static int
+grind_utf8_to_ucs4 (const char *str, gsize len)
+{
+  int i;
+  for (i = 0; i < NUM_ITERATIONS; i++)
+    {
+      gunichar *ustr;
+      ustr = g_utf8_to_ucs4 (str, -1, NULL, NULL, NULL);
+      g_free (ustr);
+    }
+  return 0;
+}
+
+static int
+grind_get_char_backwards (const char *str, gsize len)
+{
+  gunichar acc = 0;
+  int i;
+  for (i = 0; i < NUM_ITERATIONS; i++)
+    {
+      const char *p = str + len;
+      do
+	{
+	  p = g_utf8_prev_char (p);
+	  acc += g_utf8_get_char (p);
+        }
+      while (p != str);
+    }
+  return acc;
+}
+
+static int
+grind_utf8_to_ucs4_sized (const char *str, gsize len)
+{
+  int i;
+  for (i = 0; i < NUM_ITERATIONS; i++)
+    {
+      gunichar *ustr;
+      ustr = g_utf8_to_ucs4 (str, len, NULL, NULL, NULL);
+      g_free (ustr);
+    }
+  return 0;
+}
+
+static int
+grind_utf8_to_ucs4_fast (const char *str, gsize len)
+{
+  int i;
+  for (i = 0; i < NUM_ITERATIONS; i++)
+    {
+      gunichar *ustr;
+      ustr = g_utf8_to_ucs4_fast (str, -1, NULL);
+      g_free (ustr);
+    }
+  return 0;
+}
+
+static int
+grind_utf8_to_ucs4_fast_sized (const char *str, gsize len)
+{
+  int i;
+  for (i = 0; i < NUM_ITERATIONS; i++)
+    {
+      gunichar *ustr;
+      ustr = g_utf8_to_ucs4_fast (str, len, NULL);
+      g_free (ustr);
+    }
+  return 0;
+}
+
+static void
+perform_for (GrindFunc grind_func, const char *str, const char *label)
+{
+  gsize len;
+  gulong bytes_ground;
+  gdouble time_elapsed;
+  gdouble result;
+
+  len = strlen (str);
+  bytes_ground = (gulong) len * NUM_ITERATIONS;
+
+  g_test_timer_start ();
+
+  grind_func (str, len);
+
+  time_elapsed = g_test_timer_elapsed ();
+
+  result = ((gdouble) bytes_ground / time_elapsed) * 1.0e-6;
+
+  g_test_maximized_result (result, "%-9s %6.1f MB/s", label, result);
+}
+
+static void
+perform (gconstpointer data)
+{
+  GrindFunc grind_func = (GrindFunc) data;
+
+  if (!g_test_perf ())
+    return;
+
+  perform_for (grind_func, str_ascii, "ASCII:");
+  perform_for (grind_func, str_latin1, "Latin-1:");
+  perform_for (grind_func, str_cyrillic, "Cyrillic:");
+  perform_for (grind_func, str_chinese, "Chinese:");
+}
+
+int
+main (int argc, char **argv)
+{
+  g_test_init (&argc, &argv, NULL);
+  g_test_add_data_func ("/utf8/perf/get_char",
+      grind_get_char, perform);
+  g_test_add_data_func ("/utf8/perf/get_char-backwards",
+      grind_get_char_backwards, perform);
+  g_test_add_data_func ("/utf8/perf/get_char_validated",
+      grind_get_char_validated, perform);
+  g_test_add_data_func ("/utf8/perf/utf8_to_ucs4",
+      grind_utf8_to_ucs4, perform);
+  g_test_add_data_func ("/utf8/perf/utf8_to_ucs4-sized",
+      grind_utf8_to_ucs4_sized, perform);
+  g_test_add_data_func ("/utf8/perf/utf8_to_ucs4_fast",
+      grind_utf8_to_ucs4_fast, perform);
+  g_test_add_data_func ("/utf8/perf/utf8_to_ucs4_fast-sized",
+      grind_utf8_to_ucs4_fast_sized, perform);
+  return g_test_run ();
+}



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]