【发布时间】:2021-04-07 04:36:02
【问题描述】:
我无法理解以下公认的非常简单的代码,它是一个更复杂的项目的简化版本,我现在花了很多时间在其中。 这段代码将在我的系统上运行大约 2000 毫秒。但是当我启用该线路使 cpu 进入睡眠 500 毫秒时,程序将运行更长的时间,大约为 2500 毫秒。
我无法理解这如何符合 cuda 内核相对于主机异步执行的声明?
在 Vistual Studio 2019 上运行 cuda 11.1
#include "cuda_runtime.h"
#include "device_launch_parameters.h"
#include <chrono>
#include <iostream>
#include <numeric>
#include <thread>
__global__ void kernel(double* val, int siz) {
for (int i = 0; i < siz; i++) val[i] = sqrt(val[i]); //calculate square root for every value in array
}
int main() {
auto t1 = std::chrono::high_resolution_clock::now();
const int siz = 1'000'000; //array length
double* val = new double[siz];
std::iota(val, val + siz, 0.0); //fill array with 0, 1, 2,...
double* d_val;
cudaMalloc(&d_val, sizeof(double) * siz);
cudaMemcpy(d_val, val, sizeof(double) * siz, cudaMemcpyDefault);
kernel <<<1, 1 >>> (d_val, siz); //start kernel
//std::this_thread::sleep_for(std::chrono::milliseconds(500)); //---- putting cpu to sleep also delays kernel execution?
cudaError_t err = cudaDeviceSynchronize();
auto t2 = std::chrono::high_resolution_clock::now();
std::cout << "status: " << cudaGetErrorString(err) << std::endl;
std::chrono::duration<double, std::milli> ms = t2 - t1;
std::cout << "duration: " << ms.count() << std::endl;
delete[] val;
}
【问题讨论】: