2024-06-05 15:53:02 +00:00
|
|
|
{
|
|
|
|
lib,
|
|
|
|
buildPythonPackage,
|
|
|
|
fetchFromGitHub,
|
|
|
|
pythonOlder,
|
|
|
|
coloredlogs,
|
|
|
|
datasets,
|
|
|
|
diffusers,
|
|
|
|
evaluate,
|
|
|
|
h5py,
|
|
|
|
huggingface-hub,
|
|
|
|
numpy,
|
|
|
|
onnx,
|
|
|
|
onnxruntime,
|
|
|
|
packaging,
|
|
|
|
protobuf,
|
|
|
|
setuptools,
|
|
|
|
sympy,
|
|
|
|
tensorflow,
|
|
|
|
tf2onnx,
|
|
|
|
timm,
|
|
|
|
torch,
|
|
|
|
transformers,
|
2023-08-22 20:05:09 +00:00
|
|
|
}:
|
|
|
|
|
|
|
|
buildPythonPackage rec {
|
|
|
|
pname = "optimum";
|
2024-07-27 06:49:29 +00:00
|
|
|
version = "1.21.2";
|
2024-06-05 15:53:02 +00:00
|
|
|
pyproject = true;
|
2023-08-22 20:05:09 +00:00
|
|
|
|
|
|
|
disabled = pythonOlder "3.7";
|
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "huggingface";
|
|
|
|
repo = "optimum";
|
|
|
|
rev = "refs/tags/v${version}";
|
2024-07-27 06:49:29 +00:00
|
|
|
hash = "sha256-OhquE+QhNOXFkKy/TvKlLn65CMchvKjcbR/S4Rl2MT4=";
|
2023-08-22 20:05:09 +00:00
|
|
|
};
|
|
|
|
|
2024-06-05 15:53:02 +00:00
|
|
|
build-system = [ setuptools ];
|
|
|
|
|
|
|
|
dependencies = [
|
2023-08-22 20:05:09 +00:00
|
|
|
coloredlogs
|
|
|
|
datasets
|
|
|
|
huggingface-hub
|
|
|
|
numpy
|
|
|
|
packaging
|
|
|
|
sympy
|
|
|
|
torch
|
|
|
|
transformers
|
|
|
|
] ++ transformers.optional-dependencies.sentencepiece;
|
|
|
|
|
2024-06-05 15:53:02 +00:00
|
|
|
optional-dependencies = {
|
2023-08-22 20:05:09 +00:00
|
|
|
onnxruntime = [
|
|
|
|
onnx
|
|
|
|
onnxruntime
|
|
|
|
datasets
|
|
|
|
evaluate
|
|
|
|
protobuf
|
|
|
|
];
|
|
|
|
exporters = [
|
|
|
|
onnx
|
|
|
|
onnxruntime
|
|
|
|
timm
|
|
|
|
];
|
|
|
|
exporters-tf = [
|
|
|
|
tensorflow
|
|
|
|
tf2onnx
|
|
|
|
onnx
|
|
|
|
onnxruntime
|
|
|
|
timm
|
|
|
|
h5py
|
|
|
|
numpy
|
|
|
|
];
|
2024-06-05 15:53:02 +00:00
|
|
|
diffusers = [ diffusers ];
|
2023-08-22 20:05:09 +00:00
|
|
|
intel = [
|
|
|
|
# optimum-intel
|
|
|
|
];
|
|
|
|
openvino = [
|
|
|
|
# optimum-intel
|
|
|
|
]; # ++ optimum-intel.optional-dependencies.openvino;
|
|
|
|
nncf = [
|
|
|
|
# optimum-intel
|
|
|
|
]; # ++ optimum-intel.optional-dependencies.nncf;
|
|
|
|
neural-compressor = [
|
|
|
|
# optimum-intel
|
|
|
|
]; # ++ optimum-intel.optional-dependencies.neural-compressor;
|
|
|
|
graphcore = [
|
|
|
|
# optimum-graphcore
|
|
|
|
];
|
|
|
|
habana = [
|
|
|
|
transformers
|
|
|
|
# optimum-habana
|
|
|
|
];
|
|
|
|
neuron = [
|
|
|
|
# optimum-neuron
|
|
|
|
]; # ++ optimum-neuron.optional-dependencies.neuron;
|
|
|
|
neuronx = [
|
|
|
|
# optimum-neuron
|
|
|
|
]; # ++ optimum-neuron.optional-dependencies.neuronx;
|
|
|
|
furiosa = [
|
|
|
|
# optimum-furiosa
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
|
|
|
# almost all tests try to connect to https://huggingface.co
|
|
|
|
doCheck = false;
|
|
|
|
|
|
|
|
pythonImportsCheck = [ "optimum" ];
|
|
|
|
|
|
|
|
meta = with lib; {
|
|
|
|
description = "Accelerate training and inference of 🤗 Transformers and 🤗 Diffusers with easy to use hardware optimization tools";
|
2024-04-21 15:54:59 +00:00
|
|
|
mainProgram = "optimum-cli";
|
2023-08-22 20:05:09 +00:00
|
|
|
homepage = "https://github.com/huggingface/optimum";
|
|
|
|
changelog = "https://github.com/huggingface/optimum/releases/tag/${src.rev}";
|
|
|
|
license = licenses.asl20;
|
|
|
|
maintainers = with maintainers; [ natsukium ];
|
|
|
|
};
|
|
|
|
}
|