|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
from itertools import product |
|
|
|
|
|
from fvcore.common.benchmark import benchmark |
|
|
from tests.test_sample_farthest_points import TestFPS |
|
|
|
|
|
|
|
|
def bm_fps() -> None: |
|
|
kwargs_list = [] |
|
|
backends = ["cpu", "cuda:0"] |
|
|
Ns = [8, 32] |
|
|
Ps = [64, 256] |
|
|
Ds = [3] |
|
|
Ks = [24] |
|
|
test_cases = product(Ns, Ps, Ds, Ks, backends) |
|
|
for case in test_cases: |
|
|
N, P, D, K, d = case |
|
|
kwargs_list.append({"N": N, "P": P, "D": D, "K": K, "device": d}) |
|
|
|
|
|
benchmark( |
|
|
TestFPS.sample_farthest_points_naive, |
|
|
"FPS_NAIVE_PYTHON", |
|
|
kwargs_list, |
|
|
warmup_iters=1, |
|
|
) |
|
|
|
|
|
|
|
|
Ns = [32] |
|
|
Ps = [2048, 8192, 18384] |
|
|
Ds = [3, 9] |
|
|
Ks = [24, 48] |
|
|
test_cases = product(Ns, Ps, Ds, Ks, backends) |
|
|
for case in test_cases: |
|
|
N, P, D, K, d = case |
|
|
kwargs_list.append({"N": N, "P": P, "D": D, "K": K, "device": d}) |
|
|
|
|
|
benchmark(TestFPS.sample_farthest_points, "FPS", kwargs_list, warmup_iters=1) |
|
|
|
|
|
|
|
|
if __name__ == "__main__": |
|
|
bm_fps() |
|
|
|