[perf] benchmark subsetting via glyphs.
diff --git a/perf/benchmark-subset.cc b/perf/benchmark-subset.cc
index cf775d5..d6102d4 100644
--- a/perf/benchmark-subset.cc
+++ b/perf/benchmark-subset.cc
@@ -17,6 +17,16 @@
}
}
+void AddGlyphs(unsigned num_glyphs_in_font,
+ unsigned subset_size,
+ hb_subset_input_t* input)
+{
+ for (unsigned i = 0; i < subset_size && i < num_glyphs_in_font; i++) {
+ // TODO(garretrieger): pick randomly.
+ hb_set_add (hb_subset_input_glyph_set (input), i);
+ }
+}
+
/* benchmark for subsetting a font */
static void BM_subset_codepoints (benchmark::State &state,
const char *font_path)
@@ -86,4 +96,72 @@
->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,
+ "perf/fonts/NotoSansCJKsc-VF.ttf")
+ ->Unit(benchmark::kMillisecond)
+ ->Range(10, 100000);
+#endif
+
+
+
BENCHMARK_MAIN();