
cuda里面的核函数怎么调用第三方库的函数 200
做opencv的项目要用到cuda,最简单的我想把遍历一副图像的操作放到gpu上去运行,但会报.at<Vec3b>(i,j)这个函数在和函数中不被允许的错误,如何解决?_...
做opencv的项目要用到cuda,最简单的我想把遍历一副图像的操作放到gpu上去运行,但会报.at<Vec3b>(i,j)这个函数在和函数中不被允许的错误,如何解决?
__global__ void GPUimgcal(Mat *gimg1, Mat *gimg2, Mat *gresult,clock_t *time_GPU,int grows,int gcols)
{
clock_t start=clock();
for(int x=0;x<3;x++)
{
for(int i=0;i<grows;i++)
{
for(int j=0;j<gcols;j++)
{
//img.at<uchar>(i,j)=255;
int b=((*gimg1).at<Vec3b>(i,j)[0]*0.3+(*gimg2).at<Vec3b>(i,j)[0]*0.7);
int g=((*gimg1).at<Vec3b>(i,j)[1]*0.3+(*gimg2).at<Vec3b>(i,j)[1]*0.7);
int r=((*gimg1).at<Vec3b>(i,j)[2]*0.3+(*gimg2).at<Vec3b>(i,j)[2]*0.7);
(*gresult).at<Vec3b>(i, j) = Vec3b(b,g,r);
}
}
}
clock_t end=clock();
(*time_GPU)=end-start;
} 展开
__global__ void GPUimgcal(Mat *gimg1, Mat *gimg2, Mat *gresult,clock_t *time_GPU,int grows,int gcols)
{
clock_t start=clock();
for(int x=0;x<3;x++)
{
for(int i=0;i<grows;i++)
{
for(int j=0;j<gcols;j++)
{
//img.at<uchar>(i,j)=255;
int b=((*gimg1).at<Vec3b>(i,j)[0]*0.3+(*gimg2).at<Vec3b>(i,j)[0]*0.7);
int g=((*gimg1).at<Vec3b>(i,j)[1]*0.3+(*gimg2).at<Vec3b>(i,j)[1]*0.7);
int r=((*gimg1).at<Vec3b>(i,j)[2]*0.3+(*gimg2).at<Vec3b>(i,j)[2]*0.7);
(*gresult).at<Vec3b>(i, j) = Vec3b(b,g,r);
}
}
}
clock_t end=clock();
(*time_GPU)=end-start;
} 展开
2个回答
展开全部
你的静态库是编译后的x86代码,而你的CUDA核心是不能执行x86代码的,所以肯定不能这么用。
你可以用CPU把Mat转换成基本元素的数组,然后再交给CUDA处理。
你可以用CPU把Mat转换成基本元素的数组,然后再交给CUDA处理。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |