2020-01-03 11:52:42 +00:00
|
|
|
{ lib
|
|
|
|
, fetchPypi
|
2021-08-11 03:29:42 +00:00
|
|
|
, fetchpatch
|
2020-01-03 11:52:42 +00:00
|
|
|
, python
|
|
|
|
, buildPythonPackage
|
|
|
|
, gfortran
|
2020-08-09 06:35:41 +00:00
|
|
|
, hypothesis
|
2021-02-01 05:29:05 +00:00
|
|
|
, pytest
|
2022-07-15 10:50:02 +00:00
|
|
|
, typing-extensions
|
2020-01-03 11:52:42 +00:00
|
|
|
, blas
|
2020-03-31 14:47:18 +00:00
|
|
|
, lapack
|
2020-01-03 11:52:42 +00:00
|
|
|
, writeTextFile
|
|
|
|
, cython
|
|
|
|
, setuptoolsBuildHook
|
2021-02-01 05:29:05 +00:00
|
|
|
, pythonOlder
|
|
|
|
}:
|
2016-02-04 20:30:39 +00:00
|
|
|
|
2020-04-20 20:50:55 +00:00
|
|
|
assert (!blas.isILP64) && (!lapack.isILP64);
|
2020-03-31 14:47:18 +00:00
|
|
|
|
2018-10-18 19:00:48 +00:00
|
|
|
let
|
|
|
|
cfg = writeTextFile {
|
|
|
|
name = "site.cfg";
|
|
|
|
text = (lib.generators.toINI {} {
|
2020-03-31 14:47:18 +00:00
|
|
|
${blas.implementation} = {
|
2020-04-20 20:31:59 +00:00
|
|
|
include_dirs = "${lib.getDev blas}/include:${lib.getDev lapack}/include";
|
2020-03-31 14:47:18 +00:00
|
|
|
library_dirs = "${blas}/lib:${lapack}/lib";
|
2020-08-27 02:14:53 +00:00
|
|
|
runtime_library_dirs = "${blas}/lib:${lapack}/lib";
|
2020-04-20 18:53:29 +00:00
|
|
|
libraries = "lapack,lapacke,blas,cblas";
|
2018-10-18 19:00:48 +00:00
|
|
|
};
|
2020-05-07 21:26:55 +00:00
|
|
|
lapack = {
|
|
|
|
include_dirs = "${lib.getDev lapack}/include";
|
|
|
|
library_dirs = "${lapack}/lib";
|
2020-08-27 02:14:53 +00:00
|
|
|
runtime_library_dirs = "${lapack}/lib";
|
2020-05-07 21:26:55 +00:00
|
|
|
};
|
|
|
|
blas = {
|
|
|
|
include_dirs = "${lib.getDev blas}/include";
|
|
|
|
library_dirs = "${blas}/lib";
|
2020-08-27 02:14:53 +00:00
|
|
|
runtime_library_dirs = "${blas}/lib";
|
2020-05-07 21:26:55 +00:00
|
|
|
};
|
2018-10-18 19:00:48 +00:00
|
|
|
});
|
|
|
|
};
|
|
|
|
in buildPythonPackage rec {
|
2017-05-16 07:22:07 +00:00
|
|
|
pname = "numpy";
|
2022-01-23 00:02:42 +00:00
|
|
|
|
|
|
|
# Attention! v1.22.0 breaks scipy and by extension scikit-learn, so
|
|
|
|
# build both to verify they don't break.
|
|
|
|
# https://github.com/scipy/scipy/issues/15414
|
2022-07-15 10:50:02 +00:00
|
|
|
version = "1.23.1";
|
2022-01-23 00:02:42 +00:00
|
|
|
|
2020-01-03 11:52:42 +00:00
|
|
|
format = "pyproject.toml";
|
2021-02-01 05:29:05 +00:00
|
|
|
disabled = pythonOlder "3.7";
|
2016-02-04 20:30:39 +00:00
|
|
|
|
2017-09-28 08:50:50 +00:00
|
|
|
src = fetchPypi {
|
|
|
|
inherit pname version;
|
2022-07-15 10:50:02 +00:00
|
|
|
extension = "tar.gz";
|
|
|
|
hash = "sha256-10jvNJv+8uEZS1naN+1aKcGeqNfmNCAZkhuiuk/YtiQ=";
|
2017-05-16 07:22:07 +00:00
|
|
|
};
|
2016-02-04 20:30:39 +00:00
|
|
|
|
2021-11-23 06:00:05 +00:00
|
|
|
patches = lib.optionals python.hasDistutilsCxxPatch [
|
2018-04-26 21:54:25 +00:00
|
|
|
# We patch cpython/distutils to fix https://bugs.python.org/issue1222585
|
|
|
|
# Patching of numpy.distutils is needed to prevent it from undoing the
|
|
|
|
# patch to distutils.
|
2016-10-15 21:51:09 +00:00
|
|
|
./numpy-distutils-C++.patch
|
|
|
|
];
|
|
|
|
|
2021-02-01 05:29:05 +00:00
|
|
|
nativeBuildInputs = [ gfortran cython setuptoolsBuildHook ];
|
|
|
|
buildInputs = [ blas lapack ];
|
|
|
|
|
2020-11-17 16:31:06 +00:00
|
|
|
# we default openblas to build with 64 threads
|
|
|
|
# if a machine has more than 64 threads, it will segfault
|
|
|
|
# see https://github.com/xianyi/OpenBLAS/issues/2993
|
2016-02-04 20:30:39 +00:00
|
|
|
preConfigure = ''
|
|
|
|
sed -i 's/-faltivec//' numpy/distutils/system_info.py
|
2017-07-30 08:19:02 +00:00
|
|
|
export NPY_NUM_BUILD_JOBS=$NIX_BUILD_CORES
|
2020-11-17 16:31:06 +00:00
|
|
|
export OMP_NUM_THREADS=$((NIX_BUILD_CORES > 64 ? 64 : NIX_BUILD_CORES))
|
2016-02-04 20:30:39 +00:00
|
|
|
'';
|
|
|
|
|
|
|
|
preBuild = ''
|
2018-10-18 19:00:48 +00:00
|
|
|
ln -s ${cfg} site.cfg
|
2016-02-04 20:30:39 +00:00
|
|
|
'';
|
|
|
|
|
2017-07-30 08:19:02 +00:00
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
2020-11-29 22:12:41 +00:00
|
|
|
checkInputs = [
|
2021-02-01 05:29:05 +00:00
|
|
|
pytest
|
2020-11-29 22:12:41 +00:00
|
|
|
hypothesis
|
2022-07-15 10:50:02 +00:00
|
|
|
typing-extensions
|
2020-11-29 22:12:41 +00:00
|
|
|
];
|
2020-08-09 06:35:41 +00:00
|
|
|
|
2016-02-04 20:30:39 +00:00
|
|
|
checkPhase = ''
|
|
|
|
runHook preCheck
|
|
|
|
pushd dist
|
|
|
|
${python.interpreter} -c 'import numpy; numpy.test("fast", verbose=10)'
|
|
|
|
popd
|
|
|
|
runHook postCheck
|
|
|
|
'';
|
|
|
|
|
|
|
|
passthru = {
|
2020-03-31 14:47:18 +00:00
|
|
|
# just for backwards compatibility
|
|
|
|
blas = blas.provider;
|
|
|
|
blasImplementation = blas.implementation;
|
|
|
|
inherit cfg;
|
2016-02-04 20:30:39 +00:00
|
|
|
};
|
|
|
|
|
2019-07-02 21:36:09 +00:00
|
|
|
# Disable test
|
2016-12-24 11:06:28 +00:00
|
|
|
# - test_large_file_support: takes a long time and can cause the machine to run out of disk space
|
2019-07-02 21:36:09 +00:00
|
|
|
NOSE_EXCLUDE="test_large_file_support";
|
2016-02-04 20:30:39 +00:00
|
|
|
|
|
|
|
meta = {
|
|
|
|
description = "Scientific tools for Python";
|
2020-04-01 01:11:51 +00:00
|
|
|
homepage = "https://numpy.org/";
|
2020-10-22 13:24:51 +00:00
|
|
|
license = lib.licenses.bsd3;
|
2016-02-04 20:30:39 +00:00
|
|
|
maintainers = with lib.maintainers; [ fridh ];
|
2017-05-16 07:22:07 +00:00
|
|
|
};
|
|
|
|
}
|