Merge pull request #22084 from LumiGuide/opencv-3.2.0

opencv: upgrade from 3.1.0 to 3.2.0
This commit is contained in:
Michael Raskin 2017-01-24 18:05:05 +00:00 committed by GitHub
commit 62b0495614

View File

@ -1,16 +1,17 @@
{ lib, stdenv, fetchurl, fetchpatch, fetchFromGitHub, cmake, pkgconfig, unzip { lib, stdenv, fetchurl, fetchpatch, fetchFromGitHub, cmake, pkgconfig, unzip, zlib
, zlib
, enableIpp ? false
, enableContrib ? false
, enablePython ? false, pythonPackages
, enableGtk2 ? false, gtk2
, enableGtk3 ? false, gtk3
, enableJPEG ? true, libjpeg , enableJPEG ? true, libjpeg
, enablePNG ? true, libpng , enablePNG ? true, libpng
, enableTIFF ? true, libtiff , enableTIFF ? true, libtiff
, enableWebP ? true, libwebp , enableWebP ? true, libwebp
, enableEXR ? true, openexr, ilmbase , enableEXR ? true, openexr, ilmbase
, enableJPEG2K ? true, jasper , enableJPEG2K ? true, jasper
, enableIpp ? false
, enableContrib ? false, protobuf3_1
, enablePython ? false, pythonPackages
, enableGtk2 ? false, gtk2
, enableGtk3 ? false, gtk3
, enableFfmpeg ? false, ffmpeg , enableFfmpeg ? false, ffmpeg
, enableGStreamer ? false, gst_all_1 , enableGStreamer ? false, gst_all_1
, enableEigen ? false, eigen , enableEigen ? false, eigen
@ -18,53 +19,66 @@
}: }:
let let
version = "3.1.0"; version = "3.2.0";
src = fetchFromGitHub {
owner = "opencv";
repo = "opencv";
rev = version;
sha256 = "0f59g0dvhp5xg1xa3r4lp351a7x0k03i77ylgcf69ns3y47qd16p";
};
contribSrc = fetchFromGitHub { contribSrc = fetchFromGitHub {
owner = "Itseez"; owner = "opencv";
repo = "opencv_contrib"; repo = "opencv_contrib";
rev = version; rev = version;
sha256 = "153yx62f34gl3zd6vgxv0fj3wccwmq78lnawlda1f6xhrclg9bax"; sha256 = "1lynpbxz1jay3ya5y45zac5v8c6ifgk4ssn8d1chfdk3spi691jj";
};
vggFiles = fetchFromGitHub {
owner = "opencv";
repo = "opencv_3rdparty";
rev = "fccf7cd6a4b12079f73bbfb21745f9babcd4eb1d";
sha256 = "0r9fam8dplyqqsd3qgpnnfgf9l7lj44di19rxwbm8mxiw0rlcdvy";
};
bootdescFiles = fetchFromGitHub {
owner = "opencv";
repo = "opencv_3rdparty";
rev = "34e4206aef44d50e6bbcd0ab06354b52e7466d26";
sha256 = "13yig1xhvgghvxspxmdidss5lqiikpjr0ddm83jsi0k85j92sn62";
}; };
opencvFlag = name: enabled: "-DWITH_${name}=${if enabled then "ON" else "OFF"}"; opencvFlag = name: enabled: "-DWITH_${name}=${if enabled then "ON" else "OFF"}";
in in
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
name = "opencv-${version}"; name = "opencv-${version}";
inherit version; inherit version src;
src = fetchFromGitHub { postUnpack =
owner = "Itseez"; (lib.optionalString enableContrib ''
repo = "opencv"; cp --no-preserve=mode -r "${contribSrc}/modules" "$NIX_BUILD_TOP/opencv_contrib"
rev = version;
sha256 = "1l0w12czavgs0wzw1c594g358ilvfg2fn32cn8z7pv84zxj4g429";
};
patches = for name in vgg_generated_48.i \
lib.optionals enableCuda [ vgg_generated_64.i \
(fetchpatch { # Patch for CUDA 8 compatibility vgg_generated_80.i \
url = "https://github.com/opencv/opencv/commit/10896129b39655e19e4e7c529153cb5c2191a1db.patch"; vgg_generated_120.i; do
sha256 = "0jka3kxxywgs3prqqgym5kav6p73rrblwj50k1nf3fvfpk194ah1"; ln -s "${vggFiles}/$name" "$NIX_BUILD_TOP/opencv_contrib/xfeatures2d/src/$name"
}) done
(fetchpatch { # Patch to add CUDA Compute Capability compilation targets up to 6.0
url = "https://github.com/opencv/opencv/commit/d76f258aebdf63f979a205cabe6d3e81700a7cd8.patch";
sha256 = "00b3msfgrcw7laij6qafn4b18c1dl96xxpzwx05wxzrjldqb6kqg";
})
]
++ lib.optional enablePython (fetchpatch { # Patch to fix FlannBasedMatcher under python
url = "https://github.com/opencv/opencv/commit/05cfe28612fd8dc8fb0ccb876df945c7b435dd26.patch";
sha256 = "0niza5lybr1ljzdkyiapr16laa468168qinpy5qn00yimnaygpm6";
});
for name in boostdesc_bgm.i \
boostdesc_bgm_bi.i \
boostdesc_bgm_hd.i \
boostdesc_binboost_064.i \
boostdesc_binboost_128.i \
boostdesc_binboost_256.i \
boostdesc_lbgm.i; do
ln -s "${bootdescFiles}/$name" "$NIX_BUILD_TOP/opencv_contrib/xfeatures2d/src/$name"
done
'');
preConfigure = preConfigure =
# By default ippicv gets downloaded by cmake each time opencv is build. See: (let version = "20151201";
# https://github.com/opencv/opencv/blob/3.1.0/3rdparty/ippicv/downloader.cmake
# Fortunately cmake doesn't download ippicv if it's already there.
# So to prevent repeated downloads we store it in the nix store
# and create a symbolic link to it.
let version = "20151201";
md5 = "808b791a6eac9ed78d32a7666804320e"; md5 = "808b791a6eac9ed78d32a7666804320e";
sha256 = "1nph0w0pdcxwhdb5lxkb8whpwd9ylvwl97hn0k425amg80z86cs3"; sha256 = "1nph0w0pdcxwhdb5lxkb8whpwd9ylvwl97hn0k425amg80z86cs3";
rev = "81a676001ca8075ada498583e4166079e5744668"; rev = "81a676001ca8075ada498583e4166079e5744668";
@ -76,11 +90,14 @@ stdenv.mkDerivation rec {
inherit sha256; inherit sha256;
}; };
dir = "3rdparty/ippicv/downloads/${platform}-${md5}"; dir = "3rdparty/ippicv/downloads/${platform}-${md5}";
in lib.optionalString enableIpp in lib.optionalString enableIpp ''
''
mkdir -p "${dir}" mkdir -p "${dir}"
ln -s "${ippicv}" "${dir}/${name}" ln -s "${ippicv}" "${dir}/${name}"
''; ''
) +
(lib.optionalString enableContrib ''
cmakeFlagsArray+=("-DOPENCV_EXTRA_MODULES_PATH=$NIX_BUILD_TOP/opencv_contrib")
'');
buildInputs = buildInputs =
[ zlib ] [ zlib ]
@ -96,7 +113,8 @@ stdenv.mkDerivation rec {
++ lib.optional enableFfmpeg ffmpeg ++ lib.optional enableFfmpeg ffmpeg
++ lib.optionals enableGStreamer (with gst_all_1; [ gstreamer gst-plugins-base ]) ++ lib.optionals enableGStreamer (with gst_all_1; [ gstreamer gst-plugins-base ])
++ lib.optional enableEigen eigen ++ lib.optional enableEigen eigen
++ lib.optional enableCuda [ cudatoolkit gcc5 ] ++ lib.optionals enableCuda [ cudatoolkit gcc5 ]
++ lib.optional enableContrib protobuf3_1
; ;
propagatedBuildInputs = lib.optional enablePython pythonPackages.numpy; propagatedBuildInputs = lib.optional enablePython pythonPackages.numpy;
@ -115,8 +133,8 @@ stdenv.mkDerivation rec {
(opencvFlag "OPENEXR" enableEXR) (opencvFlag "OPENEXR" enableEXR)
(opencvFlag "CUDA" enableCuda) (opencvFlag "CUDA" enableCuda)
(opencvFlag "CUBLAS" enableCuda) (opencvFlag "CUBLAS" enableCuda)
] ++ lib.optionals enableContrib [ "-DOPENCV_EXTRA_MODULES_PATH=${contribSrc}/modules" ] ] ++ lib.optionals enableCuda [ "-DCUDA_FAST_MATH=ON" ]
++ lib.optionals enableCuda [ "-DCUDA_FAST_MATH=ON" ]; ++ lib.optional enableContrib "-DBUILD_PROTOBUF=off";
enableParallelBuilding = true; enableParallelBuilding = true;