OpenGL ES 入门指南:从基础到实战
引言:为什么需要 OpenGL ES?
在当今的嵌入式设备(如智能手机、汽车仪表盘、智能家居中控屏)中,流畅的图形渲染能力是用户体验的核心。OpenGL ES(OpenGL for Embedded Systems) 作为行业标准,为这些设备提供了高效、跨平台的图形解决方案:
- 智能手机游戏:《原神》《王者荣耀》等手游依赖 OpenGL ES 实现复杂场景渲染。
- 车载系统:特斯拉的 UI 仪表盘通过 OpenGL ES 实现动态 3D 导航。
- 工业控制:工厂中的 HMI(人机界面)使用 OpenGL ES 显示实时数据可视化。
本文将深入解析 OpenGL ES 的核心概念,并通过一个完整的 三角形渲染示例,手把手教你如何从零搭建开发环境、编写代码,并优化嵌入式设备的图形性能。
1. OpenGL ES 核心概念解析
1.1 版本演进与特性对比
版本 | 发布时间 | 核心特性 |
---|---|---|
OpenGL ES 1.x | 2003 | 固定渲染管线,支持光照、雾效等固定功能 |
OpenGL ES 2.0 | 2007 | 引入可编程着色器(Vertex/Fragment Shader),支持更灵活的渲染控制 |
OpenGL ES 3.0 | 2012 | 新增变换反馈(Transform Feedback)、多重渲染目标(MRT)、ETC2 纹理压缩 |
OpenGL ES 3.1 | 2014 | 支持计算着色器(Compute Shader)、间接绘制命令 |
OpenGL ES 3.2 | 2016 | 增强几何着色器、曲面细分,支持 ASTC 纹理格式 |
版本选择建议:
- 嵌入式设备首选 ES 2.0:兼容性强,硬件支持广泛(如 NXP i.MX 8M Plus、树莓派)
- 高性能设备可选 ES 3.x:需要硬件支持,适用于汽车仪表、AR/VR 设备
1.2 OpenGL ES 与桌面版 OpenGL 的差异
特性 | OpenGL ES | OpenGL(桌面版) |
---|---|---|
目标平台 | 移动/嵌入式设备(低功耗) | 桌面/工作站(高性能 GPU) |
API 复杂度 | 精简,移除高级特性(如 glBegin/glEnd) | 完整支持历史功能 |
着色语言 | GLSL ES(精简版) | GLSL |
纹理支持 | 有限格式(如 ETC2、ASTC) | 支持所有格式(包括 sRGB、浮点) |
扩展机制 | 必须通过 EGL 扩展 | 直接通过 glGetString 查询 |
1.3 OpenGL ES 渲染管线详解
OpenGL ES 2.0 可编程渲染管线(图片来源:LearnOpenGL)
- 顶点数据输入:
- 从缓冲区(VBO)或客户端内存读取顶点坐标、颜色、纹理坐标等数据。
- 顶点着色器(Vertex Shader):
- 处理每个顶点,进行坐标变换(MVP 矩阵)、光照计算等。
- 图元装配与光栅化:
- 将顶点连接成三角形/线条,并转换为片元(Fragment,即像素候选)。
- 片元着色器(Fragment Shader):
- 计算每个片元的颜色、深度值,可应用纹理采样、颜色混合等。
- 逐片元操作:
- 深度测试(Depth Test)、模板测试(Stencil Test)、混合(Blending)等。
- 帧缓冲输出:
- 将最终结果写入窗口系统提供的帧缓冲(通过 EGL 管理)。
2. 开发环境搭建:针对嵌入式 Linux(Yocto)
2.1 Yocto 项目集成 OpenGL ES
以 NXP i.MX 8M Plus 为例,配置 conf/local.conf
:
# 启用 GPU 支持
DISTRO_FEATURES:append = " opengl"# 添加必要软件包
IMAGE_INSTALL:append = " \libgles2 \libegl \opencl-headers \packagegroup-fsl-gpu \
"
编译并验证:
bitbake core-image-base
# 部署到设备后检查库文件
ls /usr/lib/libGLESv2.so # 应存在
2.2 工具链配置
安装交叉编译工具链(以 ARM64 为例):
sudo apt install gcc-aarch64-linux-gnu
# 验证
aarch64-linux-gnu-gcc --version
2.3 EGL 与 OpenGL ES 头文件
确保项目包含以下头文件路径:
-I/usr/include/EGL -I/usr/include/GLES2
链接库参数:
LDLIBS = -lEGL -lGLESv2
3. OpenGL ES 编程核心 API
3.1 资源管理 API
API | 功能说明 | 示例代码片段 |
---|---|---|
glGenBuffers() | 生成缓冲区对象 ID | glGenBuffers(1, &vbo); |
glBindBuffer() | 绑定缓冲区到当前上下文 | glBindBuffer(GL_ARRAY_BUFFER, vbo); |
glBufferData() | 上传数据到缓冲区 | glBufferData(GL_ARRAY_BUFFER, sizeof(data), data, GL_STATIC_DRAW); |
3.2 着色器管理 API
// 创建着色器对象
GLuint shader = glCreateShader(GL_VERTEX_SHADER);
// 加载着色器源码
glShaderSource(shader, 1, &source, NULL);
// 编译着色器
glCompileShader(shader);
// 检查编译状态
GLint success;
glGetShaderiv(shader, GL_COMPILE_STATUS, &success);
if (!success) {char log[512];glGetShaderInfoLog(shader, 512, NULL, log);printf("Shader compile error: %s\n", log);
}
3.3 EGL 上下文管理流程
// 1. 获取默认显示
EGLDisplay display = eglGetDisplay(EGL_DEFAULT_DISPLAY);
// 2. 初始化 EGL
eglInitialize(display, NULL, NULL);
// 3. 选择配置
EGLConfig config;
EGLint numConfigs;
eglChooseConfig(display, configAttribs, &config, 1, &numConfigs);
// 4. 创建窗口表面
EGLSurface surface = eglCreateWindowSurface(display, config, nativeWindow, NULL);
// 5. 创建上下文
EGLContext context = eglCreateContext(display, config, EGL_NO_CONTEXT, contextAttribs);
// 6. 绑定上下文
eglMakeCurrent(display, surface, surface, context);
4. 实战:绘制红色三角形(完整代码)
4.1 代码结构
#include <EGL/egl.h>
#include <GLES2/gl2.h>
#include <X11/Xlib.h> // 假设使用 X11 窗口系统// 顶点着色器源码
const char* vertexShaderSource = "attribute vec4 aPosition;\n""void main() {\n"" gl_Position = aPosition;\n""}\n";// 片元着色器源码
const char* fragmentShaderSource = "precision mediump float;\n""void main() {\n"" gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0);\n""}\n";// 三角形顶点数据(标准化设备坐标)
GLfloat vertices[] = {0.0f, 0.5f, 0.0f, // 顶点 1-0.5f, -0.5f, 0.0f, // 顶点 20.5f, -0.5f, 0.0f // 顶点 3
};int main() {// 初始化 X11 窗口Display* xDisplay = XOpenDisplay(NULL);Window root = DefaultRootWindow(xDisplay);XWindowAttributes wa;XGetWindowAttributes(xDisplay, root, &wa);Window window = XCreateSimpleWindow(xDisplay, root, 0, 0, 800, 600, 0, 0, 0);XMapWindow(xDisplay, window);// 初始化 EGLEGLDisplay eglDisplay = eglGetDisplay((EGLNativeDisplayType)xDisplay);eglInitialize(eglDisplay, NULL, NULL);// 配置 EGLconst EGLint configAttribs[] = {EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,EGL_SURFACE_TYPE, EGL_WINDOW_BIT,EGL_RED_SIZE, 8,EGL_GREEN_SIZE, 8,EGL_BLUE_SIZE, 8,EGL_NONE};EGLConfig config;EGLint numConfigs;eglChooseConfig(eglDisplay, configAttribs, &config, 1, &numConfigs);// 创建 EGL 窗口表面EGLSurface surface = eglCreateWindowSurface(eglDisplay, config, window, NULL);// 创建 OpenGL ES 上下文const EGLint contextAttribs[] = { EGL_CONTEXT_CLIENT_VERSION, 2, EGL_NONE };EGLContext context = eglCreateContext(eglDisplay, config, EGL_NO_CONTEXT, contextAttribs);eglMakeCurrent(eglDisplay, surface, surface, context);// 初始化 OpenGL ES 状态glClearColor(0.0f, 0.0f, 0.0f, 1.0f);glViewport(0, 0, 800, 600);// 创建着色器程序GLuint program = glCreateProgram();GLuint vertexShader = glCreateShader(GL_VERTEX_SHADER);glShaderSource(vertexShader, 1, &vertexShaderSource, NULL);glCompileShader(vertexShader);glAttachShader(program, vertexShader);GLuint fragmentShader = glCreateShader(GL_FRAGMENT_SHADER);glShaderSource(fragmentShader, 1, &fragmentShaderSource, NULL);glCompileShader(fragmentShader);glAttachShader(program, fragmentShader);glLinkProgram(program);glUseProgram(program);// 创建顶点缓冲区GLuint vbo;glGenBuffers(1, &vbo);glBindBuffer(GL_ARRAY_BUFFER, vbo);glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), vertices, GL_STATIC_DRAW);// 设置顶点属性指针GLint posAttrib = glGetAttribLocation(program, "aPosition");glEnableVertexAttribArray(posAttrib);glVertexAttribPointer(posAttrib, 3, GL_FLOAT, GL_FALSE, 0, 0);// 主渲染循环while (1) {glClear(GL_COLOR_BUFFER_BIT);glDrawArrays(GL_TRIANGLES, 0, 3);eglSwapBuffers(eglDisplay, surface);}// 清理资源eglDestroyContext(eglDisplay, context);eglDestroySurface(eglDisplay, surface);eglTerminate(eglDisplay);return 0;
}
4.2 代码解析与调试技巧
关键步骤说明
- 窗口系统集成:
- 使用 X11 创建原生窗口,EGL 通过
eglCreateWindowSurface
将其绑定到 OpenGL ES 表面。
- 使用 X11 创建原生窗口,EGL 通过
- 着色器编译检查:
- 通过
glGetShaderiv
和glGetShaderInfoLog
捕获编译错误。
- 通过
- 顶点缓冲区优化:
- 使用 VBO(顶点缓冲对象)将数据存储在 GPU 内存,减少 CPU-GPU 数据传输。
常见错误排查
-
黑屏无输出:
- 检查 EGL 初始化是否成功(
eglGetError()
) - 验证着色器是否编译链接成功
- 确保
glViewport
设置正确
- 检查 EGL 初始化是否成功(
-
三角形颜色异常:
- 检查片元着色器是否设置了正确的
gl_FragColor
- 确认颜色缓冲区的位深(EGL 配置中的
EGL_RED_SIZE
等参数)
- 检查片元着色器是否设置了正确的
5. 性能优化:嵌入式设备专属技巧
5.1 减少绘制调用(Draw Calls)
- 批处理(Batching):合并多个物体的顶点数据到单个 VBO。
- 实例化渲染(Instancing):使用
glDrawArraysInstanced
绘制重复物体。
5.2 纹理优化
- 压缩纹理格式:使用 ETC2/ASTC 代替 PNG/JPG,减少内存占用。
- Mipmap 链:预生成多级纹理,提升渲染效率。
5.3 着色器优化
- 精度限定符:在片元着色器中优先使用
lowp
,如:precision lowp float;
- 避免分支语句:GPU 不擅长处理分支,尽量使用数学函数替代
if/else
。
6. 扩展学习:下一步做什么?
- 3D 模型加载:解析 OBJ 或 glTF 格式,实现复杂场景渲染。
- 光照与阴影:实现 Phong 光照模型、阴影映射(Shadow Mapping)。
- 高级特效:
- 粒子系统(烟雾、火焰)
- 后处理效果(Bloom、HDR)
- 跨平台框架集成:结合 Qt Quick 3D、SDL 构建完整应用。
总结
通过本文,你已掌握:
✅ OpenGL ES 核心概念与版本差异
✅ 嵌入式 Linux 开发环境搭建(Yocto 集成)
✅ EGL 上下文管理与完整渲染流程
✅ 三角形绘制示例与性能优化技巧
实战建议:
- 在真实硬件(如树莓派、i.MX 8M Plus)上运行示例代码。
- 修改顶点数据,尝试绘制四边形或立方体。
- 为三角形添加纹理贴图(使用
glTexImage2D
)。
资源推荐:
- 书籍:《OpenGL ES 3.0 Programming Guide》
- 在线教程:LearnOpenGL ES
- 工具:RenderDoc(图形调试器)
相关文章:
OpenGL ES 入门指南:从基础到实战
引言:为什么需要 OpenGL ES? 在当今的嵌入式设备(如智能手机、汽车仪表盘、智能家居中控屏)中,流畅的图形渲染能力是用户体验的核心。OpenGL ES(OpenGL for Embedded Systems) 作为行业标准&am…...
台达PLC转太网转换的教程案例(台达DVP系列)
产品介绍 台达DVP-PLC自投身工业自动化市场以来,始终致力于创新发展,不断推陈出新。其产品紧密贴合市场需求与行业工艺,凭借卓越性能与丰富功能,深受用户青睐。不仅推出了高效的程序与编辑工具,显著提升了主机执行速度…...
Ubuntu24.10编译Android12源码并运行于模拟器中
效果如下: 初始化环境: 运行lunch弹出对应目标 生成模拟器版本镜像 镜像生成成功 生成模拟器启动镜像 编译注意事项: 24.10版本: sudo apt install curl curl -sSL https://gerrit-googlesource.proxy.ustclug.org/git-repo//master/r…...
Java面试易忽略知识点
1. CompletableFuture中thenApply()与thenCompose()的区别 考察点:组合式异步编程 解析: **thenApply()**:接收前序任务结果,返回普通对象(同步转换),适用简单数据处理。**thenCompose()*…...
C#通过SignalR直接返回流式响应内容
1、背景 实现流式响应基本上分为两大技术方案:(1)基于HTTP的Stream处理;(2)基于socket的连接。前者的实现方式有:《C#通过API接口返回流式响应内容—SSE方式》和《C#通过API接口返回流式响应内…...
【排序算法对比】快速排序、归并排序、堆排序
排序算法对比:快速排序、归并排序、堆排序 1. 快速排序(Quick Sort) 原理 快速排序采用 分治法(Divide and Conquer),通过选取基准值(pivot),将数组划分为 小于基准值…...
YOLO11改进-模块-引入空间带状注意力机制(Spatial Strip Attention,SSA)增强模型对空间信息处理能力的重要模块
在图像相关任务中,传统卷积神经网络(CNN)在处理空间信息时,卷积核的感受野有限,难以有效捕捉长距离的空间依赖关系。而自注意力机制虽然能建模长距离依赖,但计算复杂度较高。为了在高效计算的同时更好地捕捉…...
C++内存分配方式
文章目录 1、静态内存分配2、栈内存分配3、堆内存分配4、内存池分配5、placement new语法工作原理示例 placement new应用场景 在C 中,内存分配主要有以下几种方式: 1、静态内存分配 特点:在编译时就确定了内存的分配和释放,内存…...
【经验】Orin系列Ubuntu远程桌面:VNC、NoMachine、URDC
1、VNC 1.1 Ubuntu端 1)安装VNC服务器 sudo apt install tigervnc-standalone-server2)安装xfce4 桌面 xfce4 用资源较GNOME ,KDE较少。适合老机器,轻量级桌面。与windows界面环境类似。 sudo apt install xfce4 xfce4-goodies也可以使用其它的桌面系统,可以使用如下命…...
【RabbitMQ】RabbitMQ消息的重复消费问题如何解决?
可以从消息队列和消费者两方面入手,确保消息处理的幂等性和可靠性。 1.消息重复消费的原因 1.1消息队列的机制 消息确认失败: 消费者处理完消息后,未正确发送确认(ACK)给RabbitMQ,导致消息被重新投递。消息重试机制:…...
Python、MATLAB和PPT完成数学建模竞赛中的地图绘制
参加数学建模比赛时,很多题目——诸如统计类、数据挖掘类、环保类、建议类的题目总会涉及到地理相关的情景,往往要求我们制作与地图相关的可视化内容。如下图,这是21年亚太赛的那道塞罕坝的题目,期间涉及到温度、降水和森林覆盖率…...
Git 分支删除操作指南(含本地与远程)
🚀 Git 分支删除操作指南(含本地与远程) 在多人协作的开发过程中,定期清理已合并的临时分支(如 feature/*、bugfix/*、hotfix/* 等)可以保持仓库整洁,避免混乱。 📌 分支命名规范回…...
视频推拉流EasyDSS点播平台云端录像播放异常的问题排查与解决
视频推拉流EasyDSS视频直播点播平台可提供一站式的视频转码、点播、直播、视频推拉流、播放H.265视频等服务,搭配RTMP高清摄像头使用,可将无人机设备的实时流推送到平台上,实现无人机视频推流直播、巡检等应用。 有用户反馈,项目现…...
v-model+computed实现父子组件数据传递和同步
v-modelcomputed实现父子组件数据传递和同步 1. 父组件2. 子组件说明总结 1. 父组件 <template><div><span>父子组件传值:{{countRef}}<my-counter v-modelcount></my-counter></span></div> </template> <scr…...
一键秒连WiFi智能设备,uni-app全栈式物联开发指南。
如何使用 uni-app 框架实现通过 WiFi 连接设备并进行命令交互的硬件开发。为了方便理解和实践,我们将提供相应的源代码示例,帮助开发者快速上手。 1. 硬件准备 在开始之前,请确保你已经准备好以下硬件设备: 支持 WiFi 连接的设备…...
关于Docker是否被淘汰虚拟机实现连接虚拟专用网络Ubuntu 22.04 LTS部署Harbor仓库全流程
1.今天的第一个主题: 第一个主题是关于Docker是否真的被K8S弃用,还是可以继续兼容,因为我们知道在去年的时候,由于不可控的原因,docker的所有国内镜像源都被Ban了,再加上K8S自从V1.20之后,宣布…...
【C++】动态规划从入门到精通
一、动态规划基础概念详解 什么是动态规划 动态规划(Dynamic Programming,DP)是一种通过将复杂问题分解为重叠子问题,并存储子问题解以避免重复计算的优化算法。它适用于具有以下两个关键性质的问题: 最优子结构&…...
【专栏预告】《VR 360°全景视频开发:从GoPro到Unity VR眼镜应用实战》
【专栏预告】每周天12:00更新,欢迎指导与交流。 专栏地址:《VR 360全景视频开发:从GoPro到Unity VR眼镜应用实战》 前言 随着VR技术的不断发展,360全景视频的需求也在逐年增长。尤其是在VR眼镜端,360全景视频带来了…...
【leetcode100】搜索插入位置
1、题目描述 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 示例 1: 输入: nums [1,3,5,6], target 5 输出: 2…...
Java面试黄金宝典3
1. 什么是 NIO 原理 缓冲区(Buffer): 它是一个线性的、有限的基本数据元素序列,本质上是一块内存区域,被包装成了一个对象,以便于进行高效的数据读写操作。不同类型的基本数据都有对应的Buffer子类…...
vue3 报错 Could not find a declaration file for module ‘/App.vue‘
vue3 报错 Could not find a declaration file for module /App.vue.app.vue路径.js implicitly has an any type 问题描述原因分析:解决方案: 问题描述 Could not find a declaration file for module /App.vue.app.vue路径.js implicitly has an any …...
linux对串口设备文件进行重命名(删除、重建)
0.前言 最近在弄3562的自制板,有很多串口,然后发现设备文件名编号有些跳跃,不方便用户使用,因此,需要对这些设备文件进行重命名 1.查看设备号 我们需要知道目标设备文件的设备号,通过ls -l /dev/tty*查看…...
Linux内核传输层UDP源码分析
一、用户数据包协议(UDP) 1.UDP数据报头 UDP 提供面向消息的不可靠传输,但没有拥塞控制功能。很多协议都使用 UDP,如用于 IP 网络传输音频和视频的实时传输协议 (Real-time Transport Protocol,RTP),此类型…...
GitHub 超火的开源终端工具——Warp
Warp 作为近年来 GitHub 上备受瞩目的开源终端工具,以其智能化、高性能和协作能力重新定义了命令行操作体验。以下从多个维度深入解析其核心特性、技术架构、用户评价及生态影响力: 一、背景与核心团队 Warp 由前 GitHub CTO Jason Warner 和 Google 前…...
【Java基础巩固系列】异常
业务背景 业务开发中,总会遇到代码出现异常的情况,不合理的异常处理或不处理异常除了影响业务功能和中断业务功能外,还会增加排查问题的难度。所以我们要学会正确的使用异常处理。合理的异常处理能减少很多潜在的问题,是提高代码…...
sass介绍
1、Sass简介 Sass 是一种 CSS 的预编译语言。它提供了 变量(variables)、嵌套(nested rules)、 混合(mixins)、 函数(functions)等功能,并且完全兼容 CSS 语法。Sass 能…...
第1章:云原生时代:容器技术的发展历程与核心价值
第1章:云原生时代:容器技术的发展历程与核心价值 作者:DogDog_Shuai 阅读时间:约15分钟 难度:入门级 目录 1. 引言2. 容器技术的发展历程3. 容器技术的核心价值4. 云原生时代的机遇与挑战5. 总结1. 引言...
软考程序员考试知识点汇总
软考程序员考试(初级资格)主要考察计算机基础理论、编程能力及软件开发相关知识。以下是核心知识点总结及备考建议: 一、计算机基础 数制与编码 二进制、八进制、十进制、十六进制转换原码、反码、补码表示(整数与浮点数…...
JVM OOM问题如何排查和解决
在 Java 开发中,JVM OOM(OutOfMemoryError)问题通常是指程序运行时,JVM 无法为对象分配足够的内存空间,导致发生内存溢出的错误。这个问题往往和内存的配置、内存泄漏、或者资源过度使用等因素有关。 1. OOM 错误类型…...
折叠树报表
折叠树报表中包含了三种信息: 1.树组织信息-可展开、收拢 2.节点的统计信息(汇总求和) 3.每个节点对应的数据信息 一、准备数据 mysql8 数据库中存在两张表 org和store表。 org表和部分数据如下,其中orgname是组织的名称,codepath是完整的组织代码,seq是每个节点的顺序,可…...
python 数据可视化matplotib库安装与使用
要使用 matplotlib 库进行数据可视化,首先你需要确保已经安装了该库。如果你还没有安装,可以通过 Python 的包管理器 pip 来安装它。在你的命令行工具中运行以下命令来安装 matplotlib: pip install matplotlib安装完成后,你就可以…...
Springdoc配置参数详解
文章目录 **1. 基础配置****API 文档路径-springdoc.api-docs.path****Swagger UI 路径-springdoc.swagger-ui.path****是否启用 API 文档-springdoc.api-docs.enabled****是否启用 Swagger UI-springdoc.swagger-ui.enabled** **2. 全局元信息-info****应用标题-springdoc.inf…...
抖音视频数据获取实战:从API调用到热门内容挖掘
在短视频流量为王的时代,掌握抖音热门视频数据已成为内容运营、竞品分析及营销决策的关键。本文将手把手教你通过抖音开放平台API获取视频详情数据,并提供完整的代码实现及商业化应用思路。 一、抖音API权限申请与核心接口 抖音API需企业资质认证&…...
【数学建模】灰色关联分析模型详解与应用
灰色关联分析模型详解与应用 文章目录 灰色关联分析模型详解与应用引言灰色系统理论简介灰色关联分析基本原理灰色关联分析计算步骤1. 确定分析序列2. 数据无量纲化处理3. 计算关联系数4. 计算关联度 灰色关联分析应用实例实例:某企业生产效率影响因素分析 灰色关联…...
Spring Boot 与 Couchbase 整合教程
精心整理了最新的面试资料和简历模板,有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 Spring Boot 与 Couchbase 整合教程 环境要求 JDK 8Spring Boot 2.7.xCouchbase Server 7.xMaven/Gradle 步骤 1:创建Spring Boot项目 使用 st…...
Oracle ASM Failgroup故障组
Oracle ASM Failgroup故障组 1. 故障组的核心作用2. 故障组的配置规则3. 故障组的设计最佳实践4. 故障组的实际示例场景1:普通冗余(2个故障组)场景2:高冗余(3个故障组,跨数据中心) 关键注意事项…...
深度学习框架PyTorch——从入门到精通(2)张量
又名:张亮的一生~~ 张量(Tensors)初始化张量张量的属性张量上的操作与NumPy桥接 张量(Tensors) 张量是一种专门的数据结构,类似Python中的数组或者矩阵。在Torch中,我们使用张量来编码模型的输…...
pytorch小记(十三):pytorch中`nn.ModuleList` 详解
pytorch小记(十三):pytorch中nn.ModuleList 详解 PyTorch 中的 nn.ModuleList 详解1. 什么是 nn.ModuleList?2. 为什么不直接使用普通的 Python 列表?3. nn.ModuleList 的基本用法示例:构建一个包含两层全连…...
C语言-动态内存管理
1.为什么要有动态内存分配 我们现如今已经掌握的内存开辟方式有 int main() {int a 0;int arr[30] { 0 };return 0; } 这两种方式,但是这种开辟空间的方式有两个特点: 1.空间开辟大小是固定的 2.数组在申明的时候,必须指定数组的长度&…...
深入解析MySQL数据库分库分表技术
友情提示:本文内容由银河易创(https://ai.eaigx.com)AI创作平台gpt-4-turbo模型生成,仅供参考。 随着互联网应用的快速发展,单一数据库在面对大规模数据时可能会遇到性能瓶颈。因此,数据库分库分表作为一种…...
【Embedded World 2025:边缘 AI、存储革新与 1X nm 工艺重塑嵌入式未来】
Embedded World 2025于3月11-13日在德国纽伦堡举办,作为全球嵌入式系统领域顶级盛会,汇聚超千家展商与3万专业观众,聚焦嵌入式智能、安全管理及行业解决方案。展会呈现边缘AI、低功耗MCU、5G RedCap、新型存储及车规级技术等前沿方向…...
【人工智能基础2】机器学习、深度学习总结
文章目录 一、人工智能关键技术二、机器学习基础1. 监督、无监督、半监督学习2. 损失函数:四种损失函数3. 泛化与交叉验证4. 过拟合与欠拟合5. 正则化6. 支持向量机 三、深度学习基础:深度神经网络1、概念与原理2、多层神经网络训练方法 一、人工智能关键…...
MySQL如何存储表情符号?
存储表情符号 默认mysql的字符集是utf8,排序规则为 utf8_general_ci INSERT INTO department (name) VALUES (😄)在存储表情的时候会报 1366 - Incorrect string value: \xF0\x9F\x98\x84 for column name at row 1, Time: 0.007000s 这时需要修改字符…...
Unity Shader 学习16:全局光照 概念理解
- 全局光照 直接光 间接光,在没有开启GI的情况下是不计算间接光的(如果放了光照探针 倒是可以模拟间接光 <光照探针只影响动态物体>); - 处理对象:静态物体(static) 、 非静态(动态)物体; - 计算方…...
Jobby、Quarkus 和 Spring Boot对比
Jobby、Quarkus 和 Spring Boot 是三种不同的 Java 框架,各自有不同的设计目标和适用场景。以下是对它们的详细对比: 1. 设计目标 框架设计目标Jobby轻量级的任务调度框架,专注于任务调度和执行。Quarkus面向云原生和 Kubernetes 的 Java 框…...
Dubbo 服务发现
总览 学习 Dubbo 的服务发现机制,可以从以下几方面入手: 注册中心的配置服务的注册客户端拉取服务列表服务列表的本地缓存服务提供者列表变更的监听机制服务发现的接口设计 注册中心的配置 Dubbo 通过解析用户配置决定使用的注册中心。比如用户配置了…...
Pytorch使用手册—自定义 C++ 和 CUDA 运算符(专题五十一)
你将学到什么 如何将用 C++/CUDA 编写的自定义运算符与 PyTorch 集成如何使用 torch.library.opcheck 测试自定义运算符先决条件 1. PyTorch 2.4 或更高版本 2. 对 C++ 和 CUDA 编程有基本了解 注意 本教程也适用于 AMD ROCm,无需额外修改。 PyTorch 提供了一个庞大的运算符库…...
Linux 实时同步服务实现(Rsync 结合 Inotify)
文章目录 1. 实时同步服务介绍2. Inotify 机制介绍3. Inotify-toolRsync 实时同步实践3.1 确认远程数据传输服务部署完成3.2 检查Linux系统是否支持Inotify实时监控3.3 安装inotify-tools3.4 命令测试3.5 重要监控事件汇总3.6 使用步骤 4. Sersync 工具使用(重点&am…...
用Java写斗地主前期工作的一些小想法
目前我们并不是要实现一个游戏,而是要对斗地主游戏做准备,主要是做牌+洗牌+发牌+给发的牌进行排序。在这个过程中我希望通过集中方式来实现: 1. 使用集合+方法+字符串的运用完成以上功能 2. 使用面向对象思想,对1做改进,主要是对其排序的改进,从而理解面向对象的真正意…...
鸿蒙数据持久化之首选项
场景介绍 用户首选项为应用提供Key-Value键值型的数据处理能力,支持应用持久化轻量级数据,并对其修改和查询。当用户希望有一个全局唯一存储的地方,可以采用用户首选项来进行存储。Preferences会将该数据缓存在内存中,当用户读取…...