Buckets:

|
download
raw
4.45 kB
# Kernels API Reference
## Main Functions
### get_kernel[[kernels.get_kernel]]
#### kernels.get_kernel[[kernels.get_kernel]]
[Source](https://github.com/huggingface/kernels/blob/vr_499/kernels/src/kernels/utils.py#L290)
Load a kernel from the kernel hub.
This function downloads a kernel to the local Hugging Face Hub cache directory (if it was not downloaded before)
and then loads the kernel.
Example:
```python
import torch
from kernels import get_kernel
activation = get_kernel("kernels-community/relu", version=1)
x = torch.randn(10, 20, device="cuda")
out = torch.empty_like(x)
result = activation.relu(out, x)
```
**Parameters:**
repo_id (`str`) : The Hub repository containing the kernel.
revision (`str`, *optional*, defaults to `"main"`) : The specific revision (branch, tag, or commit) to download. Cannot be used together with `version`.
version (`int`, *optional*) : The kernel version to download. Cannot be used together with `revision`.
backend (`str`, *optional*) : The backend to load the kernel for. Can only be `cpu` or the backend that Torch is compiled for. The backend will be detected automatically if not provided.
user_agent (`Union[str, dict]`, *optional*) : The `user_agent` info to pass to `snapshot_download()` for internal telemetry.
**Returns:**
``ModuleType``
The imported kernel module.
### get_local_kernel[[kernels.get_local_kernel]]
#### kernels.get_local_kernel[[kernels.get_local_kernel]]
[Source](https://github.com/huggingface/kernels/blob/vr_499/kernels/src/kernels/utils.py#L348)
Import a kernel from a local kernel repository path.
**Parameters:**
repo_path (`Path`) : The local path to the kernel repository.
backend (`str`, *optional*) : The backend to load the kernel for. Can only be `cpu` or the backend that Torch is compiled for. The backend will be detected automatically if not provided.
**Returns:**
``ModuleType``
The imported kernel module.
### has_kernel[[kernels.has_kernel]]
#### kernels.has_kernel[[kernels.has_kernel]]
[Source](https://github.com/huggingface/kernels/blob/vr_499/kernels/src/kernels/utils.py#L381)
Check whether a kernel build exists for the current environment (Torch version and compute framework).
**Parameters:**
repo_id (`str`) : The Hub repository containing the kernel.
revision (`str`, *optional*, defaults to `"main"`) : The specific revision (branch, tag, or commit) to download. Cannot be used together with `version`.
version (`int`, *optional*) : The kernel version to download. Cannot be used together with `revision`.
backend (`str`, *optional*) : The backend to load the kernel for. Can only be `cpu` or the backend that Torch is compiled for. The backend will be detected automatically if not provided.
**Returns:**
``bool``
`True` if a kernel is available for the current environment.
### get_loaded_kernels[[kernels.get_loaded_kernels]]
#### kernels.get_loaded_kernels[[kernels.get_loaded_kernels]]
[Source](https://github.com/huggingface/kernels/blob/vr_499/kernels/src/kernels/utils.py#L81)
Return a snapshot of every kernel that has been loaded into the current process.
The returned list is a new list; mutating it does not affect the registry.
Example:
```python
from kernels import get_kernel, get_loaded_kernels
get_kernel("kernels-community/activation", version=1)
for loaded in get_loaded_kernels():
print(loaded.metadata.name, loaded.repo_info)
```
**Returns:**
``list[LoadedKernel]``
One [LoadedKernel](/docs/kernels/pr_499/en/api/kernels#kernels.LoadedKernel) per distinct kernel variant path
loaded in this process.
## Loading locked kernels
### load_kernel[[kernels.load_kernel]]
#### kernels.load_kernel[[kernels.load_kernel]]
[Source](https://github.com/huggingface/kernels/blob/vr_499/kernels/src/kernels/utils.py#L421)
Get a pre-downloaded, locked kernel.
If `lockfile` is not specified, the lockfile will be loaded from the caller's package metadata.
**Parameters:**
repo_id (`str`) : The Hub repository containing the kernel.
lockfile (`Path`, *optional*) : Path to the lockfile. If not provided, the lockfile will be loaded from the caller's package metadata.
backend (`str`, *optional*) : The backend to load the kernel for. Can only be `cpu` or the backend that Torch is compiled for. The backend will be detected automatically if not provided.
**Returns:**
``ModuleType``
The imported kernel module.
### get_locked_kernel[[kernels.get_locked_kernel]]
>>>>>> main

Xet Storage Details

Size:
4.45 kB
·
Xet hash:
5266c28955a17e635158fd9ef01a01aac1c3815d34617b1bae034c40a6b09c42

Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.