slang
slang copied to clipboard
Making it easier to work with shaders
Slang
Slang is a shading language that makes it easier to build and maintain large shader codebases in a modular and extensible fashion, while also maintaining the highest possible performance on modern GPUs and graphics APIs. Slang is based on years of collaboration between researchers at NVIDIA, Carnegie Mellon University, Stanford, MIT, UCSD and the University of Washington.
Why Slang?
The Slang shading language is designed to enable real-time graphics developers to work with large-scale, high-performance shader code.
Write Shaders Once, Run Anywhere
The Slang compiler can generate code for a wide variety of targets: D3D12, Vulkan, Metal, D3D11, OpenGL, CUDA, and even generate code to run on a CPU. For textual targets, such as Metal Shading Language (MSL) and CUDA, Slang produces readable code that preserves original identifier names, as well as the type and call structure, making it easier to debug.
Access the Latest GPU Features
Slang code is highly portable, but can still leverage unique platform capabilities, including the latest features in Direct3D and Vulkan. For example, developers can make full use of pointers when generating SPIR-V. Slang's capability system helps applications manage feature set differences across target platforms by ensuring code only uses available features during the type-checking step, before generating final code. Additionally, Slang provides flexible interop features to enable directly embedding target code or SPIR-V into generated shaders.
Leverage Neural Graphics with Automatic Differentiation
Slang can automatically generate both forward and backward derivative propagation code for complex functions that involve arbitrary control flow and dynamic dispatch. This allows existing rendering codebases to easily become differentiable, or for Slang to serve as the kernel language in a PyTorch-driven machine learning framework via slangtorch
.
Scalable Software Development with Modules
Slang provides a module system that enables logical organization of code for separate compilation. Slang modules can be independently compiled offline to a custom IR (with optional obfuscation) and then linked at runtime to generate code in formats such as DXIL or SPIR-V.
Code Specialization that Works with Modules
Slang supports generics and interfaces (a.k.a. type traits/protocols), allowing for clear expression of shader specialization without the need for preprocessor techniques or string-pasting. Unlike C++ templates, Slang's generics are pre-checked and don't produce cascading error messages that are difficult to diagnose. The same generic shader can be specialized for a variety of different types to produce specialized code ahead of time, or on the fly, entirely under application control.
Easy On-ramp for HLSL and GLSL Codebases
Slang's syntax is similar to HLSL, and most existing HLSL code can be compiled with the Slang compiler out-of-the-box, or with just minor modifications. This allows existing shader codebases to immediately benefit from Slang without requiring a complete rewrite or port.
Slang provides a compatibility module that enables the use of most GLSL intrinsic functions and GLSL's parameter binding syntax.
Comprehensive Tooling Support
Slang comes with full support of IntelliSense editing features in Visual Studio Code and Visual Studio through the Language Server Protocol. Full debugging capabilities are also available through RenderDoc and SPIR-V based tools.
Getting Started
The fastest way to get started using Slang in your own development is to use a pre-built binary package, available through GitHub releases. Slang binaries are also included in the Vulkan SDK since version 1.3.296.0.
There are packages built for 32- and 64-bit Windows, as well as 64-bit Ubuntu.
Each binary release includes the command-line slangc
compiler, a shared library for the compiler, and the slang.h
header.
See the user-guide for info on using the slangc
command-line tool: Slang Command Line Usage.
If you want to try out the Slang language without installing anything, a fast and simple way is to use the Slang Playground. The playground allows you to compile Slang code to a variety of targets, and even run some simple shaders directly within the browser. The playground loads Slang compiler to your browser and runs all compilation locally. No data will be sent to any servers.
If you would like to build Slang from source, please consult the build instructions.
Documentation
The Slang project provides a variety of different documentation, but most users would be well served starting with the User's Guide.
For developers writing Slang code, the Slang Core Module Reference provides detailed documentation on Slang's built-in types and functions.
We also provide a few examples of how to integrate Slang into a rendering application.
These examples use a graphics layer that we include with Slang called "GFX" which is an abstraction library of various graphics APIs (D3D11, D2D12, OpenGL, Vulkan, CUDA, and the CPU) to support cross-platform applications using GPU graphics and compute capabilities. If you'd like to learn more about GFX, see the GFX User Guide.
Additionally, we recommend checking out Vulkan Mini Examples for more examples of using Slang's language features available on Vulkan, such as pointers and the ray tracing intrinsics.
Contributing
If you'd like to contribute to the project, we are excited to have your input. The following guidelines should be observed by contributors:
- Please follow the contributor Code of Conduct.
- Bugs reports and feature requests should go through the GitHub issue tracker
- Changes should ideally come in as small pull requests on top of
master
, coming from your own personal fork of the project - Large features that will involve multiple contributors or a long development time should be discussed in issues, and broken down into smaller pieces that can be implemented and checked in in stages
Contribution guide describes the workflow for contributors at more detail.
Limitations and Support
Platform support
The Slang compiler and libraries can be built on the following platforms:
Windows | Linux | MacOS | WebAssembly |
---|---|---|---|
supported | supported | supported | experimental |
Both x86_64
and aarch64
architectures are supported on Windows, Linux and MacOS platforms.
Target support
Slang can compile shader code to the following targets:
Target | Status | Output Formats |
---|---|---|
Direct3D 11 | supported | HLSL |
Direct3D 12 | supported | HLSL |
Vulkan | supported | SPIRV, GLSL |
Metal | experimental* | Metal Shading Language |
WebGPU | experimental** | WGSL |
CUDA | supported | C++ (compute only) |
Optix | experimental | C++ (WIP) |
CPU | experimental | C++ (kernel), C++ (host), standalone executable, dynamic library |
*Slang currently supports generating vertex, fragment, compute, task and mesh shaders for Metal.
**WGSL support is still work in-progress.
For greater detail, see the Supported Compilation Targets section of the User Guide
The Slang project has been used for production applications and large shader codebases, but it is still under active development. Support is currently focused on the platforms (Windows, Linux) and target APIs (Direct3D 12, Vulkan) where Slang is used most heavily. Users who are looking for support on other platforms or APIs should coordinate with the development team via the issue tracker to make sure that their use cases can be supported.
License
The Slang code itself is under the Apache 2.0 with LLVM Exception license (see LICENSE).
Builds of the core Slang tools depend on the following projects, either automatically or optionally, which may have their own licenses:
-
glslang
(BSD) -
lz4
(BSD) -
miniz
(MIT) -
spirv-headers
(Modified MIT) -
spirv-tools
(Apache 2.0) -
ankerl::unordered_dense::{map, set}
(MIT)
Slang releases may include slang-llvm which includes LLVM under the license:
-
llvm
(Apache 2.0 License with LLVM exceptions)
Some of the tests and example programs that build with Slang use the following projects, which may have their own licenses:
-
glm
(MIT) -
stb_image
andstb_image_write
from thestb
collection of single-file libraries (Public Domain) -
tinyobjloader
(MIT)