草庐IT

cuda-context

全部标签

c++ - 是否有等同于 std::numeric_limits 的 CUDA?

我想确定最大值intCUDA内核中的值。不幸的是,我找不到任何类似于std::numeric_limits的东西对于CUDA。尝试使用::std函数导致错误:error:callinga__host__function("std::numeric_limits::max")froma__global__function("xyz_kernel")isnotallowedC:\cuda.cu(153)(col.10)有没有一种方法可以通过内核确定所需的值,或者我应该将其作为参数传递? 最佳答案 它存在,但不像std::numeric_

c++ - 可以使用 clang 将 C++17 与 CUDA 一起使用吗?

就使用nvcc而言,需要结合使用相应的gcc(我相信目前最大为5.4)。这当然会在某种程度上阻止人们在主机端使用C++17。因为C++17可以使用clang5和更高版本编译(参见here),并且也可以编译cuda代码(参见here),是不是是否可以同时使用C++17和CUDA(或者是否会出现问题,例如CUDA运行时)? 最佳答案 是的,正如您已经猜到的那样,CUDAclang前端在C++功能支持方面确实领先,甚至在设备代码方面也是如此。这已经是过去了,在NVCC之前引入了C++14特性,社区大多没有注意到。以这个C++17为例,不必

c++ - Objective-C 中的 AOP : Inject context-aware code into each method while maintaining DRY

更新:通过一些关键建议以及与George的交流,我想出了两种不同的方法来在CodeRunner中实现我想要的,并将其发布在Github的要点网站上:Objective-CAOPgist代码很粗糙,因为它是一个新概念,我刚刚在凌晨1:30完成。它确实有效,并且有一些细节,比如自动添加所有不是初始化器、getter或setter的方法。[结束更新]我有好几次(但肯定不是经常)遇到这样的情况,如果我可以为类中的每个方法调用一段上下文相关的代码,我的代码就会有点枯燥。使用Objective-C运行时完全没问题,我也接受C或C++解决方案。代替:-(void)methodName1{self->

c++ - CUDA 中的稀疏矩阵 vector 乘法

我正在尝试在GPU上实现矩阵vector乘法(使用CUDA)。在我的C++代码(CPU)中,我将矩阵加载为密集矩阵,然后使用CUDA执行矩阵vector乘法。我还使用共享内存来提高性能。如何在知道我的矩阵是稀疏矩阵的情况下以高效方式加载矩阵?下面是我加载矩阵的C++函数:intreadMatrix(char*filename,float*&matrix,unsignedint*dim=NULL,intmajority=ROW_MAJOR){unsignedintw,h,x,y,num_entries;floatval;std::ifstreamfile(filename);if(fil

c++ - 使用套接字/内存而不是文件在 Cuda 中解码视频

我目前正在尝试使用cuda解码视频。我有名为cudaDecodeD3D9的cuda示例。此示例使用名为cuvidCreateVideoSource的方法,该方法采用指向源视频的文件指针。有没有办法让Cuda从内存/套接字/流中加载视频? 最佳答案 事实证明,我根本无法使用cuvidCreateVideoSource方法,而是可以通过调用cuvidParseVideoData将每一帧数据直接提供给cuda视频解析器。这是一个从文件中读取一帧并将其提供给cuda解析器的示例。该文件是我创建的,方法是将每个帧的大小写入文件,然后是帧数据。

c++ - 在 CUDA 内核中放置一个 for 循环

在内核中放置一个for循环是个坏主意吗?或者这是一件很常见的事情? 最佳答案 将循环放入内核是很常见的。这并不意味着它总是一个好主意,但也不意味着它不是。确定如何有效地分配任务和数据以及利用相关并行性的一般问题是一个非常困难且Unresolved问题,尤其是在涉及CUDA时。正在进行积极的研究以有效地确定(即,不盲目地探索参数空间)如何为给定的内核实现最佳结果。有时,将循环放入内核中会很有意义。例如,对具有强数据独立性的大型常规数据结构的许多元素进行迭代计算非常适合包含循环的内核。其他时候,您可能决定让每个线程处理许多数据点,例如您

cuda 5.0支持的c++版本

我找不到CUDA5.0支持哪个版本/哪些c++概念。我在CUDA5.0RC随附的编程指南或引用指南中找不到任何信息。特别是我想知道CUDA5.0是否支持C++11。谁能告诉我在哪里可以找到这些信息? 最佳答案 显然,5.0RC中没有可用的C++11功能。nvcc仍然不理解gcc4.6标准包含中使用的C++11语法(参见ErrorwhileusingCUDAandC++11):$nvcc--versionnvcc:NVIDIA(R)CudacompilerdriverCopyright(c)2005-2012NVIDIACorpora

c++ - 无法从静态初始化代码启动 CUDA 内核

我有一个在其构造函数中调用内核的类,如下所示:“标量场.h”#includevoidERROR_CHECK(cudaError_terr,constchar*msg){if(err!=cudaSuccess){std::cout“类A.h”#include"ScalarField.h"static__global__voidKernelSetScalarField(ScalarFieldv){intindex=threadIdx.x+blockIdx.x*blockDim.x;if(index>>(v);ERROR_CHECK(cudaGetLastError(),"Kernel");

c++ - 将常量参数传递给 CUDA 内核的最快(或最优雅)方式

假设我想要一个需要做很多事情的CUDA内核,但是有一些对所有内核都是不变的圆顶参数。此参数作为输入传递给主程序,因此它们不能在#DEFINE中定义。内核将运行多次(大约65K)并且它需要这些参数(和一些其他输入)来进行计算。我的问题是:将这些常量传递给内核的最快(或者最优雅)的方法是什么?常量是2或3个元素长度的float*或int*数组。他们大约有5~10个。玩具示例:2个常量const1和const2__global__voidkernelToyExample(intinputdata,?????){value=inputdata*const1[0]+const2[1]/const

c++ - 可由设备或主机调用的 CUDA 函数

我在一些需要从设备和主机调用的CUDA代码中有一个可重用的函数。是否有合适的限定符?例如在这种情况下,func1的正确定义是什么:intfunc1(inta,intb){returna+b;}__global__devicecode(float*A){inti=blockDim.x*blockIdx.x+threadIdx.x;A[i]=func1(i,i);}voidmain(){//Normalcudamemoryset-up//Callfunc1frominsidemain:intj=func1(2,4)//Normalcudamemorycopy/programrun/retr