Files
nixpkgs/pkgs/development/python-modules/flash-linear-attention/default.nix
2026-06-02 18:52:36 +03:00

67 lines
1.3 KiB
Nix

{
lib,
buildPythonPackage,
fetchFromGitHub,
pythonOlder,
# build-system
setuptools,
# dependencies
einops,
torch,
transformers,
# optional-dependencies
causal-conv1d,
matplotlib,
datasets,
pytest,
}:
buildPythonPackage (finalAttrs: {
pname = "flash-linear-attention";
version = "0.5.0";
pyproject = true;
disabled = pythonOlder "3.10";
src = fetchFromGitHub {
owner = "fla-org";
repo = "flash-linear-attention";
tag = "v${finalAttrs.version}";
hash = "sha256-g66yGHaBwEyjb+of76tKTtV/7as/2xQuqcjbGs4E3rU=";
};
build-system = [ setuptools ];
dependencies = [
einops
torch
transformers
];
optional-dependencies = {
# tilelang = [ tilelang ];
conv1d = [ causal-conv1d ];
benchmark = [
matplotlib
datasets
];
test = [ pytest ];
};
# Tests require a GPU
doCheck = false;
pythonImportsCheck = [ "fla" ];
meta = {
description = "Triton-based implementations of causal linear attention";
homepage = "https://github.com/fla-org/flash-linear-attention";
changelog = "https://github.com/fla-org/flash-linear-attention/releases/tag/v${finalAttrs.version}";
license = lib.licenses.mit;
maintainers = with lib.maintainers; [ BatteredBunny ];
};
})