# Copyright (c) Meta Platforms, Inc. and affiliates. # All rights reserved. # # This source code is licensed under the BSD-style license found in the # LICENSE file in the root directory of this source tree. from itertools import product import torch from fvcore.common.benchmark import benchmark from tests.test_mesh_normal_consistency import TestMeshNormalConsistency def bm_mesh_normal_consistency() -> None: devices = ["cpu"] if torch.cuda.is_available(): devices.append("cuda") kwargs_list = [] num_meshes = [16, 32, 64] levels = [2, 3] test_cases = product(num_meshes, levels, devices) for case in test_cases: n, l, d = case kwargs_list.append({"num_meshes": n, "level": l, "device": d}) benchmark( TestMeshNormalConsistency.mesh_normal_consistency_with_ico, "MESH_NORMAL_CONSISTENCY_ICO", kwargs_list, warmup_iters=1, ) if __name__ == "__main__": bm_mesh_normal_consistency()