OpenGL实现通用GPU计算概述
可能比較早一点做GPU计算的开发者会对OpenGL做通用GPU计算,随着GPU计算技术的兴起,越来越多的技术出现,比方OpenCL、CUDA、OpenAcc等,这些都是专门用来做并行计算的标准或者说接口。
OpenGL用来做通用GPU计算主要是利用纹理存储器在GPU中计算以及把结果取回内存,这大概是OpenGL做通用GPU计算最好的选择。
大概的流程主要就是先创建OpenGL的环境,接着创建FBO(帧缓存对象)、纹理、设置纹理參数、然后将纹理绑定到帧缓存对象,最后传输数据到纹理,接着用片段着色器对数据进行处理,最后就是取回数据。
一个简单的样例例如以下:
#include <stdio.h>#include <gl/glew.h>
#include <gl/glut.h>int main(int argc,char** argv)
{int nWidth = 8;int nHeight = 3;int nSize = nWidth*nHeight;//创建输入数据float *pfInput = new float[4*nSize];float *pfOutput = new float[4*nSize];for (int i = 0; i < nSize*4; i ++){pfInput[i] = i + 1.5;}//创建绘制窗体glutInit(&argc,argv);glutCreateWindow("GPGPU");glewInit();//创建FBO并绑定GLuint fb;glGenFramebuffersEXT(1,&fb);glBindFramebufferEXT(GL_FRAMEBUFFER_EXT,fb);//创建纹理对象并绑定GLuint tex;glGenTextures(1,&tex);glBindTexture(GL_TEXTURE_RECTANGLE_ARB,tex);//设置纹理參数glTexParameteri(GL_TEXTURE_RECTANGLE_ARB,GL_TEXTURE_MIN_FILTER,GL_NEAREST);glTexParameteri(GL_TEXTURE_RECTANGLE_ARB,GL_TEXTURE_MAG_FILTER,GL_NEAREST);glTexParameteri(GL_TEXTURE_RECTANGLE_ARB,GL_TEXTURE_WRAP_S,GL_CLAMP);glTexParameteri(GL_TEXTURE_RECTANGLE_ARB,GL_TEXTURE_WRAP_T,GL_CLAMP);//将纹理关联到FBOglFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT,GL_COLOR_ATTACHMENT0_EXT,GL_TEXTURE_RECTANGLE_ARB,tex,0);//定义纹理数据单元类型glTexImage2D(GL_TEXTURE_RECTANGLE_ARB,0,GL_RGBA32F_ARB,nWidth,nHeight,0,GL_RGBA,GL_FLOAT,0);//将传输数据到纹理缓存glTexSubImage2D(GL_TEXTURE_RECTANGLE_ARB,0,0,0,nWidth,nHeight,GL_RGBA,GL_FLOAT,pfInput);//读取数据glReadBuffer(GL_COLOR_ATTACHMENT0_EXT);glReadPixels(0,0,nWidth,nHeight,GL_RGBA,GL_FLOAT,pfOutput);//打印结果for (int i = 0; i < nSize*4; i ++){printf("%f\t%f\n",pfInput[i],pfOutput[i]);}//清除资源delete []pfInput;delete []pfOutput;glDeleteFramebuffersEXT(1,&fb);glDeleteTextures(1,&tex);return 0;
}
上面的样例。什么也没做。仅仅是将传输数据到GPU,然后原封不动传回来。主要是验证作用。事实上这个样例就是參考GPGPU编程技术-从GLSL、CUDA到OpenCL这本书上的。
OpenGL实现通用GPU计算概述相关推荐
- 什么是GPU计算?阿里云国际版有没有GPU计算?-Unirech
GPU计算是指使用GPU(图形处理单元)作为协处理器来加速CPU,以加速科学.分析.工程.消费者和企业应用程序的运行.GPU加速器由NVIDIA®于2007年首次推出,现在已经支持了世界各地的政府实验 ...
- OpenGL ES 2.0 总体概述
文章目录 OpenGL ES 2.0 总体概述 1. OpenGL ES 的两个小伙伴 1.1 EGL 1.2 GLSL 2. 屏幕图片的本质和产生过程 3. OpenGL ES pipeline 3 ...
- gpu处理信号_GPU显卡不仅用来打游戏那么简单,它还可以用于通用加速计算
如今,显卡不仅在工作站.个人PC中变得非常重要,而且在数据中心也处于举足轻重的地位.CPU负责通用计算.GPU负责加速计算已经成为绝大数数据中心一种常态.用于加速计算的GPU专用处理器,它将计算密集型 ...
- 温故知新之GPU计算
据说,ChatGPT用了5000块GPU,而对于普通工程师而言,看看过去,或许可以帮助望见未来.那么,GPU是什么呢? 图形处理器(GPU,Graphic Processing Unit)是面向吞吐率 ...
- CUDA:主导GPU计算的革命
G80计算架构 真正的革命来自于2006年,NVIDIA在这一年推出了基于DX10统一渲染体系的旗舰图形处理器G80,当人们为其强悍的3D效能惊叹时,有谁又会想到NVIDIA这次会给那些GPU通用运算 ...
- 两种GPU计算平台:CUDA 与 OpenCL
目录 1.硬件层面 2.操作系统 3.软件和社区 4.编程模型 5.CUDA 的优点和局限性 优点 限制 6.OpenCL 的优点和限制 优点 限制 7.补充一点 参考 1.硬件层面 图形加速器的三大 ...
- 如何用Python一门语言通吃高性能并发、GPU计算和深度学习
[CTO讲堂]如何用Python一门语言通吃高性能并发.GPU计算和深度学习 发表于2016-01-04 15:11| 4374次阅读| 来源CSDN| 4 条评论| 作者蒲婧 CTO俱乐部CTOCT ...
- GPU计算主板学习资料保存第735篇:基于3U VPX的AGX Xavier GPU计算主板
基于3U VPX的AGX Xavier GPU计算主板 一.板卡概述 基于3U VPX的 Jetson AGX Xavier GPU计算主板是LINUX环境下软件开发等理想工具.拥有VPX标准连接器和 ...
- gpu的单位表示_现代企业中的GPU计算!
从电子工程领域来讲,GPU是一种专门设计,主要用于图形信号处理的单芯片处理器.在独立显卡中, 一般位于PCB板的中心.与之对应的是使用计算机中央处理器的CPU.很久以前,显卡还叫做图形加速器,并不是计 ...
最新文章
- 云服务器适合什么样的用户?
- 表单form类型数据转换为数组array
- mac安装python3
- 2021考研时间公布 2020年12月26日至27日进行初试
- spring 学习 requestMapping
- (转) android so 文件存私密数据,且防止 so文件未知应用盗用
- 《高效程序员的45个习惯》-末篇
- 注意安全!XSS 和 XSRF
- NOIP 2012 Day2
- HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\PendingFileRenameOperations
- 如何删除office2007、以及安装新版本office
- 每天CookBook之Python-037
- 深度学习VS机器学习——到底什么区别
- 电脑Windows磁盘修复工具如何使用
- matlab中的矩阵求和
- 复杂UI卡顿问题没想到还能这么优化?
- python批量图像处理_python图像处理(4)之图像批量处理
- K8S集群搭建,并部署nginx实现跨网络访问
- python图片合并代码
- 洛谷 P4735 最大异或和