国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

CUDA二維紋理內存+OpenCV圖像濾波

2019-11-10 19:35:41
字體:
來源:轉載
供稿:網友

CUDA和OpenCV混合編程,使用CUDA的紋理內存,實現圖像的二值化以及濾波功能。

#include <cuda_runtime.h> #include <highgui/highgui.hpp>#include <imgPRoc/imgproc.hpp>using namespace cv;int width = 512;int height = 512;// 2維紋理texture<float, 2, cudaReadModeElementType> texRef;// 核函數__global__ void transformKernel(uchar* output, int width, int height){	// 根據tid bid計算歸一化的拾取坐標	unsigned int x = blockIdx.x * blockDim.x + threadIdx.x;	unsigned int y = blockIdx.y * blockDim.y + threadIdx.y;	float u = x / (float)width;	float v = y / (float)height;	//從紋理存儲器中拾取數據,并寫入顯存	output[(y * width + x)] = tex2D(texRef, u / 4, v / 4);}int main(){	// 分配CUDA數組	cudaChannelFormatDesc channelDesc = cudaCreateChannelDesc(32, 0, 0, 0, cudaChannelFormatKindFloat);	cudaArray* cuArray;	cudaMallocArray(&cuArray, &channelDesc, width, height);	//使用OpenCV讀入圖像	Mat image = imread("D://lena.jpg", 0);	resize(image, image, Size(width, height));	imshow("原始圖像", image);	cudaMemcpyToArray(cuArray, 0, 0, image.data, width*height, cudaMemcpyHostToDevice);	// 設置紋理屬性	texRef.addressMode[0] = cudaAddressModeWrap; //循環尋址方式	texRef.addressMode[1] = cudaAddressModeWrap;	texRef.filterMode = cudaFilterModeLinear;   //線性濾波	texRef.normalized = true; //歸一化坐標							 	//綁定紋理	cudaBindTextureToArray(texRef, cuArray, channelDesc);	Mat imageOutput = Mat(Size(width, height), CV_8UC1);	uchar * output = imageOutput.data;	cudaMalloc((void**)&output, width * height * sizeof(float));	dim3 dimBlock(16, 16);	dim3 dimGrid((width + dimBlock.x - 1) / dimBlock.x, (height + dimBlock.y - 1) / dimBlock.y);	transformKernel << <dimGrid, dimBlock >> > (output, width, height);	cudaMemcpy(imageOutput.data, output, height*width, cudaMemcpyDeviceToHost);	imshow("CUDA+OpenCV濾波", imageOutput);	waitKey();	cudaFreeArray(cuArray);	cudaFree(output);}

原始lena圖像:

運行效果:


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 文成县| 东至县| 莱西市| 酒泉市| 上思县| 桂阳县| 贵溪市| 琼中| 镇康县| 曲松县| 轮台县| 海宁市| 靖江市| 建阳市| 栾城县| 炎陵县| 石城县| 博客| 拉萨市| 和平县| 罗江县| 申扎县| 珲春市| 康保县| 莱芜市| 郯城县| 腾冲县| 奉新县| 广水市| 凤山市| 锦州市| 呼玛县| 丹江口市| 阆中市| 潞西市| 安仁县| 景宁| 铜山县| 博兴县| 武鸣县| 泽州县|