-
Notifications
You must be signed in to change notification settings - Fork 122
Upgrade v0.1.X to v0.2.X
If you rely on the LightningContext
class (of ILGPU.Lightning
v0.1.X) for high-level kernel loading or other high-level operations, you will have to adapt your projects to the API changes.
The new API does not require a LightningContext
instance.
Instead, all operations are extension methods to the ILGPU Accelerator class.
This simplifies programming and makes the general API more consistent.
Furthermore, kernel caching and convenient kernel loading are now included in the ILGPU runtime system and do not require any ILGPU.Lightning
operations.
Moreover, if you make use of the low-level kernel-loading functionality of the ILGPU runtime system (in order to avoid additional library dependencies to ILGPU.Lightning
), you will also benefit from the new API changes.
Note that all functions from v0.1.X will still work to ensure backwards compatibility. However, they will be removed in future versions.
The LightningContext
class is obsolete and will be removed in future versions.
It encapsulated an ILGPU Accelerator
instance and provided useful kernel caching and loading features.
Moreover, all extensions functions (like sorting, for example) were based on a LightningContext
.
We recommend that you replace all occurrences of a LightningContext
with an ILGPU Accelerator
.
Furthermore, change the LightningContext
creation code with an appropriate accelerator construction from ILGPU.
Note that kernel caching and loading are now natively provided by an Accelerator
object.
class ...
{
public static void Main(string[] args)
{
// Create the required ILGPU context
using (var context = new Context())
{
// Deprecated code snippets for creating a LightningContext
var ... = LightningContext.CreateCPUContext(context);
var ... = LightningContext.CreateCudaContext(context);
var ... = LightningContext.Create(context, acceleratorId);
// New version: use default ILGPU accelerators and perform
// all required operations on an accelerator instance.
var ... = new CPUAccelerator(context);
var ... = new CudaAccelerator(context);
var ... = Accelerator.Create(context, acceleratorId);
// Old sample for an Initialize command
var lc = LightningContext.Create(context, ...);
lc.Initialize(targetView);
// New version
var accl = Accelerator.Create(context, acceleratorId);
accl.Initialize(targetView);
}
}
}