[perf] use option_t in subset benchmark to select between glyphs and codepoint subset.
diff --git a/perf/benchmark-subset.cc b/perf/benchmark-subset.cc
index d6102d4..d74f29e 100644
--- a/perf/benchmark-subset.cc
+++ b/perf/benchmark-subset.cc
@@ -5,6 +5,12 @@
// TODO(garretrieger): TrueType CJK font.
// TODO(garretrieger): Amiri + Devanagari
+enum operation_t
+{
+ subset_codepoints,
+ subset_glyphs
+};
+
void AddCodepoints(const hb_set_t* codepoints_in_font,
unsigned subset_size,
hb_subset_input_t* input)
@@ -28,8 +34,9 @@
}
/* benchmark for subsetting a font */
-static void BM_subset_codepoints (benchmark::State &state,
- const char *font_path)
+static void BM_subset (benchmark::State &state,
+ operation_t operation,
+ const char *font_path)
{
unsigned subset_size = state.range(0);
@@ -46,10 +53,16 @@
{
hb_set_t* all_codepoints = hb_set_create ();
- hb_face_collect_unicodes (face, all_codepoints);
-
- AddCodepoints(all_codepoints, subset_size, input);
-
+ switch (operation) {
+ case subset_codepoints:
+ hb_face_collect_unicodes (face, all_codepoints);
+ AddCodepoints(all_codepoints, subset_size, input);
+ break;
+ case subset_glyphs:
+ unsigned num_glyphs = hb_face_get_glyph_count (face);
+ AddGlyphs(num_glyphs, subset_size, input);
+ break;
+ }
hb_set_destroy (all_codepoints);
}
@@ -64,99 +77,76 @@
hb_face_destroy (face);
}
-BENCHMARK_CAPTURE (BM_subset_codepoints, subset_roboto,
+BENCHMARK_CAPTURE (BM_subset, subset_codepoints_roboto,
+ subset_codepoints,
"perf/fonts/Roboto-Regular.ttf")
->Unit(benchmark::kMillisecond)
->Range(10, 4000);
-BENCHMARK_CAPTURE (BM_subset_codepoints, subset_amiri,
+BENCHMARK_CAPTURE (BM_subset, subset_glyphs_roboto,
+ subset_glyphs,
+ "perf/fonts/Roboto-Regular.ttf")
+ ->Unit(benchmark::kMillisecond)
+ ->Range(10, 4000);
+
+BENCHMARK_CAPTURE (BM_subset, subset_codepoints_amiri,
+ subset_codepoints,
"perf/fonts/Amiri-Regular.ttf")
->Unit(benchmark::kMillisecond)
->Range(10, 4000);
-BENCHMARK_CAPTURE (BM_subset_codepoints, subset_noto_nastaliq_urdu,
+BENCHMARK_CAPTURE (BM_subset, subset_glyphs_amiri,
+ subset_glyphs,
+ "perf/fonts/Amiri-Regular.ttf")
+ ->Unit(benchmark::kMillisecond)
+ ->Range(10, 4000);
+
+BENCHMARK_CAPTURE (BM_subset, subset_codepoints_noto_nastaliq_urdu,
+ subset_codepoints,
"perf/fonts/NotoNastaliqUrdu-Regular.ttf")
->Unit(benchmark::kMillisecond)
->Range(10, 1000);
-BENCHMARK_CAPTURE (BM_subset_codepoints, subset_noto_devangari,
+BENCHMARK_CAPTURE (BM_subset, subset_glyphs_noto_nastaliq_urdu,
+ subset_glyphs,
+ "perf/fonts/NotoNastaliqUrdu-Regular.ttf")
+ ->Unit(benchmark::kMillisecond)
+ ->Range(10, 1000);
+
+BENCHMARK_CAPTURE (BM_subset, subset_codepoints_noto_devangari,
+ subset_codepoints,
"perf/fonts/NotoSansDevanagari-Regular.ttf")
->Unit(benchmark::kMillisecond)
->Range(10, 1000);
-BENCHMARK_CAPTURE (BM_subset_codepoints, subset_mplus1p,
+BENCHMARK_CAPTURE (BM_subset, subset_glyphs_noto_devangari,
+ subset_glyphs,
+ "perf/fonts/NotoSansDevanagari-Regular.ttf")
+ ->Unit(benchmark::kMillisecond)
+ ->Range(10, 1000);
+
+BENCHMARK_CAPTURE (BM_subset, subset_codepoints_mplus1p,
+ subset_codepoints,
"test/subset/data/fonts/Mplus1p-Regular.ttf")
->Unit(benchmark::kMillisecond)
->Range(10, 10000);
+BENCHMARK_CAPTURE (BM_subset, subset_glyphs_mplus1p,
+ subset_glyphs,
+ "test/subset/data/fonts/Mplus1p-Regular.ttf")
+ ->Unit(benchmark::kMillisecond)
+ ->Range(10, 10000);
+
+
#if 0
-BENCHMARK_CAPTURE (BM_subset_codepoints, subset_notocjk,
+BENCHMARK_CAPTURE (BM_subset, subset_codepoints_notocjk,
+ subset_codepoints,
"perf/fonts/NotoSansCJKsc-VF.ttf")
->Unit(benchmark::kMillisecond)
->Range(10, 100000);
-#endif
-
-static void BM_subset_glyphs (benchmark::State &state,
- const char *font_path)
-{
- unsigned subset_size = state.range(0);
-
- hb_face_t *face;
- {
- hb_blob_t *blob = hb_blob_create_from_file_or_fail (font_path);
- assert (blob);
- face = hb_face_create (blob, 0);
- hb_blob_destroy (blob);
- }
-
- hb_subset_input_t* input = hb_subset_input_create_or_fail ();
- assert (input);
-
- {
- unsigned num_glyphs = hb_face_get_glyph_count (face);
-
- AddGlyphs(num_glyphs, subset_size, input);
- }
-
- for (auto _ : state)
- {
- hb_face_t* subset = hb_subset_or_fail (face, input);
- assert (subset);
- hb_face_destroy (subset);
- }
-
- hb_subset_input_destroy (input);
- hb_face_destroy (face);
-}
-
-BENCHMARK_CAPTURE (BM_subset_glyphs, subset_roboto,
- "perf/fonts/Roboto-Regular.ttf")
- ->Unit(benchmark::kMillisecond)
- ->Range(10, 4000);
-
-BENCHMARK_CAPTURE (BM_subset_glyphs, subset_amiri,
- "perf/fonts/Amiri-Regular.ttf")
- ->Unit(benchmark::kMillisecond)
- ->Range(10, 4000);
-
-BENCHMARK_CAPTURE (BM_subset_glyphs, subset_noto_nastaliq_urdu,
- "perf/fonts/NotoNastaliqUrdu-Regular.ttf")
- ->Unit(benchmark::kMillisecond)
- ->Range(10, 1000);
-
-BENCHMARK_CAPTURE (BM_subset_glyphs, subset_noto_devangari,
- "perf/fonts/NotoSansDevanagari-Regular.ttf")
- ->Unit(benchmark::kMillisecond)
- ->Range(10, 1000);
-
-BENCHMARK_CAPTURE (BM_subset_glyphs, subset_mplus1p,
- "test/subset/data/fonts/Mplus1p-Regular.ttf")
- ->Unit(benchmark::kMillisecond)
- ->Range(10, 10000);
-
-#if 0
-BENCHMARK_CAPTURE (BM_subset_glyphs, subset_notocjk,
+BENCHMARK_CAPTURE (BM_subset, subset_glyphs_notocjk,
+ subset_glyphs,
"perf/fonts/NotoSansCJKsc-VF.ttf")
->Unit(benchmark::kMillisecond)
->Range(10, 100000);