1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
{
lib,
config,
buildPythonPackage,
fetchFromGitHub,
# build-system
hatch-vcs,
hatchling,
# dependencies
filecheck,
psutil,
rich,
torch,
tqdm,
triton,
typing-extensions,
# tests
pytestCheckHook,
writableTmpDirAsHomeHook,
helion,
}:
buildPythonPackage rec {
pname = "helion";
version = "0.2.1";
pyproject = true;
src = fetchFromGitHub {
owner = "pytorch";
repo = "helion";
tag = "v${version}";
hash = "sha256-JuuVPz8FPKtaGxbJM4omUzIjY9chtGZFGXwEMX34/Y0=";
};
build-system = [
hatch-vcs
hatchling
];
dependencies = [
filecheck
psutil
rich
torch
tqdm
triton
typing-extensions
];
pythonImportsCheck = [ "helion" ];
nativeCheckInputs = [
pytestCheckHook
writableTmpDirAsHomeHook
];
disabledTests = [
# Flaky: AssertionError: Tensor-likes are not close!
# Mismatched elements: 3 / 65536 (0.0%)
"test_squeeze_and_excitation_net_bwd_dx"
];
# Tests require GPU access
doCheck = false;
passthru.gpuChecks = {
pytest = helion.overridePythonAttrs {
doCheck = true;
requiredSystemFeatures = [ "cuda" ];
};
};
meta = {
description = "Python-embedded DSL that makes it easy to write fast, scalable ML kernels with minimal boilerplate";
homepage = "https://github.com/pytorch/helion";
changelog = "https://github.com/pytorch/helion/releases/tag/v${version}";
license = lib.licenses.bsd3;
maintainers = with lib.maintainers; [ GaetanLepage ];
# This package explicitly requires CUDA-enabled pytorch
broken = !config.cudaSupport;
};
}
|