[perf] use option_t in subset benchmark to select between glyphs and codepoint subset.

This commit is contained in:
Garret Rieger 2022-05-04 22:16:03 +00:00 committed by Behdad Esfahbod
parent 43938ecdc2
commit bc5129d7fa
1 changed files with 64 additions and 74 deletions

View File

@ -5,6 +5,12 @@
// TODO(garretrieger): TrueType CJK font. // TODO(garretrieger): TrueType CJK font.
// TODO(garretrieger): Amiri + Devanagari // TODO(garretrieger): Amiri + Devanagari
enum operation_t
{
subset_codepoints,
subset_glyphs
};
void AddCodepoints(const hb_set_t* codepoints_in_font, void AddCodepoints(const hb_set_t* codepoints_in_font,
unsigned subset_size, unsigned subset_size,
hb_subset_input_t* input) hb_subset_input_t* input)
@ -28,8 +34,9 @@ void AddGlyphs(unsigned num_glyphs_in_font,
} }
/* benchmark for subsetting a font */ /* benchmark for subsetting a font */
static void BM_subset_codepoints (benchmark::State &state, static void BM_subset (benchmark::State &state,
const char *font_path) operation_t operation,
const char *font_path)
{ {
unsigned subset_size = state.range(0); unsigned subset_size = state.range(0);
@ -46,10 +53,16 @@ static void BM_subset_codepoints (benchmark::State &state,
{ {
hb_set_t* all_codepoints = hb_set_create (); hb_set_t* all_codepoints = hb_set_create ();
hb_face_collect_unicodes (face, all_codepoints); switch (operation) {
case subset_codepoints:
AddCodepoints(all_codepoints, subset_size, input); 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); hb_set_destroy (all_codepoints);
} }
@ -64,99 +77,76 @@ static void BM_subset_codepoints (benchmark::State &state,
hb_face_destroy (face); 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") "perf/fonts/Roboto-Regular.ttf")
->Unit(benchmark::kMillisecond) ->Unit(benchmark::kMillisecond)
->Range(10, 4000); ->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") "perf/fonts/Amiri-Regular.ttf")
->Unit(benchmark::kMillisecond) ->Unit(benchmark::kMillisecond)
->Range(10, 4000); ->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") "perf/fonts/NotoNastaliqUrdu-Regular.ttf")
->Unit(benchmark::kMillisecond) ->Unit(benchmark::kMillisecond)
->Range(10, 1000); ->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") "perf/fonts/NotoSansDevanagari-Regular.ttf")
->Unit(benchmark::kMillisecond) ->Unit(benchmark::kMillisecond)
->Range(10, 1000); ->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") "test/subset/data/fonts/Mplus1p-Regular.ttf")
->Unit(benchmark::kMillisecond) ->Unit(benchmark::kMillisecond)
->Range(10, 10000); ->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 #if 0
BENCHMARK_CAPTURE (BM_subset_codepoints, subset_notocjk, BENCHMARK_CAPTURE (BM_subset, subset_codepoints_notocjk,
subset_codepoints,
"perf/fonts/NotoSansCJKsc-VF.ttf") "perf/fonts/NotoSansCJKsc-VF.ttf")
->Unit(benchmark::kMillisecond) ->Unit(benchmark::kMillisecond)
->Range(10, 100000); ->Range(10, 100000);
#endif
BENCHMARK_CAPTURE (BM_subset, subset_glyphs_notocjk,
static void BM_subset_glyphs (benchmark::State &state, subset_glyphs,
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") "perf/fonts/NotoSansCJKsc-VF.ttf")
->Unit(benchmark::kMillisecond) ->Unit(benchmark::kMillisecond)
->Range(10, 100000); ->Range(10, 100000);