开源 企业版 高校版 私有云 模力方舟 AI 队友
代码拉取完成,页面将自动刷新
捐赠
捐赠前请先登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
1 Star 0 Fork 0

zdevt/cpptest

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
已有帐号? 立即登录
文件
master
分支 (1)
master
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
项目仓库所选许可证以仓库主分支所使用许可证为准
master
分支 (1)
master
克隆/下载
克隆/下载
提示
下载代码请复制以下命令到终端执行
为确保你提交的代码身份被 Gitee 正确识别,请执行以下命令完成配置
初次使用 SSH 协议进行代码克隆、推送等操作时,需按下述提示完成 SSH 配置
1 生成 RSA 密钥
2 获取 RSA 公钥内容,并配置到 SSH公钥
在 Gitee 上使用 SVN,请访问 使用指南
使用 HTTPS 协议时,命令行会出现如下账号密码验证步骤。基于安全考虑,Gitee 建议 配置并使用私人令牌 替代登录密码进行克隆、推送等操作
Username for 'https://gitee.com': userName
Password for 'https://userName@gitee.com': # 私人令牌
master
分支 (1)
master
cpptest
/
opencl.cpp
cpptest
/
opencl.cpp
opencl.cpp 3.95 KB
一键复制 编辑 原始数据 按行查看 历史
zdevt 提交于 2021年10月30日 17:20 +08:00 . format
#include <stdio.h>
#include <stdlib.h>
#ifdef __APPLE__
#include <OpenCL/opencl.h>
#else
#include <CL/cl.h>
#endif
#define MAX_SOURCE_SIZE (0x100000)
int main ( void )
{
int i;
const int LIST_SIZE = 1024;
int* A = ( int* ) malloc ( sizeof ( int ) * LIST_SIZE );
int* B = ( int* ) malloc ( sizeof ( int ) * LIST_SIZE );
for ( i = 0; i < LIST_SIZE; i++ )
{
A[i] = i;
B[i] = LIST_SIZE - i;
}
//载入内核源码到source_str
FILE* fp;
char* source_str;
size_t source_size;
fp = fopen ( "vector_add_kernel.cl", "r" );
if ( !fp )
{
fprintf ( stderr, "Failed to load kernel\n" );
exit ( 1 );
}
source_str = ( char* ) malloc ( MAX_SOURCE_SIZE );
source_size = fread ( source_str, 1, MAX_SOURCE_SIZE, fp );
fclose ( fp );
//获得平台和设备信息
cl_platform_id platform_id = NULL;
cl_device_id device_id = NULL;
cl_uint ret_num_devices;
cl_uint ret_num_platforms;
cl_int ret = clGetPlatformIDs ( 1, &platform_id, &ret_num_platforms );
ret = clGetDeviceIDs ( platform_id, CL_DEVICE_TYPE_DEFAULT, 1, &device_id, &ret_num_devices );
//创建OpenCL上下文
cl_context context = clCreateContext ( NULL, 1, &device_id, NULL, NULL, &ret );
//创建命令队列
cl_command_queue command_queue = clCreateCommandQueue ( context, device_id, 0, &ret );
//创建内存缓冲对象,在设备上为每个向量
cl_mem a_mem_obj = clCreateBuffer ( context, CL_MEM_READ_ONLY,
LIST_SIZE * sizeof ( int ), NULL, &ret );
cl_mem b_mem_obj = clCreateBuffer ( context, CL_MEM_READ_ONLY,
LIST_SIZE * sizeof ( int ), NULL, &ret );
cl_mem c_mem_obj = clCreateBuffer ( context, CL_MEM_WRITE_ONLY,
LIST_SIZE * sizeof ( int ), NULL, &ret );
//拷贝数据A和B到对应的内存缓冲
ret = clEnqueueWriteBuffer ( command_queue, a_mem_obj, CL_TRUE, 0,
LIST_SIZE * sizeof ( int ), A, 0, NULL, NULL );
ret = clEnqueueWriteBuffer ( command_queue, a_mem_obj, CL_TRUE, 0,
LIST_SIZE * sizeof ( int ), B, 0, NULL, NULL );
//创建程序
cl_program program = clCreateProgramWithSource ( context, 1,
( const char** ) &source_str, ( const size_t* ) &source_size, &ret );
//构建程序
ret = clBuildProgram ( program, 1, &device_id, NULL, NULL, NULL );
//创建OpenCL内核
cl_kernel kernel = clCreateKernel ( program, "vector_add", &ret );
//设置内核参数
ret = clSetKernelArg ( kernel, 0, sizeof ( cl_mem ), ( void* ) &a_mem_obj );
ret = clSetKernelArg ( kernel, 1, sizeof ( cl_mem ), ( void* ) &b_mem_obj );
ret = clSetKernelArg ( kernel, 2, sizeof ( cl_mem ), ( void* ) &c_mem_obj );
//执行内核
size_t global_item_size = LIST_SIZE; //处理整个列表
size_t local_item_size = 64; //分割为64个组
ret = clEnqueueNDRangeKernel ( command_queue, kernel, 1, NULL,
&global_item_size, &local_item_size, 0, NULL, NULL );
//读取内存缓冲C到本地变量C
int* C = ( int* ) malloc ( sizeof ( int ) * LIST_SIZE );
ret = clEnqueueReadBuffer ( command_queue, c_mem_obj, CL_TRUE, 0,
LIST_SIZE * sizeof ( int ), C, 0, NULL, NULL );
//显示结果
for ( i = 0; i < LIST_SIZE; i++ )
{
printf ( "%d + %d = %d\n", A[i], B[i], C[i] );
}
//清理资源
ret = clFlush ( command_queue );
ret = clFinish ( command_queue );
ret = clReleaseKernel ( kernel );
ret = clReleaseProgram ( program );
ret = clReleaseMemObject ( a_mem_obj );
ret = clReleaseMemObject ( b_mem_obj );
ret = clReleaseMemObject ( c_mem_obj );
ret = clReleaseCommandQueue ( command_queue );
ret = clReleaseContext ( context );
free ( A );
free ( B );
free ( C );
return 0;
}
Loading...
举报
举报成功
我们将于2个工作日内通过站内信反馈结果给你!
请认真填写举报原因,尽可能描述详细。
请选择举报类型
取消
发送
误判申诉

此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。

如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。

取消
提交

简介

取消

发行版

暂无发行版

贡献者

全部

近期动态

不能加载更多了
编辑仓库简介
简介内容
主页
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/zdevt/cpptest.git
git@gitee.com:zdevt/cpptest.git
zdevt
cpptest
cpptest
master
点此查找更多帮助

搜索帮助

评论
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册

AltStyle によって変換されたページ (->オリジナル) /