我正在使用小型重力模拟测试 CUDAfy,在对代码运行分析器后,我发现大部分时间都花在了 GPU 的 CopyFromDevice 方法上。这是代码:
private void WithGPU(float dt)
{
this.myGpu.CopyToDevice(this.myBodies, this.myGpuBodies);
this.myGpu.Launch(1024, 1, "MoveBodies", -1, dt, this.myGpuBodies);
this.myGpu.CopyFromDevice(this.myGpuBodies, this.myBodies);
}
澄清一下,this.myBodies 是一个包含 10,000 个结构的数组,如下所示:
[Cudafy(eCudafyType.Struct)]
[StructLayout(LayoutKind.Sequential)]
internal struct Body
{
public float Mass;
public Vector Position;
public Vector Speed;
}
Vector 是一个带有两个浮点数 X 和 Y 的结构体。
根据我的分析器,这三行的平均时间是 0.092、0.192 和 222.873 毫秒。这些时间是在带有 NVIDIA NVS 310 的 Windows 7 上进行的。
有没有办法提高 CopyFromDevice() 方法的时间?
谢谢