FastDeploy  latest
Fast & Easy to Deploy!
cuda_utils.h
1 // Copyright (c) 2022 PaddlePaddle Authors. All Rights Reserved.
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
15 #pragma once
16 
17 #include <cuda_runtime.h>
18 #include <cstdint>
19 #include <vector>
20 
21 #ifndef CUDA_CHECK
22 #define CUDA_CHECK(callstr)\
23  {\
24  cudaError_t error_code = callstr;\
25  if (error_code != cudaSuccess) {\
26  std::cerr << "CUDA error " << error_code << " at " << __FILE__ << ":";\
27  std::cerr << __LINE__;\
28  assert(0);\
29  }\
30  }
31 #endif // CUDA_CHECK
32 
33 namespace fastdeploy {
34 namespace vision {
35 namespace utils {
36 void CudaYoloPreprocess(uint8_t* src, int src_width, int src_height,
37  float* dst, int dst_width, int dst_height,
38  const std::vector<float> padding_value,
39  cudaStream_t stream);
40 } // namespace utils
41 } // namespace vision
42 } // namespace fastdeploy
All C++ FastDeploy APIs are defined inside this namespace.
Definition: option.h:16