GPU编程之GLSL(四)——片段着色器

2024-02-14 12:38
文章标签 编程 gpu 着色器 片段 glsl

本文主要是介绍GPU编程之GLSL(四)——片段着色器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文列出三种片段着色器:

 

清除片段着色器

void main(void){gl_FragColor=vec4(0.0,0.0,0.0,0.0);}


 

 

流经片段着色器

uniform sampler2D texturevoid main(){vec4 color=texture2D(texture,gl_TexCoord[0].st);gl_FragColor=color;}


 

这个片段着色器相当于具有纹理映射工能的流经着色器,因为如果不使用该着色器,OpenGL也会以相同的效果映射纹理

 

卷积着色器convolution.flag

#extenson GL_ARB_texture_rectangle : enableuniform sampler2DRect texture;uniform float fRadius;float nWidth=3.0;float nHeight=3.0;void main(void){vec2 pos=gl_TexCoord[0].st;                       //获取当前纹理元坐标值vec4 fSum=vec4(0.0,0.0,0.0,0.0);                //邻近元素取值之和vec4 fTotal=vec4(0.0,0.0,0.0,0.0);               //邻近元素个数vec4 vec4result=vec4(0.0,0.0,0.0,0.0);        //覆盖当前纹理元的输出坐标//邻近元素求和。坐标值加上0.5,以防计算误差for(float ii=pos.x-fRadius;ii<pos.x+fRadius+0.5;ii+=1.0){for(float ii=pos.x-fRadius;ii<pos.x+fRadius+0.5;ii+=1.0){if(ii>=0.0&&jj>=0.0&&ii<nWidth&&jj<nHeight) {fSum+=texture2DRect(txture,vec2(ii,jj)) ;fTotal+=vec4(1.0,1.0,1.0,1.0);}}//求得邻近元素的均值vec4Result=fSum/fTotal;//将结果写入帧缓存对应像素gl_FragColor=vec4Result;}}


 

 

 

参考文献:

仇德元.《GPGPU编程技术——从GLSL、CDPU到OpenGL》[M].河北省三河市:机械工业出版社,2012年:323.

 

 

 

 

 

 

 

 

 

 

 

这篇关于GPU编程之GLSL(四)——片段着色器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/708525

相关文章

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

conda安装GPU版pytorch默认却是cpu版本

《conda安装GPU版pytorch默认却是cpu版本》本文主要介绍了遇到Conda安装PyTorchGPU版本却默认安装CPU的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录一、问题描述二、网上解决方案罗列【此节为反面方案罗列!!!】三、发现的根本原因[独家]3.1 p

Python 异步编程 asyncio简介及基本用法

《Python异步编程asyncio简介及基本用法》asyncio是Python的一个库,用于编写并发代码,使用协程、任务和Futures来处理I/O密集型和高延迟操作,本文给大家介绍Python... 目录1、asyncio是什么IO密集型任务特征2、怎么用1、基本用法2、关键字 async1、async

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

判断PyTorch是GPU版还是CPU版的方法小结

《判断PyTorch是GPU版还是CPU版的方法小结》PyTorch作为当前最流行的深度学习框架之一,支持在CPU和GPU(NVIDIACUDA)上运行,所以对于深度学习开发者来说,正确识别PyTor... 目录前言为什么需要区分GPU和CPU版本?性能差异硬件要求如何检查PyTorch版本?方法1:使用命

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制