Shader-Slang 2025.8版本发布:编译器优化与新特性解析
Shader-Slang是一个开源的着色器语言编译器框架,它支持多种现代着色器语言和平台。该项目旨在为开发者提供高性能的着色器编译能力,同时支持跨平台开发。在2025年8月发布的v2025.8版本中,Shader-Slang带来了多项重要的改进和新特性。
编译器核心优化
本次更新中,编译器核心进行了多项优化。首先是将C++标准升级到了C++20,这为编译器带来了更现代的编程语言特性支持。同时,团队修复了GCC 15上的构建问题,确保了编译器在不同环境下的兼容性。
在编译器内部,新增了IREnumType类型来区分枚举与整数类型,这解决了之前枚举类型可能被错误处理的问题。此外,团队还修复了多个可能导致段错误的bug,提升了编译器的稳定性。
着色器语言特性增强
v2025.8版本为GLSL着色器语言增加了整数打包/解包(int pack/unpack)内置函数支持,这对需要高效处理整数数据的图形应用非常有用。同时,字符字面量现在会被正确解析为整数类型,这解决了之前可能出现的类型混淆问题。
对于HLSL用户,新增了hlsl_2018能力选项,可以避免使用select/and/or等特定语法结构,提高了代码兼容性。此外,countbits函数现在支持16位和8位数据类型,扩展了位操作功能的适用范围。
性能优化与调试改进
在性能方面,新增了fwidth_coarse和fwidth_fine函数,为开发者提供了更精细的导数计算控制选项。调试支持方面,语言服务器现在会显示默认参数值,提高了开发体验。
团队还修复了多个间歇性测试失败的问题,包括自动微分类型测试和重放记录测试等,确保了测试套件的可靠性。对于CUDA后端,改进了SV_DispatchThreadID的处理方式,并增加了下标操作符支持。
跨平台支持
本次更新继续加强了跨平台支持。macOS平台现在提供了ARM64和x86_64架构的独立分发包。Windows平台也同时支持ARM64和x86_64架构。团队还新增了WASM的持续集成测试,为Web平台支持奠定了基础。
对于Metal后端,修复了枚举使用不正确的问题。SPIR-V后端现在会为WTexture*类型正确发出NonReadable修饰符,提高了与Vulkan的兼容性。
文档与示例改进
文档方面进行了多项改进,包括为用户指南添加目录结构、修正示例代码中的注释错误等。这些改进使得新用户能更容易上手Shader-Slang。
总体而言,Shader-Slang v2025.8版本在编译器稳定性、语言特性支持和跨平台能力方面都有显著提升,为图形开发者提供了更强大、更可靠的着色器编译工具链。
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0132
let_datasetLET数据集 基于全尺寸人形机器人 Kuavo 4 Pro 采集,涵盖多场景、多类型操作的真实世界多任务数据。面向机器人操作、移动与交互任务,支持真实环境下的可扩展机器人学习00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python059
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
AgentCPM-ReportAgentCPM-Report是由THUNLP、中国人民大学RUCBM和ModelBest联合开发的开源大语言模型智能体。它基于MiniCPM4.1 80亿参数基座模型构建,接收用户指令作为输入,可自主生成长篇报告。Python00