# 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. import itertools from fvcore.common.benchmark import benchmark from tests.test_points_to_volumes import TestPointsToVolumes def bm_points_to_volumes() -> None: case_grid = { "device": ["cpu", "cuda:0"], "batch_size": [10, 100], "interp_mode": ["trilinear", "nearest"], "volume_size": [[25, 25, 25], [101, 111, 121]], "n_points": [1000, 10000, 100000], } test_cases = itertools.product(*case_grid.values()) kwargs_list = [dict(zip(case_grid.keys(), case)) for case in test_cases] benchmark( TestPointsToVolumes.add_points_to_volumes, "ADD_POINTS_TO_VOLUMES", kwargs_list, warmup_iters=1, ) if __name__ == "__main__": bm_points_to_volumes()