depot/third_party/nixpkgs/pkgs/development/python-modules/sentence-transformers/default.nix

109 lines
2.3 KiB
Nix

{
lib,
stdenv,
buildPythonPackage,
fetchFromGitHub,
# build-system
setuptools,
# dependencies
huggingface-hub,
nltk,
numpy,
scikit-learn,
scipy,
sentencepiece,
tokenizers,
torch,
tqdm,
transformers,
# tests
accelerate,
datasets,
pytestCheckHook,
pytest-cov-stub,
}:
buildPythonPackage rec {
pname = "sentence-transformers";
version = "3.3.1";
pyproject = true;
src = fetchFromGitHub {
owner = "UKPLab";
repo = "sentence-transformers";
rev = "refs/tags/v${version}";
hash = "sha256-D8LHzEVHRuayod084B05cL3OvZiO1ByDZLxROGxTD0I=";
};
build-system = [ setuptools ];
dependencies = [
huggingface-hub
nltk
numpy
scikit-learn
scipy
sentencepiece
tokenizers
torch
tqdm
transformers
];
nativeCheckInputs = [
accelerate
datasets
pytestCheckHook
pytest-cov-stub
];
pythonImportsCheck = [ "sentence_transformers" ];
disabledTests = [
# Tests require network access
"test_cmnrl_same_grad"
"test_forward"
"test_initialization_with_embedding_dim"
"test_initialization_with_embedding_weights"
"test_LabelAccuracyEvaluator"
"test_model_card_reuse"
"test_paraphrase_mining"
"test_ParaphraseMiningEvaluator"
"test_save_and_load"
"test_simple_encode"
"test_tokenize"
"test_trainer"
"test_trainer_invalid_column_names"
"test_trainer_multi_dataset_errors"
];
disabledTestPaths = [
# Tests require network access
"tests/evaluation/test_information_retrieval_evaluator.py"
"tests/test_compute_embeddings.py"
"tests/test_cross_encoder.py"
"tests/test_model_card_data.py"
"tests/test_multi_process.py"
"tests/test_pretrained_stsb.py"
"tests/test_sentence_transformer.py"
"tests/test_train_stsb.py"
];
# Sentence-transformer needs a writable hf_home cache
postInstall = ''
export HF_HOME=$(mktemp -d)
'';
meta = {
description = "Multilingual Sentence & Image Embeddings with BERT";
homepage = "https://github.com/UKPLab/sentence-transformers";
changelog = "https://github.com/UKPLab/sentence-transformers/releases/tag/v${version}";
license = lib.licenses.asl20;
maintainers = with lib.maintainers; [ dit7ya ];
# Segmentation fault at import
broken = stdenv.hostPlatform.system == "x86_64-darwin";
};
}