ACloudViewer  3.9.4
A Modern Library for 3D Data Processing
cudacc.cc
Go to the documentation of this file.
1 // Copyright (c) 2018, ETH Zurich and UNC Chapel Hill.
2 // All rights reserved.
3 //
4 // Redistribution and use in source and binary forms, with or without
5 // modification, are permitted provided that the following conditions are met:
6 //
7 // * Redistributions of source code must retain the above copyright
8 // notice, this list of conditions and the following disclaimer.
9 //
10 // * Redistributions in binary form must reproduce the above copyright
11 // notice, this list of conditions and the following disclaimer in the
12 // documentation and/or other materials provided with the distribution.
13 //
14 // * Neither the name of ETH Zurich and UNC Chapel Hill nor the names of
15 // its contributors may be used to endorse or promote products derived
16 // from this software without specific prior written permission.
17 //
18 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21 // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
22 // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23 // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24 // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26 // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27 // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28 // POSSIBILITY OF SUCH DAMAGE.
29 //
30 // Author: Johannes L. Schoenberger (jsch-at-demuc-dot-de)
31 
32 #include "util/cudacc.h"
33 
34 #include "util/logging.h"
35 
36 namespace colmap {
37 
39  CUDA_SAFE_CALL(cudaEventCreate(&start_));
40  CUDA_SAFE_CALL(cudaEventCreate(&stop_));
41  CUDA_SAFE_CALL(cudaEventRecord(start_, 0));
42 }
43 
45  CUDA_SAFE_CALL(cudaEventDestroy(start_));
46  CUDA_SAFE_CALL(cudaEventDestroy(stop_));
47 }
48 
49 void CudaTimer::Print(const std::string& message) {
50  CUDA_SAFE_CALL(cudaEventRecord(stop_, 0));
51  CUDA_SAFE_CALL(cudaEventSynchronize(stop_));
52  CUDA_SAFE_CALL(cudaEventElapsedTime(&elapsed_time_, start_, stop_));
53  std::cout << StringPrintf("%s: %.4fs", message.c_str(),
54  elapsed_time_ / 1000.0f)
55  << std::endl;
56 }
57 
58 void CudaSafeCall(const cudaError_t error, const std::string& file,
59  const int line) {
60  if (error != cudaSuccess) {
61  std::cerr << StringPrintf("CUDA error at %s:%i - %s", file.c_str(), line,
62  cudaGetErrorString(error))
63  << std::endl;
64  exit(EXIT_FAILURE);
65  }
66 }
67 
68 void CudaCheck(const char* file, const int line) {
69  const cudaError error = cudaGetLastError();
70  while (error != cudaSuccess) {
71  std::cerr << StringPrintf("CUDA error at %s:%i - %s", file, line,
72  cudaGetErrorString(error))
73  << std::endl;
74  exit(EXIT_FAILURE);
75  }
76 }
77 
78 void CudaSyncAndCheck(const char* file, const int line) {
79  // Synchronizes the default stream which is a nullptr.
80  const cudaError error = cudaStreamSynchronize(nullptr);
81  if (cudaSuccess != error) {
82  std::cerr << StringPrintf("CUDA error at %s:%i - %s", file, line,
83  cudaGetErrorString(error))
84  << std::endl;
85  std::cerr
86  << "This error is likely caused by the graphics card timeout "
87  "detection mechanism of your operating system. Please refer to "
88  "the FAQ in the documentation on how to solve this problem."
89  << std::endl;
90  exit(EXIT_FAILURE);
91  }
92 }
93 
94 } // namespace colmap
void Print(const std::string &message)
Definition: cudacc.cc:49
#define CUDA_SAFE_CALL(error)
Definition: cudacc.h:14
QTextStream & endl(QTextStream &stream)
Definition: QtCompat.h:718
void CudaSyncAndCheck(const char *file, const int line)
Definition: cudacc.cc:78
void CudaCheck(const char *file, const int line)
Definition: cudacc.cc:68
void CudaSafeCall(const cudaError_t error, const std::string &file, const int line)
Definition: cudacc.cc:58
std::string StringPrintf(const char *format,...)
Definition: string.cc:131