2024-06-05 15:53:02 +00:00
|
|
|
{
|
|
|
|
lib,
|
|
|
|
buildPythonPackage,
|
|
|
|
hatch-fancy-pypi-readme,
|
|
|
|
hatch-vcs,
|
|
|
|
hatchling,
|
|
|
|
pytestCheckHook,
|
|
|
|
pythonOlder,
|
|
|
|
accelerate,
|
|
|
|
bentoml,
|
|
|
|
bitsandbytes,
|
|
|
|
build,
|
|
|
|
click,
|
|
|
|
ctranslate2,
|
|
|
|
datasets,
|
|
|
|
docker,
|
|
|
|
einops,
|
|
|
|
ghapi,
|
|
|
|
huggingface-hub,
|
|
|
|
hypothesis,
|
|
|
|
ipython,
|
|
|
|
jupyter,
|
|
|
|
jupytext,
|
|
|
|
nbformat,
|
|
|
|
notebook,
|
|
|
|
openai,
|
|
|
|
openllm-client,
|
|
|
|
openllm-core,
|
|
|
|
optimum,
|
|
|
|
peft,
|
|
|
|
pytest-mock,
|
|
|
|
pytest-randomly,
|
|
|
|
pytest-rerunfailures,
|
|
|
|
pytest-xdist,
|
|
|
|
safetensors,
|
|
|
|
scipy,
|
|
|
|
sentencepiece,
|
|
|
|
soundfile,
|
|
|
|
syrupy,
|
|
|
|
tabulate,
|
|
|
|
tiktoken,
|
|
|
|
transformers,
|
2024-07-27 06:49:29 +00:00
|
|
|
triton,
|
2024-06-05 15:53:02 +00:00
|
|
|
xformers,
|
2023-10-09 19:29:22 +00:00
|
|
|
}:
|
|
|
|
|
|
|
|
buildPythonPackage rec {
|
|
|
|
inherit (openllm-core) src version;
|
|
|
|
pname = "openllm";
|
2023-11-16 04:20:00 +00:00
|
|
|
pyproject = true;
|
2023-10-09 19:29:22 +00:00
|
|
|
|
|
|
|
disabled = pythonOlder "3.8";
|
|
|
|
|
2024-04-21 15:54:59 +00:00
|
|
|
sourceRoot = "${src.name}/openllm-python";
|
2023-10-09 19:29:22 +00:00
|
|
|
|
|
|
|
|
|
|
|
pythonRemoveDeps = [
|
|
|
|
# remove cuda-python as it has an unfree license
|
|
|
|
"cuda-python"
|
|
|
|
];
|
|
|
|
|
2024-04-21 15:54:59 +00:00
|
|
|
build-system = [
|
|
|
|
hatch-fancy-pypi-readme
|
|
|
|
hatch-vcs
|
|
|
|
hatchling
|
|
|
|
];
|
|
|
|
|
2024-06-05 15:53:02 +00:00
|
|
|
dependencies =
|
|
|
|
[
|
|
|
|
accelerate
|
|
|
|
bentoml
|
|
|
|
bitsandbytes
|
|
|
|
build
|
|
|
|
click
|
|
|
|
einops
|
|
|
|
ghapi
|
|
|
|
openllm-client
|
|
|
|
openllm-core
|
|
|
|
optimum
|
|
|
|
safetensors
|
|
|
|
scipy
|
|
|
|
sentencepiece
|
|
|
|
transformers
|
|
|
|
]
|
|
|
|
++ bentoml.optional-dependencies.io
|
|
|
|
++ tabulate.optional-dependencies.widechars
|
|
|
|
++ transformers.optional-dependencies.tokenizers
|
|
|
|
++ transformers.optional-dependencies.torch;
|
2023-10-09 19:29:22 +00:00
|
|
|
|
2024-04-21 15:54:59 +00:00
|
|
|
optional-dependencies = {
|
2023-10-09 19:29:22 +00:00
|
|
|
agents = [
|
|
|
|
# diffusers
|
|
|
|
soundfile
|
|
|
|
transformers
|
|
|
|
] ++ transformers.optional-dependencies.agents;
|
2024-01-02 11:29:13 +00:00
|
|
|
awq = [
|
|
|
|
# autoawq
|
|
|
|
];
|
2023-10-09 19:29:22 +00:00
|
|
|
baichuan = [
|
|
|
|
# cpm-kernels
|
|
|
|
];
|
|
|
|
chatglm = [
|
|
|
|
# cpm-kernels
|
2024-01-02 11:29:13 +00:00
|
|
|
];
|
2024-06-05 15:53:02 +00:00
|
|
|
ctranslate = [ ctranslate2 ];
|
|
|
|
falcon = [ xformers ];
|
2023-10-09 19:29:22 +00:00
|
|
|
fine-tune = [
|
|
|
|
datasets
|
2024-01-02 11:29:13 +00:00
|
|
|
huggingface-hub
|
2023-10-09 19:29:22 +00:00
|
|
|
peft
|
|
|
|
# trl
|
|
|
|
];
|
|
|
|
ggml = [
|
|
|
|
# ctransformers
|
|
|
|
];
|
|
|
|
gptq = [
|
|
|
|
# auto-gptq
|
|
|
|
]; # ++ autogptq.optional-dependencies.triton;
|
2024-06-05 15:53:02 +00:00
|
|
|
grpc = [ bentoml ] ++ bentoml.optional-dependencies.grpc;
|
2024-07-27 06:49:29 +00:00
|
|
|
mpt = [ triton ];
|
2023-10-09 19:29:22 +00:00
|
|
|
openai = [
|
|
|
|
openai
|
|
|
|
tiktoken
|
2024-01-02 11:29:13 +00:00
|
|
|
] ++ openai.optional-dependencies.datalib;
|
2023-10-09 19:29:22 +00:00
|
|
|
playground = [
|
|
|
|
ipython
|
|
|
|
jupyter
|
|
|
|
jupytext
|
|
|
|
nbformat
|
|
|
|
notebook
|
|
|
|
];
|
2024-06-05 15:53:02 +00:00
|
|
|
starcoder = [ bitsandbytes ];
|
2023-10-09 19:29:22 +00:00
|
|
|
vllm = [
|
|
|
|
# vllm
|
|
|
|
];
|
2024-06-05 15:53:02 +00:00
|
|
|
full =
|
|
|
|
with optional-dependencies;
|
|
|
|
(
|
|
|
|
agents
|
|
|
|
++ awq
|
|
|
|
++ baichuan
|
|
|
|
++ chatglm
|
|
|
|
++ ctranslate
|
|
|
|
++ falcon
|
|
|
|
++ fine-tune
|
|
|
|
++ ggml
|
|
|
|
++ gptq
|
|
|
|
++ mpt
|
|
|
|
# disambiguate between derivation input and passthru field
|
|
|
|
++ optional-dependencies.openai
|
|
|
|
++ playground
|
|
|
|
++ starcoder
|
|
|
|
++ vllm
|
|
|
|
);
|
2024-04-21 15:54:59 +00:00
|
|
|
all = optional-dependencies.full;
|
2023-10-09 19:29:22 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
nativeCheckInputs = [
|
|
|
|
docker
|
|
|
|
hypothesis
|
|
|
|
pytest-mock
|
|
|
|
pytest-randomly
|
|
|
|
pytest-rerunfailures
|
|
|
|
pytest-xdist
|
|
|
|
pytestCheckHook
|
|
|
|
syrupy
|
|
|
|
];
|
|
|
|
|
|
|
|
preCheck = ''
|
|
|
|
export HOME=$TMPDIR
|
|
|
|
# skip GPUs test on CI
|
|
|
|
export GITHUB_ACTIONS=1
|
2023-11-16 04:20:00 +00:00
|
|
|
# disable hypothesis' deadline
|
|
|
|
export CI=1
|
2023-10-09 19:29:22 +00:00
|
|
|
'';
|
|
|
|
|
2024-01-02 11:29:13 +00:00
|
|
|
disabledTestPaths = [
|
|
|
|
# require network access
|
|
|
|
"tests/models"
|
|
|
|
];
|
|
|
|
|
2023-10-09 19:29:22 +00:00
|
|
|
disabledTests = [
|
2024-01-02 11:29:13 +00:00
|
|
|
# incompatible with recent TypedDict
|
|
|
|
# https://github.com/bentoml/OpenLLM/blob/f3fd32d596253ae34c68e2e9655f19f40e05f666/openllm-python/tests/configuration_test.py#L18-L21
|
|
|
|
"test_missing_default"
|
2023-10-09 19:29:22 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
pythonImportsCheck = [ "openllm" ];
|
|
|
|
|
|
|
|
meta = with lib; {
|
|
|
|
description = "Operating LLMs in production";
|
|
|
|
homepage = "https://github.com/bentoml/OpenLLM/tree/main/openllm-python";
|
|
|
|
changelog = "https://github.com/bentoml/OpenLLM/blob/${src.rev}/CHANGELOG.md";
|
|
|
|
license = licenses.asl20;
|
2024-06-05 15:53:02 +00:00
|
|
|
maintainers = with maintainers; [
|
|
|
|
happysalada
|
|
|
|
natsukium
|
|
|
|
];
|
2023-10-09 19:29:22 +00:00
|
|
|
};
|
|
|
|
}
|