ILGPU is a JIT (just-in-time) compiler for high-performance GPU programs written in .Net-based languages. ILGPU is entirely written in C# without any native dependencies. It offers the flexibility and the convenience of C++ AMP on the one hand and the high performance of Cuda programs on the other hand. Functions in the scope of kernels do not have to be annotated (default C# functions) and are allowed to work on value types. All kernels (including all hardware features like shared memory and atomics) can be executed and debugged on the CPU using the integrated multi-threaded CPU accelerator.
Real-world applications typically require a standard library and a set of standard algorithms that "simply work". The ILGPU Algorithms library meets these requirements by offering a set of auxiliary functions and high-level algorithms (e.g. sorting or prefix sum). All algorithms can be run on all supported accelerator types. The CPU accelerator support is especially useful for kernel debugging.
The ILGPU community provides immediate help, feedback and suggestions via Discord ASAP. Log on to the server and you can get started right away.
There are weekly talk-to-dev meetings on the Discord server. Don't hesitate to join the meeting if you have any questions or suggestions or just want to talk to one of the contributors. Check out the welcome channel on our Discord server for more information.
The sample projects demonstrate the basic usage of ILGPU to help you get started with high performance GPU programming.
ILGPU requires Visual Studio 2022 (or higher) and/or a .NET 6.0 SDK toolchain.
Use the provided Visual Studio solution to build the ILGPU libs in the desired configurations (Debug/Release).
Sometimes the XUnit test runner stops execution when all tests are run in parallel. This is not a problem related to the internal tests, but a known XUnit/Visual Studio problem. If the tests stop unexpectedly, you can simply run the remaining tests again to continue working.
Note: You can unload ILGPU.Tests.Cuda (for example) if you do not have a Cuda-capable device to execute the Cuda test cases.
- ILGPU Homepage (www.ilgpu.net)
- Latest ILGPU Samples (https://github.com/m4rs-mt/ILGPU/tree/master/Samples)
- Latest ILGPU Documentation (https://github.com/m4rs-mt/ILGPU/tree/master/Docs)
- Nuget (https://www.nuget.org/packages/ILGPU)
- Release (https://github.com/m4rs-mt/ILGPU/releases/)
Preview/Daily builds are distributed using https://feedz.io/. To pull preview versions into your project, use the following NuGet.config file:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<packageSources>
<add key="ilgpu" value="https://f.feedz.io/ilgpu/preview/nuget/index.json" />
</packageSources>
</configuration>
Symbols for ILGPU can be loaded in VS2022.
For official releases, ensure that the built-in NuGet.org Symbol Server
is enabled. For preview release symbols, add the link:
https://f.feedz.io/ilgpu/preview/symbols
ILGPU also provides Source Link support for a better debugging experience. Make sure Enable Source Link support
is activated in VS2022 options.
- Make sure that you agree with the general coding style (in terms of braces, whitespaces etc.).
- Make sure that ILGPU compiles without warnings in all build modes (Debug, DebugVerification and Release).
- Parallel Thread Execution ISA 7.0
- NVIDIA
- A Graph-Based Higher-Order Intermediate Representation
- Roland Leissa, Marcel Koester, and Sebastian Hack
- Target-Specific Refinement of Multigrid Codes
- Richard Membarth, Philipp Slusallek, Marcel Koester, Roland Leissa, and Sebastian Hack
- Code Refinement of Stencil Codes
- Marcel Koester, Roland Leissa, Sebastian Hack, Richard Membarth, and Philipp Slusallek
- Simple and Efficient Construction of Static Single Assignment Form
- Matthias Braun, Sebastian Buchwald, Sebastian Hack, Roland Leissa, Christoph Mallon and Andreas Zwinkau
- A Simple, Fast Dominance Algorithm
- Keith D. Cooper, Timothy J. Harvey and Ken Kennedy
- Fast Half Float Conversions
- Jeroen van der Zijp
- Identifying Loops In Almost Linear Time
- G. Ramalingam
ILGPU is licensed under the University of Illinois/NCSA Open Source License. Detailed license information can be found in LICENSE.txt.
Copyright (c) 2016-2024 ILGPU Project. All rights reserved.
Originally developed by Marcel Koester.
Different parts of ILGPU require different third-party libraries.
- ILGPU Dependencies
- System.Collections.Immutable (https://www.nuget.org/packages/System.Collections.Immutable)
- System.Memory (https://www.nuget.org/packages/System.Memory)
- System.Reflection.Metadata (https://www.nuget.org/packages/System.Reflection.Metadata)
- System.Runtime.CompilerServices.Unsafe (https://www.nuget.org/packages/system.runtime.CompilerServices.Unsafe/)
Detailed copyright and license information of these dependencies can be found in LICENSE-3RD-PARTY.txt.