2020-01-13 22:18:02 +00:00
|
|
|
{ lib
|
|
|
|
, buildPythonPackage
|
|
|
|
, fetchFromGitHub
|
|
|
|
, pytest
|
|
|
|
, nose
|
|
|
|
, isPy27
|
|
|
|
, numpy
|
|
|
|
, scipy
|
|
|
|
, sparse
|
|
|
|
, pytorch
|
|
|
|
}:
|
|
|
|
|
|
|
|
buildPythonPackage rec {
|
|
|
|
pname = "tensorly";
|
|
|
|
version = "0.4.5";
|
|
|
|
disabled = isPy27;
|
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = pname;
|
|
|
|
repo = pname;
|
|
|
|
rev = version;
|
|
|
|
sha256 = "1ml91yaxwx4msisxbm92yf22qfrscvk58f3z2r1jhi96pw2k4i7x";
|
|
|
|
};
|
|
|
|
|
2020-10-04 17:25:50 +00:00
|
|
|
propagatedBuildInputs = [ numpy scipy sparse ]
|
|
|
|
++ lib.optionals (!doCheck) [ nose ]; # upstream added nose to install_requires
|
|
|
|
|
2020-01-13 22:18:02 +00:00
|
|
|
checkInputs = [ pytest nose pytorch ];
|
|
|
|
# also has a cupy backend, but the tests are currently broken
|
|
|
|
# (e.g. attempts to access cupy.qr instead of cupy.linalg.qr)
|
|
|
|
# and this backend also adds a non-optional CUDA dependence,
|
|
|
|
# as well as tensorflow and mxnet backends, but the tests don't
|
|
|
|
# seem to exercise these backend by default
|
|
|
|
|
2020-10-04 17:25:50 +00:00
|
|
|
# uses >= 140GB of ram to test
|
|
|
|
doCheck = false;
|
2020-01-13 22:18:02 +00:00
|
|
|
checkPhase = ''
|
|
|
|
runHook preCheck
|
|
|
|
nosetests -e "test_cupy"
|
|
|
|
runHook postCheck
|
|
|
|
'';
|
|
|
|
|
2020-10-04 17:25:50 +00:00
|
|
|
pythonImportsCheck = [ "tensorly" ];
|
|
|
|
|
2020-01-13 22:18:02 +00:00
|
|
|
meta = with lib; {
|
|
|
|
description = "Tensor learning in Python";
|
2020-04-01 01:11:51 +00:00
|
|
|
homepage = "https://tensorly.org/";
|
2020-01-13 22:18:02 +00:00
|
|
|
license = licenses.bsd3;
|
|
|
|
maintainers = [ maintainers.bcdarwin ];
|
|
|
|
};
|
|
|
|
}
|