-
Notifications
You must be signed in to change notification settings - Fork 226
/
Copy pathBenchWarpPerspective.cpp
95 lines (74 loc) · 3.6 KB
/
BenchWarpPerspective.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/*
* SPDX-FileCopyrightText: Copyright (c) 2023-2024 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "BenchUtils.hpp"
#include <cvcuda/OpWarpPerspective.hpp>
#include <nvbench/nvbench.cuh>
template<typename T>
inline void WarpPerspective(nvbench::state &state, nvbench::type_list<T>)
try
{
long3 shape = benchutils::GetShape<3>(state.get_string("shape"));
long varShape = state.get_int64("varShape");
NVCVBorderType borderType = benchutils::GetBorderType(state.get_string("border"));
NVCVInterpolationType interpType = benchutils::GetInterpolationType(state.get_string("interpolation"));
int flags = interpType | ((state.get_string("inverseMap") == "Y") ? NVCV_WARP_INVERSE_MAP : 0);
float4 borderValue{0, 0, 0, 0};
NVCVPerspectiveTransform transMatrix{0.27, 0.16, 0.00, -0.11, 0.61, 0.65, -0.09, 0.06, 1.00};
state.add_global_memory_reads(shape.x * shape.y * shape.z * sizeof(T) + 9 * sizeof(float));
state.add_global_memory_writes(shape.x * shape.y * shape.z * sizeof(T));
cvcuda::WarpPerspective op(shape.x);
// clang-format off
if (varShape < 0) // negative var shape means use Tensor
{
nvcv::Tensor src({{shape.x, shape.y, shape.z, 1}, "NHWC"}, benchutils::GetDataType<T>());
nvcv::Tensor dst({{shape.x, shape.y, shape.z, 1}, "NHWC"}, benchutils::GetDataType<T>());
benchutils::FillTensor<T>(src, benchutils::RandomValues<T>());
state.exec(nvbench::exec_tag::sync,
[&op, &src, &dst, &transMatrix, &flags, &borderType, &borderValue](nvbench::launch &launch)
{
op(launch.get_stream(), src, dst, transMatrix, flags, borderType, borderValue);
});
}
else // zero and positive var shape means use ImageBatchVarShape
{
nvcv::ImageBatchVarShape src(shape.x);
nvcv::ImageBatchVarShape dst(shape.x);
benchutils::FillImageBatch<T>(src, long2{shape.z, shape.y}, long2{varShape, varShape},
benchutils::RandomValues<T>());
dst.pushBack(src.begin(), src.end());
nvcv::Tensor transMatrixTensor({{shape.x, 9}, "NW"}, nvcv::TYPE_F32);
benchutils::FillTensor<float>(transMatrixTensor, [&transMatrix](const long4 &c){ return transMatrix[c.y]; });
state.exec(nvbench::exec_tag::sync,
[&op, &src, &dst, &transMatrixTensor, &flags, &borderType, &borderValue](nvbench::launch &launch)
{
op(launch.get_stream(), src, dst, transMatrixTensor, flags, borderType, borderValue);
});
}
}
catch (const std::exception &err)
{
state.skip(err.what());
}
// clang-format on
using WarpPerspectiveTypes = nvbench::type_list<uint8_t, float>;
NVBENCH_BENCH_TYPES(WarpPerspective, NVBENCH_TYPE_AXES(WarpPerspectiveTypes))
.set_type_axes_names({"InOutDataType"})
.add_string_axis("shape", {"1x1080x1920"})
.add_int64_axis("varShape", {-1, 0})
.add_string_axis("border", {"REFLECT"})
.add_string_axis("interpolation", {"CUBIC"})
.add_string_axis("inverseMap", {"Y"});