gnu: unionfs-fuse: Don't use unstable tarball.
[jackhill/guix/guix.git] / gnu / packages / machine-learning.scm
CommitLineData
741115b6 1;;; GNU Guix --- Functional package management for GNU
7d4cab74 2;;; Copyright © 2015, 2016, 2017, 2018, 2019 Ricardo Wurmus <rekado@elephly.net>
d56d3ae7 3;;; Copyright © 2016, 2020 Efraim Flashner <efraim@flashner.co.il>
382550f0 4;;; Copyright © 2016, 2017, 2020 Marius Bakke <mbakke@fastmail.com>
be6eb2f1 5;;; Copyright © 2016 Hartmut Goebel <h.goebel@crazy-compilers.com>
5ed72097 6;;; Copyright © 2018, 2019 Tobias Geerinckx-Rice <me@tobias.gr>
3a354e10 7;;; Copyright © 2018 Kei Kebreau <kkebreau@posteo.net>
a9b34762
MM
8;;; Copyright © 2018 Mark Meyer <mark@ofosos.org>
9;;; Copyright © 2018 Ben Woodcroft <donttrustben@gmail.com>
2dab4188 10;;; Copyright © 2018 Fis Trivial <ybbs.daans@hotmail.com>
564cf93f 11;;; Copyright © 2018 Julien Lepiller <julien@lepiller.eu>
df4c8434 12;;; Copyright © 2018 Björn Höfling <bjoern.hoefling@bjoernhoefling.de>
d60b064d 13;;; Copyright © 2019 Nicolas Goaziou <mail@nicolasgoaziou.fr>
6e760872 14;;; Copyright © 2019 Guillaume Le Vaillant <glv@posteo.net>
5e42d197 15;;; Copyright © 2019 Brett Gilio <brettg@gnu.org>
741115b6
RW
16;;;
17;;; This file is part of GNU Guix.
18;;;
19;;; GNU Guix is free software; you can redistribute it and/or modify it
20;;; under the terms of the GNU General Public License as published by
21;;; the Free Software Foundation; either version 3 of the License, or (at
22;;; your option) any later version.
23;;;
24;;; GNU Guix is distributed in the hope that it will be useful, but
25;;; WITHOUT ANY WARRANTY; without even the implied warranty of
26;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
27;;; GNU General Public License for more details.
28;;;
29;;; You should have received a copy of the GNU General Public License
30;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
31
32(define-module (gnu packages machine-learning)
33 #:use-module ((guix licenses) #:prefix license:)
34 #:use-module (guix packages)
35 #:use-module (guix utils)
36 #:use-module (guix download)
23aab4ab 37 #:use-module (guix svn-download)
6e760872 38 #:use-module (guix build-system asdf)
c1670a81 39 #:use-module (guix build-system cmake)
741115b6 40 #:use-module (guix build-system gnu)
0a3063d6 41 #:use-module (guix build-system ocaml)
be6eb2f1 42 #:use-module (guix build-system python)
8406138b 43 #:use-module (guix build-system r)
a9b34762 44 #:use-module (guix git-download)
71f80f54 45 #:use-module (gnu packages)
0dfeb285 46 #:use-module (gnu packages adns)
5a14e81e 47 #:use-module (gnu packages algebra)
b9445d0b 48 #:use-module (gnu packages audio)
23aab4ab 49 #:use-module (gnu packages autotools)
b9445d0b 50 #:use-module (gnu packages base)
99260014 51 #:use-module (gnu packages bash)
0931c609 52 #:use-module (gnu packages boost)
be6eb2f1 53 #:use-module (gnu packages check)
0931c609 54 #:use-module (gnu packages compression)
9e37e537 55 #:use-module (gnu packages cran)
4fa16c9a 56 #:use-module (gnu packages databases)
23aab4ab 57 #:use-module (gnu packages dejagnu)
0931c609 58 #:use-module (gnu packages gcc)
b9445d0b 59 #:use-module (gnu packages glib)
f1765b57 60 #:use-module (gnu packages graphviz)
b9445d0b 61 #:use-module (gnu packages gstreamer)
5f0ff6a9 62 #:use-module (gnu packages image)
b9445d0b 63 #:use-module (gnu packages linux)
88f06fd0 64 #:use-module (gnu packages lisp-xyz)
0931c609 65 #:use-module (gnu packages maths)
112c2c01 66 #:use-module (gnu packages mpi)
0a3063d6 67 #:use-module (gnu packages ocaml)
3929f46c 68 #:use-module (gnu packages onc-rpc)
791c11d6 69 #:use-module (gnu packages perl)
c1670a81 70 #:use-module (gnu packages pkg-config)
0dfeb285 71 #:use-module (gnu packages protobuf)
0931c609 72 #:use-module (gnu packages python)
ec1224a7 73 #:use-module (gnu packages python-science)
10451f6b 74 #:use-module (gnu packages python-web)
44d10b1f 75 #:use-module (gnu packages python-xyz)
c61557b1 76 #:use-module (gnu packages rpc)
4fa16c9a 77 #:use-module (gnu packages serialization)
f1765b57 78 #:use-module (gnu packages sphinx)
c1670a81 79 #:use-module (gnu packages statistics)
4fa16c9a 80 #:use-module (gnu packages sqlite)
c1670a81 81 #:use-module (gnu packages swig)
99260014 82 #:use-module (gnu packages web)
5f0ff6a9 83 #:use-module (gnu packages xml)
39bb4937
RW
84 #:use-module (gnu packages xorg)
85 #:use-module (ice-9 match))
741115b6 86
a9b34762
MM
87(define-public fann
88 ;; The last release is >100 commits behind, so we package from git.
89 (let ((commit "d71d54788bee56ba4cf7522801270152da5209d7"))
90 (package
91 (name "fann")
92 (version (string-append "2.2.0-1." (string-take commit 8)))
93 (source (origin
94 (method git-fetch)
95 (uri (git-reference
96 (url "https://github.com/libfann/fann.git")
97 (commit commit)))
98 (file-name (string-append name "-" version "-checkout"))
99 (sha256
100 (base32
101 "0ibwpfrjs6q2lijs8slxjgzb2llcl6rk3v2ski4r6215g5jjhg3x"))))
102 (build-system cmake-build-system)
103 (arguments
104 `(#:phases
105 (modify-phases %standard-phases
106 (replace 'check
107 (lambda* (#:key outputs #:allow-other-keys)
108 (let* ((out (assoc-ref outputs "out")))
109 (with-directory-excursion (string-append (getcwd) "/tests")
110 (invoke "./fann_tests"))))))))
111 (home-page "http://leenissen.dk/fann/wp/")
112 (synopsis "Fast Artificial Neural Network")
113 (description
bd2bd80d
MB
114 "FANN is a neural network library, which implements multilayer
115artificial neural networks in C with support for both fully connected and
116sparsely connected networks.")
a9b34762
MM
117 (license license:lgpl2.1))))
118
741115b6
RW
119(define-public libsvm
120 (package
121 (name "libsvm")
2cffa2f2 122 (version "3.23")
741115b6
RW
123 (source
124 (origin
125 (method url-fetch)
d1308c5e
TGR
126 (uri (string-append "https://www.csie.ntu.edu.tw/~cjlin/libsvm/"
127 name "-" version ".tar.gz"))
741115b6 128 (sha256
2cffa2f2 129 (base32 "0jpaq0rr92x38p4nk3gjan79ip67m6p80anb28z1d8601miysyi5"))))
741115b6
RW
130 (build-system gnu-build-system)
131 (arguments
2cffa2f2 132 `(#:tests? #f ; no "check" target
741115b6
RW
133 #:phases (modify-phases %standard-phases
134 (delete 'configure)
135 (replace
d1308c5e 136 'install ; no ‘install’ target
741115b6
RW
137 (lambda* (#:key outputs #:allow-other-keys)
138 (let* ((out (assoc-ref outputs "out"))
139 (bin (string-append out "/bin/")))
140 (mkdir-p bin)
141 (for-each (lambda (file)
142 (copy-file file (string-append bin file)))
143 '("svm-train"
144 "svm-predict"
145 "svm-scale")))
146 #t)))))
62290cd4 147 (home-page "https://www.csie.ntu.edu.tw/~cjlin/libsvm/")
741115b6
RW
148 (synopsis "Library for Support Vector Machines")
149 (description
150 "LIBSVM is a machine learning library for support vector
151classification, (C-SVC, nu-SVC), regression (epsilon-SVR, nu-SVR) and
152distribution estimation (one-class SVM). It supports multi-class
153classification.")
154 (license license:bsd-3)))
71f80f54
RW
155
156(define-public python-libsvm
157 (package (inherit libsvm)
158 (name "python-libsvm")
159 (build-system gnu-build-system)
160 (arguments
2cffa2f2 161 `(#:tests? #f ; no "check" target
71f80f54
RW
162 #:make-flags '("-C" "python")
163 #:phases
164 (modify-phases %standard-phases
165 (delete 'configure)
166 (replace
d1308c5e 167 'install ; no ‘install’ target
71f80f54
RW
168 (lambda* (#:key inputs outputs #:allow-other-keys)
169 (let ((site (string-append (assoc-ref outputs "out")
170 "/lib/python"
171 (string-take
172 (string-take-right
173 (assoc-ref inputs "python") 5) 3)
174 "/site-packages/")))
175 (substitute* "python/svm.py"
176 (("../libsvm.so.2") "libsvm.so.2"))
177 (mkdir-p site)
178 (for-each (lambda (file)
179 (copy-file file (string-append site (basename file))))
180 (find-files "python" "\\.py"))
181 (copy-file "libsvm.so.2"
182 (string-append site "libsvm.so.2")))
183 #t)))))
184 (inputs
185 `(("python" ,python)))
186 (synopsis "Python bindings of libSVM")))
0931c609 187
23aab4ab
RW
188(define-public ghmm
189 ;; The latest release candidate is several years and a couple of fixes have
190 ;; been published since. This is why we download the sources from the SVN
191 ;; repository.
192 (let ((svn-revision 2341))
193 (package
194 (name "ghmm")
195 (version (string-append "0.9-rc3-0." (number->string svn-revision)))
196 (source (origin
197 (method svn-fetch)
198 (uri (svn-reference
199 (url "http://svn.code.sf.net/p/ghmm/code/trunk")
200 (revision svn-revision)))
e3a69938 201 (file-name (string-append name "-" version "-checkout"))
23aab4ab
RW
202 (sha256
203 (base32
204 "0qbq1rqp94l530f043qzp8aw5lj7dng9wq0miffd7spd1ff638wq"))))
205 (build-system gnu-build-system)
206 (arguments
ced12a7b
RW
207 `(#:imported-modules (,@%gnu-build-system-modules
208 (guix build python-build-system))
3cb8cb66
MB
209 #:modules ((guix build python-build-system)
210 ,@%gnu-build-system-modules)
ced12a7b 211 #:phases
23aab4ab
RW
212 (modify-phases %standard-phases
213 (add-after 'unpack 'enter-dir
214 (lambda _ (chdir "ghmm") #t))
ced12a7b
RW
215 (delete 'check)
216 (add-after 'install 'check
217 (assoc-ref %standard-phases 'check))
218 (add-before 'check 'fix-PYTHONPATH
219 (lambda* (#:key inputs outputs #:allow-other-keys)
9c2563a8 220 (let ((python-version (python-version
ced12a7b
RW
221 (assoc-ref inputs "python"))))
222 (setenv "PYTHONPATH"
223 (string-append (getenv "PYTHONPATH")
224 ":" (assoc-ref outputs "out")
225 "/lib/python" python-version
226 "/site-packages")))
23aab4ab
RW
227 #t))
228 (add-after 'enter-dir 'fix-runpath
229 (lambda* (#:key outputs #:allow-other-keys)
230 (substitute* "ghmmwrapper/setup.py"
231 (("^(.*)extra_compile_args = \\[" line indent)
232 (string-append indent
233 "extra_link_args = [\"-Wl,-rpath="
234 (assoc-ref outputs "out") "/lib\"],\n"
235 line
236 "\"-Wl,-rpath="
237 (assoc-ref outputs "out")
238 "/lib\", ")))
239 #t))
240 (add-after 'enter-dir 'disable-broken-tests
241 (lambda _
242 (substitute* "tests/Makefile.am"
243 ;; GHMM_SILENT_TESTS is assumed to be a command.
244 (("TESTS_ENVIRONMENT.*") "")
245 ;; Do not build broken tests.
246 (("chmm .*") "")
247 (("read_fa .*") "")
248 (("mcmc .*") "")
249 (("label_higher_order_test.*$")
250 "label_higher_order_test\n"))
251
252 ;; These Python unittests are broken as there is no gato.
253 ;; See https://sourceforge.net/p/ghmm/support-requests/3/
254 (substitute* "ghmmwrapper/ghmmunittests.py"
255 (("^(.*)def (testNewXML|testMultipleTransitionClasses|testNewXML)"
256 line indent)
257 (string-append indent
258 "@unittest.skip(\"Disabled by Guix\")\n"
259 line)))
a491856f 260 #t)))))
23aab4ab
RW
261 (inputs
262 `(("python" ,python-2) ; only Python 2 is supported
263 ("libxml2" ,libxml2)))
264 (native-inputs
265 `(("pkg-config" ,pkg-config)
266 ("dejagnu" ,dejagnu)
267 ("swig" ,swig)
268 ("autoconf" ,autoconf)
269 ("automake" ,automake)
270 ("libtool" ,libtool)))
271 (home-page "http://ghmm.org")
272 (synopsis "Hidden Markov Model library")
273 (description
274 "The General Hidden Markov Model library (GHMM) is a C library with
275additional Python bindings implementing a wide range of types of @dfn{Hidden
d1e4ad1b 276Markov Models} (HMM) and algorithms: discrete, continuous emissions, basic
23aab4ab
RW
277training, HMM clustering, HMM mixtures.")
278 (license license:lgpl2.0+))))
279
791c11d6
BW
280(define-public mcl
281 (package
282 (name "mcl")
283 (version "14.137")
284 (source (origin
285 (method url-fetch)
286 (uri (string-append
287 "http://micans.org/mcl/src/mcl-"
288 (string-replace-substring version "." "-")
289 ".tar.gz"))
290 (sha256
291 (base32
292 "15xlax3z31lsn62vlg94hkm75nm40q4679amnfg13jm8m2bnhy5m"))))
293 (build-system gnu-build-system)
294 (arguments
295 `(#:configure-flags (list "--enable-blast")))
296 (inputs
297 `(("perl" ,perl)))
298 (home-page "http://micans.org/mcl/")
299 (synopsis "Clustering algorithm for graphs")
300 (description
301 "The MCL algorithm is short for the @dfn{Markov Cluster Algorithm}, a
302fast and scalable unsupervised cluster algorithm for graphs (also known as
303networks) based on simulation of (stochastic) flow in graphs.")
304 ;; In the LICENCE file and web page it says "The software is licensed
305 ;; under the GNU General Public License, version 3.", but in several of
306 ;; the source code files it suggests GPL3 or later.
307 ;; http://listserver.ebi.ac.uk/pipermail/mcl-users/2016/000376.html
308 (license license:gpl3)))
309
0a3063d6
BW
310(define-public ocaml-mcl
311 (package
312 (name "ocaml-mcl")
313 (version "12-068oasis4")
314 (source
315 (origin
fb168a31
RW
316 (method git-fetch)
317 (uri (git-reference
318 (url "https://github.com/fhcrc/mcl.git")
319 (commit version)))
320 (file-name (git-file-name name version))
0a3063d6
BW
321 (sha256
322 (base32
fb168a31 323 "0009dc3h2jp3qg5val452wngpqnbfyhbcxylghq0mrjqxx0jdq5p"))))
0a3063d6
BW
324 (build-system ocaml-build-system)
325 (arguments
b24aaeec 326 `(#:phases
0a3063d6
BW
327 (modify-phases %standard-phases
328 (add-before 'configure 'patch-paths
329 (lambda _
330 (substitute* "configure"
b24aaeec 331 (("/bin/sh") (which "sh")))
0a3063d6
BW
332 (substitute* "setup.ml"
333 (("LDFLAGS=-fPIC")
b24aaeec
RW
334 (string-append "LDFLAGS=-fPIC\"; \"SHELL=" (which "sh")))
335 (("-std=c89") "-std=gnu99")
336
337 ;; This is a mutable string, which is no longer supported. Use
338 ;; a byte buffer instead.
339 (("String.make \\(String.length s\\)")
340 "Bytes.make (String.length s)")
341
342 ;; These two belong together.
343 (("OASISString.replace_chars")
344 "Bytes.to_string (OASISString.replace_chars")
345 ((" s;")
346 " s);"))
347 (substitute* "myocamlbuild.ml"
348 (("std=c89") "std=gnu99"))
349 ;; Since we build with a more recent OCaml, we have to use C99 or
350 ;; later. This causes problems with the old C code.
351 (substitute* "src/impala/matrix.c"
352 (("restrict") "restrict_"))
0a3063d6 353 #t)))))
b24aaeec
RW
354 (native-inputs
355 `(("ocamlbuild" ,ocamlbuild)))
0a3063d6
BW
356 (home-page "https://github.com/fhcrc/mcl")
357 (synopsis "OCaml wrappers around MCL")
358 (description
359 "This package provides OCaml bindings for the MCL graph clustering
360algorithm.")
361 (license license:gpl3)))
362
0931c609
RW
363(define-public randomjungle
364 (package
365 (name "randomjungle")
366 (version "2.1.0")
367 (source
368 (origin
369 (method url-fetch)
370 (uri (string-append
df4c8434
BH
371 "https://www.imbs.uni-luebeck.de/fileadmin/files/Software"
372 "/randomjungle/randomjungle-" version ".tar_.gz"))
1e92d311 373 (patches (search-patches "randomjungle-disable-static-build.patch"))
0931c609
RW
374 (sha256
375 (base32
376 "12c8rf30cla71swx2mf4ww9mfd8jbdw5lnxd7dxhyw1ygrvg6y4w"))))
377 (build-system gnu-build-system)
378 (arguments
379 `(#:configure-flags
1e92d311
MB
380 (list "--disable-static"
381 (string-append "--with-boost="
0931c609
RW
382 (assoc-ref %build-inputs "boost")))
383 #:phases
384 (modify-phases %standard-phases
385 (add-before
386 'configure 'set-CXXFLAGS
387 (lambda _
388 (setenv "CXXFLAGS" "-fpermissive ")
389 #t)))))
390 (inputs
391 `(("boost" ,boost)
392 ("gsl" ,gsl)
393 ("libxml2" ,libxml2)
394 ("zlib" ,zlib)))
395 (native-inputs
25e0037a
EF
396 `(("gfortran" ,gfortran)
397 ("gfortran:lib" ,gfortran "lib")))
47818201
RW
398 ;; Non-portable assembly instructions are used so building fails on
399 ;; platforms other than x86_64 or i686.
400 (supported-systems '("x86_64-linux" "i686-linux"))
df4c8434 401 (home-page "https://www.imbs.uni-luebeck.de/forschung/software/details.html#c224")
0931c609
RW
402 (synopsis "Implementation of the Random Forests machine learning method")
403 (description
404 "Random Jungle is an implementation of Random Forests. It is supposed to
405analyse high dimensional data. In genetics, it can be used for analysing big
406Genome Wide Association (GWA) data. Random Forests is a powerful machine
407learning method. Most interesting features are variable selection, missing
408value imputation, classifier creation, generalization error estimation and
409sample proximities between pairs of cases.")
410 (license license:gpl3+)))
c1670a81 411
7d4cab74
RW
412(define-public openfst
413 (package
414 (name "openfst")
5ed72097 415 (version "1.7.2")
7d4cab74
RW
416 (source (origin
417 (method url-fetch)
418 (uri (string-append "http://www.openfst.org/twiki/pub/FST/"
419 "FstDownload/openfst-" version ".tar.gz"))
420 (sha256
421 (base32
5ed72097 422 "0fqgk8195kz21is09gwzwnrg7fr9526bi9mh4apyskapz27pbhr1"))))
7d4cab74
RW
423 (build-system gnu-build-system)
424 (home-page "http://www.openfst.org")
425 (synopsis "Library for weighted finite-state transducers")
426 (description "OpenFst is a library for constructing, combining,
427optimizing, and searching weighted finite-state transducers (FSTs).")
428 (license license:asl2.0)))
429
c1670a81
RW
430(define-public shogun
431 (package
432 (name "shogun")
5a14e81e 433 (version "6.1.3")
c1670a81
RW
434 (source
435 (origin
436 (method url-fetch)
437 (uri (string-append
438 "ftp://shogun-toolbox.org/shogun/releases/"
439 (version-major+minor version)
440 "/sources/shogun-" version ".tar.bz2"))
441 (sha256
442 (base32
5a14e81e 443 "1rn9skm3nw6hr7mr3lgp2gfqhi7ii0lyxck7qmqnf8avq349s5jp"))
c1670a81
RW
444 (modules '((guix build utils)
445 (ice-9 rdelim)))
446 (snippet
447 '(begin
448 ;; Remove non-free sources and files referencing them
449 (for-each delete-file
450 (find-files "src/shogun/classifier/svm/"
451 "SVMLight\\.(cpp|h)"))
452 (for-each delete-file
453 (find-files "examples/undocumented/libshogun/"
454 (string-append
455 "(classifier_.*svmlight.*|"
456 "evaluation_cross_validation_locked_comparison).cpp")))
457 ;; Remove non-free functions.
458 (define (delete-ifdefs file)
459 (with-atomic-file-replacement file
460 (lambda (in out)
461 (let loop ((line (read-line in 'concat))
462 (skipping? #f))
463 (if (eof-object? line)
464 #t
465 (let ((skip-next?
466 (or (and skipping?
467 (not (string-prefix?
468 "#endif //USE_SVMLIGHT" line)))
469 (string-prefix?
470 "#ifdef USE_SVMLIGHT" line))))
471 (when (or (not skipping?)
472 (and skipping? (not skip-next?)))
473 (display line out))
474 (loop (read-line in 'concat) skip-next?)))))))
5a14e81e
KK
475 (for-each delete-ifdefs
476 (append
477 (find-files "src/shogun/classifier/mkl"
478 "^MKLClassification\\.cpp")
479 (find-files "src/shogun/classifier/svm"
480 "^SVMLightOneClass\\.(cpp|h)")
481 (find-files "src/shogun/multiclass"
482 "^ScatterSVM\\.(cpp|h)")
483 (find-files "src/shogun/kernel/"
484 "^(Kernel|CombinedKernel|ProductKernel)\\.(cpp|h)")
485 (find-files "src/shogun/regression/svr"
486 "^(MKLRegression|SVRLight)\\.(cpp|h)")
487 (find-files "src/shogun/transfer/domain_adaptation"
c0d7c124 488 "^DomainAdaptationSVM\\.(cpp|h)")))
6cbee49d 489 #t))))
c1670a81
RW
490 (build-system cmake-build-system)
491 (arguments
492 '(#:tests? #f ;no check target
493 #:phases
dc1d3cde
KK
494 (modify-phases %standard-phases
495 (add-after 'unpack 'delete-broken-symlinks
496 (lambda _
497 (for-each delete-file '("applications/arts/data"
498 "applications/asp/data"
499 "applications/easysvm/data"
500 "applications/msplicer/data"
501 "applications/ocr/data"
5a14e81e
KK
502 "examples/meta/data"
503 "examples/undocumented/data"))
dc1d3cde
KK
504 #t))
505 (add-after 'unpack 'change-R-target-path
506 (lambda* (#:key outputs #:allow-other-keys)
5a14e81e
KK
507 (substitute* '("src/interfaces/r/CMakeLists.txt"
508 "examples/meta/r/CMakeLists.txt")
dc1d3cde
KK
509 (("\\$\\{R_COMPONENT_LIB_PATH\\}")
510 (string-append (assoc-ref outputs "out")
511 "/lib/R/library/")))
512 #t))
513 (add-after 'unpack 'fix-octave-modules
514 (lambda* (#:key outputs #:allow-other-keys)
5a14e81e 515 (substitute* "src/interfaces/octave/CMakeLists.txt"
dc1d3cde 516 (("^include_directories\\(\\$\\{OCTAVE_INCLUDE_DIRS\\}")
5a14e81e
KK
517 "include_directories(${OCTAVE_INCLUDE_DIRS} ${OCTAVE_INCLUDE_DIRS}/octave")
518 ;; change target directory
dc1d3cde
KK
519 (("\\$\\{OCTAVE_OCT_LOCAL_API_FILE_DIR\\}")
520 (string-append (assoc-ref outputs "out")
521 "/share/octave/packages")))
5a14e81e
KK
522 (substitute* '("src/interfaces/octave/swig_typemaps.i"
523 "src/interfaces/octave/sg_print_functions.cpp")
524 ;; "octave/config.h" and "octave/oct-obj.h" deprecated in Octave.
525 (("octave/config\\.h") "octave/octave-config.h")
526 (("octave/oct-obj.h") "octave/ovl.h"))
dc1d3cde 527 #t))
5a14e81e
KK
528 (add-after 'unpack 'move-rxcpp
529 (lambda* (#:key inputs #:allow-other-keys)
530 (let ((rxcpp-dir "shogun/third-party/rxcpp"))
531 (mkdir-p rxcpp-dir)
532 (install-file (assoc-ref inputs "rxcpp") rxcpp-dir)
533 #t)))
dc1d3cde 534 (add-before 'build 'set-HOME
c1670a81 535 ;; $HOME needs to be set at some point during the build phase
dc1d3cde 536 (lambda _ (setenv "HOME" "/tmp") #t)))
c1670a81
RW
537 #:configure-flags
538 (list "-DCMAKE_BUILD_WITH_INSTALL_RPATH=TRUE"
539 "-DUSE_SVMLIGHT=OFF" ;disable proprietary SVMLIGHT
5a14e81e
KK
540 "-DBUILD_META_EXAMPLES=OFF" ;requires unpackaged ctags
541 ;;"-DINTERFACE_JAVA=ON" ;requires unpackaged jblas
542 ;;"-DINTERFACE_RUBY=ON" ;requires unpackaged ruby-narray
543 ;;"-DINTERFACE_PERL=ON" ;"FindPerlLibs" does not exist
544 ;;"-DINTERFACE_LUA=ON" ;fails because lua doesn't build pkgconfig file
545 "-DINTERFACE_OCTAVE=ON"
546 "-DINTERFACE_PYTHON=ON"
547 "-DINTERFACE_R=ON")))
c1670a81
RW
548 (inputs
549 `(("python" ,python)
550 ("numpy" ,python-numpy)
2d7c4ae3 551 ("r-minimal" ,r-minimal)
5537603f 552 ("octave" ,octave-cli)
c1670a81 553 ("swig" ,swig)
5a14e81e 554 ("eigen" ,eigen)
c1670a81
RW
555 ("hdf5" ,hdf5)
556 ("atlas" ,atlas)
557 ("arpack" ,arpack-ng)
558 ("lapack" ,lapack)
559 ("glpk" ,glpk)
560 ("libxml2" ,libxml2)
561 ("lzo" ,lzo)
562 ("zlib" ,zlib)))
563 (native-inputs
5a14e81e
KK
564 `(("pkg-config" ,pkg-config)
565 ("rxcpp" ,rxcpp)))
6b5b656f
RW
566 ;; Non-portable SSE instructions are used so building fails on platforms
567 ;; other than x86_64.
568 (supported-systems '("x86_64-linux"))
df10a64e 569 (home-page "https://shogun-toolbox.org/")
c1670a81
RW
570 (synopsis "Machine learning toolbox")
571 (description
572 "The Shogun Machine learning toolbox provides a wide range of unified and
573efficient Machine Learning (ML) methods. The toolbox seamlessly allows to
574combine multiple data representations, algorithm classes, and general purpose
575tools. This enables both rapid prototyping of data pipelines and extensibility
576in terms of new algorithms.")
577 (license license:gpl3+)))
8406138b 578
3a354e10
KK
579(define-public rxcpp
580 (package
581 (name "rxcpp")
e91a0bff 582 (version "4.1.0")
3a354e10
KK
583 (source
584 (origin
5daafe0b
TGR
585 (method git-fetch)
586 (uri (git-reference
587 (url "https://github.com/ReactiveX/RxCpp.git")
588 (commit (string-append "v" version))))
3a354e10 589 (sha256
5daafe0b
TGR
590 (base32 "1rdpa3jlc181jd08nk437aar085h28i45s6nzrv65apb3xyyz0ij"))
591 (file-name (git-file-name name version))))
3a354e10
KK
592 (build-system cmake-build-system)
593 (arguments
594 `(#:phases
595 (modify-phases %standard-phases
596 (add-after 'unpack 'remove-werror
597 (lambda _
598 (substitute* (find-files ".")
599 (("-Werror") ""))
600 #t))
601 (replace 'check
602 (lambda _
603 (invoke "ctest"))))))
604 (native-inputs
605 `(("catch" ,catch-framework)))
606 (home-page "http://reactivex.io/")
607 (synopsis "Reactive Extensions for C++")
608 (description
609 "The Reactive Extensions for C++ (RxCpp) is a library of algorithms for
610values-distributed-in-time. ReactiveX is a library for composing asynchronous
611and event-based programs by using observable sequences.
612
613It extends the observer pattern to support sequences of data and/or events and
614adds operators that allow you to compose sequences together declaratively while
615abstracting away concerns about things like low-level threading,
616synchronization, thread-safety, concurrent data structures, and non-blocking
617I/O.")
618 (license license:asl2.0)))
619
8406138b
RW
620(define-public r-adaptivesparsity
621 (package
622 (name "r-adaptivesparsity")
c0608f81 623 (version "1.6")
8406138b
RW
624 (source (origin
625 (method url-fetch)
626 (uri (cran-uri "AdaptiveSparsity" version))
627 (sha256
628 (base32
c0608f81 629 "0imr5m8mll9j6n4icsv6z9rl5kbnwsp9wvzrg7n90nnmcxq2cz91"))))
8406138b
RW
630 (properties
631 `((upstream-name . "AdaptiveSparsity")))
632 (build-system r-build-system)
633 (arguments
634 `(#:phases
635 (modify-phases %standard-phases
636 (add-after 'unpack 'link-against-armadillo
637 (lambda _
638 (substitute* "src/Makevars"
639 (("PKG_LIBS=" prefix)
640 (string-append prefix "-larmadillo"))))))))
641 (propagated-inputs
c0608f81
RW
642 `(("r-mass" ,r-mass)
643 ("r-matrix" ,r-matrix)
644 ("r-rcpp" ,r-rcpp)
8406138b 645 ("r-rcpparmadillo" ,r-rcpparmadillo)))
60e36bff
LC
646 (inputs
647 `(("armadillo" ,armadillo)))
e9960d8c 648 (home-page "https://cran.r-project.org/web/packages/AdaptiveSparsity")
8406138b
RW
649 (synopsis "Adaptive sparsity models")
650 (description
651 "This package implements the Figueiredo machine learning algorithm for
652adaptive sparsity and the Wong algorithm for adaptively sparse gaussian
653geometric models.")
654 (license license:lgpl3+)))
e4785eb8 655
39bb4937
RW
656(define-public gemmlowp-for-tensorflow
657 ;; The commit hash is taken from "tensorflow/workspace.bzl".
658 (let ((commit "38ebac7b059e84692f53e5938f97a9943c120d98")
659 (revision "2"))
660 (package
661 (name "gemmlowp")
662 (version (git-version "0" revision commit))
663 (source (origin
664 (method url-fetch)
665 (uri (string-append "https://mirror.bazel.build/"
666 "github.com/google/gemmlowp/archive/"
667 commit ".zip"))
668 (file-name (string-append "gemmlowp-" version ".zip"))
669 (sha256
670 (base32
671 "0n56s2g8hrssm4w8qj1v58gfm56a04n9v992ixkmvk6zjiralzxq"))))
672 (build-system cmake-build-system)
673 (arguments
674 `(#:configure-flags
675 (list ,@(match (%current-system)
676 ((or "x86_64-linux" "i686-linux")
a32e3b90 677 '("-DCMAKE_CXX_FLAGS=-msse2"))
39bb4937
RW
678 (_ '())))
679 #:phases
680 (modify-phases %standard-phases
681 ;; This directory contains the CMakeLists.txt.
682 (add-after 'unpack 'chdir
683 (lambda _ (chdir "contrib") #t))
684 ;; There is no install target
685 (replace 'install
686 (lambda* (#:key outputs #:allow-other-keys)
687 (let* ((out (assoc-ref outputs "out"))
688 (lib (string-append out "/lib/"))
689 (inc (string-append out "/include/")))
690 (install-file "../build/libeight_bit_int_gemm.so" lib)
691 (for-each (lambda (dir)
692 (let ((target (string-append inc "/" dir)))
693 (mkdir-p target)
694 (for-each (lambda (h)
695 (install-file h target))
696 (find-files (string-append "../" dir)
697 "\\.h$"))))
698 '("meta" "profiling" "public" "fixedpoint"
699 "eight_bit_int_gemm" "internal"))
700 #t))))))
701 (native-inputs
702 `(("unzip" ,unzip)))
703 (home-page "https://github.com/google/gemmlowp")
704 (synopsis "Small self-contained low-precision GEMM library")
705 (description
706 "This is a small self-contained low-precision @dfn{general matrix
707multiplication} (GEMM) library. It is not a full linear algebra library.
708Low-precision means that the input and output matrix entries are integers on
709at most 8 bits. To avoid overflow, results are internally accumulated on more
710than 8 bits, and at the end only some significant 8 bits are kept.")
711 (license license:asl2.0))))
f05c7eb4 712
5f0ff6a9
MB
713(define-public dlib
714 (package
715 (name "dlib")
abe97a58 716 (version "19.7")
5f0ff6a9
MB
717 (source (origin
718 (method url-fetch)
719 (uri (string-append
720 "http://dlib.net/files/dlib-" version ".tar.bz2"))
721 (sha256
722 (base32
abe97a58 723 "1mljz02kwkrbggyncxv5fpnyjdybw2qihaacb3js8yfkw12vwpc2"))
5f0ff6a9
MB
724 (modules '((guix build utils)))
725 (snippet
726 '(begin
727 ;; Delete ~13MB of bundled dependencies.
728 (delete-file-recursively "dlib/external")
0ef7ea66
MB
729 (delete-file-recursively "docs/dlib/external")
730 #t))))
5f0ff6a9
MB
731 (build-system cmake-build-system)
732 (arguments
677bc34d 733 `(#:phases
5f0ff6a9
MB
734 (modify-phases %standard-phases
735 (add-after 'unpack 'disable-asserts
736 (lambda _
737 ;; config.h recommends explicitly enabling or disabling asserts
738 ;; when building as a shared library. By default neither is set.
739 (substitute* "dlib/config.h"
740 (("^//#define DLIB_DISABLE_ASSERTS") "#define DLIB_DISABLE_ASSERTS"))
741 #t))
4fba38db
MB
742 (add-after 'disable-asserts 'disable-failing-tests
743 (lambda _
744 ;; One test times out on MIPS, so we need to disable it.
0ef7ea66 745 ;; Others are flaky on some platforms.
4fba38db
MB
746 (let* ((system ,(or (%current-target-system)
747 (%current-system)))
748 (disabled-tests (cond
749 ((string-prefix? "mips64" system)
750 '("object_detector" ; timeout
751 "data_io"))
752 ((string-prefix? "armhf" system)
a343c461 753 '("learning_to_track"))
4fba38db 754 ((string-prefix? "i686" system)
0ef7ea66 755 '("optimization"))
4fba38db 756 (else '()))))
4fba38db
MB
757 (for-each
758 (lambda (test)
759 (substitute* "dlib/test/makefile"
0ef7ea66
MB
760 (((string-append "SRC \\+= " test "\\.cpp")) "")))
761 disabled-tests)
762 #t)))
5f0ff6a9
MB
763 (replace 'check
764 (lambda _
765 ;; No test target, so we build and run the unit tests here.
8eaf53e3 766 (let ((test-dir (string-append "../dlib-" ,version "/dlib/test")))
5f0ff6a9 767 (with-directory-excursion test-dir
8448e6bf
TGR
768 (invoke "make" "-j" (number->string (parallel-job-count)))
769 (invoke "./dtest" "--runall"))
770 #t)))
5f0ff6a9
MB
771 (add-after 'install 'delete-static-library
772 (lambda* (#:key outputs #:allow-other-keys)
0ef7ea66
MB
773 (delete-file (string-append (assoc-ref outputs "out")
774 "/lib/libdlib.a"))
775 #t)))))
5f0ff6a9 776 (native-inputs
3929f46c
TGR
777 `(("pkg-config" ,pkg-config)
778 ;; For tests.
779 ("libnsl" ,libnsl)))
5f0ff6a9 780 (inputs
f40841e9 781 `(("giflib" ,giflib)
4fba38db 782 ("lapack" ,lapack)
5f0ff6a9
MB
783 ("libjpeg" ,libjpeg)
784 ("libpng" ,libpng)
785 ("libx11" ,libx11)
786 ("openblas" ,openblas)
787 ("zlib" ,zlib)))
788 (synopsis
789 "Toolkit for making machine learning and data analysis applications in C++")
790 (description
791 "Dlib is a modern C++ toolkit containing machine learning algorithms and
792tools. It is used in both industry and academia in a wide range of domains
793including robotics, embedded devices, mobile phones, and large high performance
794computing environments.")
795 (home-page "http://dlib.net")
796 (license license:boost1.0)))
be6eb2f1
RW
797
798(define-public python-scikit-learn
799 (package
800 (name "python-scikit-learn")
83a483aa 801 (version "0.22.1")
be6eb2f1
RW
802 (source
803 (origin
4a89bdd1
RW
804 (method git-fetch)
805 (uri (git-reference
806 (url "https://github.com/scikit-learn/scikit-learn.git")
807 (commit version)))
808 (file-name (git-file-name name version))
be6eb2f1
RW
809 (sha256
810 (base32
83a483aa 811 "1xqxv210gsmjw094vc5ghq2y9lmm74qkk22pq6flcjzj51b86jxf"))))
be6eb2f1
RW
812 (build-system python-build-system)
813 (arguments
814 `(#:phases
815 (modify-phases %standard-phases
4a89bdd1
RW
816 (add-after 'build 'build-ext
817 (lambda _ (invoke "python" "setup.py" "build_ext" "--inplace") #t))
818 (replace 'check
819 (lambda _
820 ;; Restrict OpenBLAS threads to prevent segfaults while testing!
821 (setenv "OPENBLAS_NUM_THREADS" "1")
7ff3f3d2
MB
822
823 ;; Some tests require write access to $HOME.
824 (setenv "HOME" "/tmp")
825
826 (invoke "pytest" "sklearn" "-m" "not network")))
71804546
BL
827 (add-before 'reset-gzip-timestamps 'make-files-writable
828 (lambda* (#:key outputs #:allow-other-keys)
829 ;; Make sure .gz files are writable so that the
830 ;; 'reset-gzip-timestamps' phase can do its work.
831 (let ((out (assoc-ref outputs "out")))
832 (for-each make-file-writable
833 (find-files out "\\.gz$"))
834 #t))))))
be6eb2f1
RW
835 (inputs
836 `(("openblas" ,openblas)))
837 (native-inputs
83a483aa
RJ
838 `(("python-joblib" ,python-joblib)
839 ("python-pytest" ,python-pytest)
4a89bdd1 840 ("python-pandas" ,python-pandas) ;for tests
be6eb2f1
RW
841 ("python-cython" ,python-cython)))
842 (propagated-inputs
843 `(("python-numpy" ,python-numpy)
844 ("python-scipy" ,python-scipy)))
e51b34bb 845 (home-page "https://scikit-learn.org/")
be6eb2f1
RW
846 (synopsis "Machine Learning in Python")
847 (description
4a89bdd1
RW
848 "Scikit-learn provides simple and efficient tools for data mining and
849data analysis.")
382550f0 850 (properties `((python2-variant . ,(delay python2-scikit-learn))))
be6eb2f1
RW
851 (license license:bsd-3)))
852
382550f0
MB
853;; scikit-learn 0.22 and later only supports Python 3, so we stick with
854;; an older version here.
be6eb2f1 855(define-public python2-scikit-learn
382550f0
MB
856 (let ((base (package-with-python2 (strip-python2-variant python-scikit-learn))))
857 (package
858 (inherit base)
859 (version "0.20.4")
860 (source (origin
861 (method git-fetch)
862 (uri (git-reference
863 (url "https://github.com/scikit-learn/scikit-learn.git")
864 (commit version)))
865 (file-name (git-file-name "python-scikit-learn" version))
866 (sha256
867 (base32
868 "08zbzi8yx5wdlxfx9jap61vg1malc9ajf576w7a0liv6jvvrxlpj")))))))
2dab4188
FT
869
870(define-public python-autograd
871 (let* ((commit "442205dfefe407beffb33550846434baa90c4de7")
872 (revision "0")
873 (version (git-version "0.0.0" revision commit)))
874 (package
875 (name "python-autograd")
876 (home-page "https://github.com/HIPS/autograd")
877 (source (origin
878 (method git-fetch)
879 (uri (git-reference
880 (url home-page)
881 (commit commit)))
882 (sha256
883 (base32
884 "189sv2xb0mwnjawa9z7mrgdglc1miaq93pnck26r28fi1jdwg0z4"))
885 (file-name (git-file-name name version))))
886 (version version)
887 (build-system python-build-system)
888 (native-inputs
889 `(("python-nose" ,python-nose)
890 ("python-pytest" ,python-pytest)))
891 (propagated-inputs
892 `(("python-future" ,python-future)
893 ("python-numpy" ,python-numpy)))
894 (arguments
895 `(#:phases (modify-phases %standard-phases
896 (replace 'check
897 (lambda _
898 (invoke "py.test" "-v"))))))
899 (synopsis "Efficiently computes derivatives of NumPy code")
900 (description "Autograd can automatically differentiate native Python and
901NumPy code. It can handle a large subset of Python's features, including loops,
902ifs, recursion and closures, and it can even take derivatives of derivatives
903of derivatives. It supports reverse-mode differentiation
904(a.k.a. backpropagation), which means it can efficiently take gradients of
905scalar-valued functions with respect to array-valued arguments, as well as
906forward-mode differentiation, and the two can be composed arbitrarily. The
907main intended application of Autograd is gradient-based optimization.")
908 (license license:expat))))
909
910(define-public python2-autograd
911 (package-with-python2 python-autograd))
112c2c01
FT
912
913(define-public lightgbm
914 (package
915 (name "lightgbm")
916 (version "2.0.12")
917 (source (origin
918 (method url-fetch)
919 (uri (string-append
920 "https://github.com/Microsoft/LightGBM/archive/v"
921 version ".tar.gz"))
922 (sha256
923 (base32
924 "132zf0yk0545mg72hyzxm102g3hpb6ixx9hnf8zd2k55gas6cjj1"))
925 (file-name (string-append name "-" version ".tar.gz"))))
926 (native-inputs
927 `(("python-pytest" ,python-pytest)
928 ("python-nose" ,python-nose)))
929 (inputs
930 `(("openmpi" ,openmpi)))
931 (propagated-inputs
932 `(("python-numpy" ,python-numpy)
933 ("python-scipy" ,python-scipy)))
934 (arguments
935 `(#:configure-flags
936 '("-DUSE_MPI=ON")
937 #:phases
938 (modify-phases %standard-phases
939 (replace 'check
940 (lambda* (#:key outputs #:allow-other-keys)
941 (with-directory-excursion ,(string-append "../LightGBM-" version)
942 (invoke "pytest" "tests/c_api_test/test_.py")))))))
943 (build-system cmake-build-system)
944 (home-page "https://github.com/Microsoft/LightGBM")
945 (synopsis "Gradient boosting framework based on decision tree algorithms")
946 (description "LightGBM is a gradient boosting framework that uses tree
947based learning algorithms. It is designed to be distributed and efficient with
948the following advantages:
949
950@itemize
951@item Faster training speed and higher efficiency
952@item Lower memory usage
953@item Better accuracy
954@item Parallel and GPU learning supported (not enabled in this package)
955@item Capable of handling large-scale data
956@end itemize\n")
957 (license license:expat)))
a8fb82a8
FT
958
959(define-public vowpal-wabbit
960 ;; Language bindings not included.
961 (package
962 (name "vowpal-wabbit")
963 (version "8.5.0")
964 (source (origin
965 (method url-fetch)
966 (uri (string-append
967 "https://github.com/JohnLangford/vowpal_wabbit/archive/"
968 version ".tar.gz"))
969 (sha256
970 (base32
971 "0clp2kb7rk5sckhllxjr5a651awf4s8dgzg4659yh4hf5cqnf0gr"))
972 (file-name (string-append name "-" version ".tar.gz"))))
973 (inputs
974 `(("boost" ,boost)
975 ("zlib" ,zlib)))
976 (arguments
977 `(#:configure-flags
978 (list (string-append "--with-boost="
979 (assoc-ref %build-inputs "boost")))))
980 (build-system gnu-build-system)
981 (home-page "https://github.com/JohnLangford/vowpal_wabbit")
982 (synopsis "Fast machine learning library for online learning")
983 (description "Vowpal Wabbit is a machine learning system with techniques
984such as online, hashing, allreduce, reductions, learning2search, active, and
985interactive learning.")
986 (license license:bsd-3)))
915c6bf6
LC
987
988(define-public python2-fastlmm
989 (package
990 (name "python2-fastlmm")
991 (version "0.2.21")
992 (source
993 (origin
994 (method url-fetch)
995 (uri (pypi-uri "fastlmm" version ".zip"))
996 (sha256
997 (base32
998 "1q8c34rpmwkfy3r4d5172pzdkpfryj561897z9r3x22gq7813x1m"))))
999 (build-system python-build-system)
1000 (arguments
237ee6f2
RW
1001 `(#:tests? #f ; some test files are missing
1002 #:python ,python-2)) ; only Python 2.7 is supported
915c6bf6
LC
1003 (propagated-inputs
1004 `(("python2-numpy" ,python2-numpy)
1005 ("python2-scipy" ,python2-scipy)
1006 ("python2-matplotlib" ,python2-matplotlib)
1007 ("python2-pandas" ,python2-pandas)
1008 ("python2-scikit-learn" ,python2-scikit-learn)
1009 ("python2-pysnptools" ,python2-pysnptools)))
1010 (native-inputs
1011 `(("unzip" ,unzip)
1012 ("python2-cython" ,python2-cython)
1013 ("python2-mock" ,python2-mock)
1014 ("python2-nose" ,python2-nose)))
1015 (home-page "http://research.microsoft.com/en-us/um/redmond/projects/mscompbio/fastlmm/")
1016 (synopsis "Perform genome-wide association studies on large data sets")
1017 (description
1018 "FaST-LMM, which stands for Factored Spectrally Transformed Linear Mixed
1019Models, is a program for performing both single-SNP and SNP-set genome-wide
1020association studies (GWAS) on extremely large data sets.")
1021 (license license:asl2.0)))
b9445d0b
RW
1022
1023;; There have been no proper releases yet.
1024(define-public kaldi
1025 (let ((commit "2f95609f0bb085bd3a1dc5eb0a39f3edea59e606")
1026 (revision "1"))
1027 (package
1028 (name "kaldi")
1029 (version (git-version "0" revision commit))
1030 (source (origin
1031 (method git-fetch)
1032 (uri (git-reference
1033 (url "https://github.com/kaldi-asr/kaldi.git")
1034 (commit commit)))
1035 (file-name (git-file-name name version))
1036 (sha256
1037 (base32
1038 "082qh3pfi7hvncylp4xsmkfahbd7gb0whdfa4rwrx7fxk9rdh3kz"))))
1039 (build-system gnu-build-system)
1040 (arguments
1041 `(#:test-target "test"
1042 #:phases
1043 (modify-phases %standard-phases
1044 (add-after 'unpack 'chdir
1045 (lambda _ (chdir "src") #t))
1046 (replace 'configure
1047 (lambda* (#:key build system inputs outputs #:allow-other-keys)
1048 (when (not (or (string-prefix? "x86_64" system)
1049 (string-prefix? "i686" system)))
1050 (substitute* "makefiles/linux_openblas.mk"
1051 (("-msse -msse2") "")))
1052 (substitute* "makefiles/default_rules.mk"
1053 (("/bin/bash") (which "bash")))
1054 (substitute* "Makefile"
1055 (("ext_depend: check_portaudio")
1056 "ext_depend:"))
1057 (substitute* '("online/Makefile"
1058 "onlinebin/Makefile"
1059 "gst-plugin/Makefile")
1060 (("../../tools/portaudio/install")
1061 (assoc-ref inputs "portaudio")))
1062
1063 ;; This `configure' script doesn't support variables passed as
1064 ;; arguments, nor does it support "prefix".
1065 (let ((out (assoc-ref outputs "out"))
1066 (openblas (assoc-ref inputs "openblas"))
1067 (openfst (assoc-ref inputs "openfst")))
1068 (substitute* "configure"
1069 (("check_for_slow_expf;") "")
1070 ;; This affects the RPATH and also serves as the installation
1071 ;; directory.
1072 (("KALDILIBDIR=`pwd`/lib")
1073 (string-append "KALDILIBDIR=" out "/lib")))
1074 (mkdir-p out) ; must exist
1075 (setenv "CONFIG_SHELL" (which "bash"))
1076 (setenv "OPENFST_VER" ,(package-version openfst))
1077 (invoke "./configure"
1078 "--use-cuda=no"
1079 "--shared"
1080 (string-append "--openblas-root=" openblas)
1081 (string-append "--fst-root=" openfst)))))
1082 (add-after 'build 'build-ext-and-gstreamer-plugin
1083 (lambda _
1084 (invoke "make" "-C" "online" "depend")
1085 (invoke "make" "-C" "online")
1086 (invoke "make" "-C" "onlinebin" "depend")
1087 (invoke "make" "-C" "onlinebin")
1088 (invoke "make" "-C" "gst-plugin" "depend")
1089 (invoke "make" "-C" "gst-plugin")
1090 #t))
1091 ;; TODO: also install the executables.
1092 (replace 'install
1093 (lambda* (#:key outputs #:allow-other-keys)
1094 (let* ((out (assoc-ref outputs "out"))
1fdd20c7 1095 (inc (string-append out "/include"))
b9445d0b
RW
1096 (lib (string-append out "/lib")))
1097 (mkdir-p lib)
1fdd20c7
RW
1098 ;; The build phase installed symlinks to the actual
1099 ;; libraries. Install the actual targets.
1100 (for-each (lambda (file)
1101 (let ((target (readlink file)))
1102 (delete-file file)
1103 (install-file target lib)))
1104 (find-files lib "\\.so"))
1105 ;; Install headers
1106 (for-each (lambda (file)
1107 (let ((target-dir (string-append inc "/" (dirname file))))
1108 (install-file file target-dir)))
1109 (find-files "." "\\.h"))
1110 (install-file "gst-plugin/libgstonlinegmmdecodefaster.so"
1111 (string-append lib "/gstreamer-1.0"))
b9445d0b
RW
1112 #t))))))
1113 (inputs
1114 `(("alsa-lib" ,alsa-lib)
1115 ("gfortran" ,gfortran "lib")
1116 ("glib" ,glib)
1117 ("gstreamer" ,gstreamer)
1118 ("jack" ,jack-1)
1119 ("openblas" ,openblas)
1120 ("openfst" ,openfst)
1121 ("portaudio" ,portaudio)
1122 ("python" ,python)))
1123 (native-inputs
1124 `(("glib" ,glib "bin") ; glib-genmarshal
1125 ("grep" ,grep)
1126 ("sed" ,sed)
1127 ("pkg-config" ,pkg-config)
1128 ("which" ,which)))
1129 (home-page "https://kaldi-asr.org/")
1130 (synopsis "Speech recognition toolkit")
1131 (description "Kaldi is an extensible toolkit for speech recognition
1132written in C++.")
1133 (license license:asl2.0))))
99260014
RW
1134
1135(define-public gst-kaldi-nnet2-online
1136 (let ((commit "617e43e73c7cc45eb9119028c02bd4178f738c4a")
1137 (revision "1"))
1138 (package
1139 (name "gst-kaldi-nnet2-online")
1140 (version (git-version "0" revision commit))
1141 (source (origin
1142 (method git-fetch)
1143 (uri (git-reference
1144 (url "https://github.com/alumae/gst-kaldi-nnet2-online.git")
1145 (commit commit)))
1146 (file-name (git-file-name name version))
1147 (sha256
1148 (base32
1149 "0xh3w67b69818s6ib02ara4lw7wamjdmh4jznvkpzrs4skbs9jx9"))))
1150 (build-system gnu-build-system)
1151 (arguments
1152 `(#:tests? #f ; there are none
1153 #:make-flags
1154 (list (string-append "SHELL="
1155 (assoc-ref %build-inputs "bash") "/bin/bash")
1156 (string-append "KALDI_ROOT="
1157 (assoc-ref %build-inputs "kaldi-src"))
1158 (string-append "KALDILIBDIR="
1159 (assoc-ref %build-inputs "kaldi") "/lib")
1160 "KALDI_FLAVOR=dynamic")
1161 #:phases
1162 (modify-phases %standard-phases
1163 (add-after 'unpack 'chdir
1164 (lambda _ (chdir "src") #t))
1165 (replace 'configure
1166 (lambda* (#:key inputs #:allow-other-keys)
1167 (let ((glib (assoc-ref inputs "glib")))
ad60a348 1168 (setenv "CXXFLAGS" "-fPIC")
99260014
RW
1169 (setenv "CPLUS_INCLUDE_PATH"
1170 (string-append glib "/include/glib-2.0:"
1171 glib "/lib/glib-2.0/include:"
1172 (assoc-ref inputs "gstreamer")
ad60a348 1173 "/include/gstreamer-1.0")))
99260014
RW
1174 (substitute* "Makefile"
1175 (("include \\$\\(KALDI_ROOT\\)/src/kaldi.mk") "")
ad60a348
MB
1176 (("\\$\\(error Cannot find") "#"))
1177 #t))
99260014
RW
1178 (add-before 'build 'build-depend
1179 (lambda* (#:key make-flags #:allow-other-keys)
1180 (apply invoke "make" "depend" make-flags)))
1181 (replace 'install
1182 (lambda* (#:key outputs #:allow-other-keys)
1183 (let* ((out (assoc-ref outputs "out"))
1184 (lib (string-append out "/lib/gstreamer-1.0")))
1185 (install-file "libgstkaldinnet2onlinedecoder.so" lib)
1186 #t))))))
1187 (inputs
1188 `(("glib" ,glib)
1189 ("gstreamer" ,gstreamer)
1190 ("jansson" ,jansson)
1191 ("openfst" ,openfst)
1192 ("kaldi" ,kaldi)))
1193 (native-inputs
1194 `(("bash" ,bash)
1195 ("glib:bin" ,glib "bin") ; glib-genmarshal
1196 ("kaldi-src" ,(package-source kaldi))
1197 ("pkg-config" ,pkg-config)))
1198 (home-page "https://kaldi-asr.org/")
1199 (synopsis "Gstreamer plugin for decoding speech")
1200 (description "This package provides a GStreamer plugin that wraps
1201Kaldi's @code{SingleUtteranceNnet2Decoder}. It requires iVector-adapted DNN
1202acoustic models. The iVectors are adapted to the current audio stream
1203automatically.")
1204 (license license:asl2.0))))
10451f6b
RW
1205
1206(define-public kaldi-gstreamer-server
1207 (let ((commit "1735ba49c5dc0ebfc184e45105fc600cd9f1f508")
1208 (revision "1"))
1209 (package
1210 (name "kaldi-gstreamer-server")
1211 (version (git-version "0" revision commit))
1212 (source (origin
1213 (method git-fetch)
1214 (uri (git-reference
1215 (url "https://github.com/alumae/kaldi-gstreamer-server.git")
1216 (commit commit)))
1217 (file-name (git-file-name name version))
1218 (sha256
1219 (base32
1220 "0j701m7lbwmzqxsfanj882v7881hrbmpqybbczbxqpcbg8q34w0k"))))
1221 (build-system gnu-build-system)
1222 (arguments
1223 `(#:tests? #f ; there are no tests that can be run automatically
1224 #:modules ((guix build utils)
1225 (guix build gnu-build-system)
1226 (srfi srfi-26))
1227 #:phases
1228 (modify-phases %standard-phases
1229 (delete 'configure)
1230 (replace 'build
1231 (lambda* (#:key outputs #:allow-other-keys)
1232 ;; Disable hash randomization to ensure the generated .pycs
1233 ;; are reproducible.
1234 (setenv "PYTHONHASHSEED" "0")
1235 (with-directory-excursion "kaldigstserver"
1236 (for-each (lambda (file)
1237 (apply invoke
1238 `("python"
1239 "-m" "compileall"
1240 "-f" ; force rebuild
1241 ,file)))
1242 (find-files "." "\\.py$")))
1243 #t))
1244 (replace 'install
1245 (lambda* (#:key inputs outputs #:allow-other-keys)
1246 (let* ((out (assoc-ref outputs "out"))
1247 (bin (string-append out "/bin"))
1248 (share (string-append out "/share/kaldi-gstreamer-server/")))
1249 ;; Install Python files
1250 (with-directory-excursion "kaldigstserver"
1251 (for-each (cut install-file <> share)
1252 (find-files "." ".*")))
1253
1254 ;; Install sample configuration files
1255 (for-each (cut install-file <> share)
1256 (find-files "." "\\.yaml"))
1257
1258 ;; Install executables
1259 (mkdir-p bin)
1260 (let* ((server (string-append bin "/kaldi-gst-server"))
1261 (client (string-append bin "/kaldi-gst-client"))
1262 (worker (string-append bin "/kaldi-gst-worker"))
1263 (PYTHONPATH (getenv "PYTHONPATH"))
1264 (GST_PLUGIN_PATH (string-append
1265 (assoc-ref inputs "gst-kaldi-nnet2-online")
1266 "/lib/gstreamer-1.0:${GST_PLUGIN_PATH}"))
1267 (wrap (lambda (wrapper what)
1268 (with-output-to-file wrapper
1269 (lambda _
1270 (format #t
1271 "#!~a
1272export PYTHONPATH=~a
1273export GST_PLUGIN_PATH=~a
1274exec ~a ~a/~a \"$@\"~%"
1275 (which "bash") PYTHONPATH GST_PLUGIN_PATH
1276 (which "python") share what)))
1277 (chmod wrapper #o555))))
1278 (for-each wrap
1279 (list server client worker)
1280 (list "master_server.py"
1281 "client.py"
1282 "worker.py")))
1283 #t))))))
1284 (inputs
1285 `(("gst-kaldi-nnet2-online" ,gst-kaldi-nnet2-online)
1286 ("python2" ,python-2)
1287 ("python2-futures" ,python2-futures)
1288 ("python2-pygobject" ,python2-pygobject)
1289 ("python2-pyyaml" ,python2-pyyaml)
1290 ("python2-tornado" ,python2-tornado)
1291 ("python2-ws4py" ,python2-ws4py-for-kaldi-gstreamer-server)))
1292 (home-page "https://github.com/alumae/kaldi-gstreamer-server")
1293 (synopsis "Real-time full-duplex speech recognition server")
1294 (description "This is a real-time full-duplex speech recognition server,
1295based on the Kaldi toolkit and the GStreamer framework and implemented in
1296Python.")
1297 (license license:bsd-2))))
0dfeb285 1298
4fa16c9a
RW
1299;; Note that Tensorflow includes a "third_party" directory, which seems to not
1300;; only contain modified subsets of upstream library source code, but also
1301;; adapter headers provided by Google (such as the fft.h header, which is not
1302;; part of the upstream project code). The Tensorflow code includes headers
1303;; from the "third_party" directory. It does not look like we can replace
1304;; these headers with unmodified upstream files, so we keep them.
1305(define-public tensorflow
1306 (package
1307 (name "tensorflow")
1308 (version "1.9.0")
1309 (source
1310 (origin
1311 (method git-fetch)
1312 (uri (git-reference
1313 (url "https://github.com/tensorflow/tensorflow.git")
1314 (commit (string-append "v" version))))
1315 (file-name (string-append "tensorflow-" version "-checkout"))
1316 (sha256
1317 (base32
1318 "0a9kwha395g3wgxfwln5j8vn9nkspmd75xldrlqdq540w996g8xa"))))
1319 (build-system cmake-build-system)
1320 (arguments
1321 `(#:tests? #f ; no "check" target
1322 #:build-type "Release"
1323 #:configure-flags
1324 (let ((protobuf (assoc-ref %build-inputs "protobuf"))
1325 (protobuf:native (assoc-ref %build-inputs "protobuf:native"))
1326 (jsoncpp (assoc-ref %build-inputs "jsoncpp"))
1327 (snappy (assoc-ref %build-inputs "snappy"))
1328 (sqlite (assoc-ref %build-inputs "sqlite")))
1329 (list
1330 ;; Use protobuf from Guix
1331 (string-append "-Dprotobuf_STATIC_LIBRARIES="
1332 protobuf "/lib/libprotobuf.so")
1333 (string-append "-DPROTOBUF_PROTOC_EXECUTABLE="
1334 protobuf:native "/bin/protoc")
1335
1336 ;; Use snappy from Guix
1337 (string-append "-Dsnappy_STATIC_LIBRARIES="
1338 snappy "/lib/libsnappy.so")
1339 ;; Yes, this is not actually the include directory but a prefix...
1340 (string-append "-Dsnappy_INCLUDE_DIR=" snappy)
1341
1342 ;; Use jsoncpp from Guix
1343 (string-append "-Djsoncpp_STATIC_LIBRARIES="
1344 jsoncpp "/lib/libjsoncpp.so")
1345 ;; Yes, this is not actually the include directory but a prefix...
1346 (string-append "-Djsoncpp_INCLUDE_DIR=" jsoncpp)
1347
1348 ;; Use sqlite from Guix
1349 (string-append "-Dsqlite_STATIC_LIBRARIES="
1350 sqlite "/lib/libsqlite.a")
1351
1352 ;; Use system libraries wherever possible. Currently, this
1353 ;; only affects zlib.
1354 "-Dsystemlib_ALL=ON"
1355 "-Dtensorflow_ENABLE_POSITION_INDEPENDENT_CODE=ON"
1356 "-Dtensorflow_BUILD_SHARED_LIB=ON"
1357 "-Dtensorflow_OPTIMIZE_FOR_NATIVE_ARCH=OFF"
1358 "-Dtensorflow_ENABLE_SSL_SUPPORT=OFF"
1359 "-Dtensorflow_BUILD_CONTRIB_KERNELS=OFF"))
1360 #:make-flags
1361 (list "CC=gcc")
1362 #:modules ((ice-9 ftw)
1363 (guix build utils)
1364 (guix build cmake-build-system))
1365 #:phases
1366 (modify-phases %standard-phases
1367 (add-after 'unpack 'set-source-file-times-to-1980
1368 ;; At the end of the tf_python_build_pip_package target, a ZIP
1369 ;; archive should be generated via bdist_wheel, but it fails with
1370 ;; "ZIP does not support timestamps before 1980". Luckily,
1371 ;; SOURCE_DATE_EPOCH is respected, which we set to some time in
1372 ;; 1980.
1373 (lambda _ (setenv "SOURCE_DATE_EPOCH" "315532800") #t))
1374 ;; See https://github.com/tensorflow/tensorflow/issues/20517#issuecomment-406373913
1375 (add-after 'unpack 'python3.7-compatibility
1376 (lambda _
1377 (substitute* '("tensorflow/python/eager/pywrap_tfe_src.cc"
1378 "tensorflow/python/lib/core/ndarray_tensor.cc"
1379 "tensorflow/python/lib/core/py_func.cc")
1380 (("PyUnicode_AsUTF8") "(char *)PyUnicode_AsUTF8"))
1381 (substitute* "tensorflow/c/eager/c_api.h"
1382 (("unsigned char async")
1383 "unsigned char is_async"))
1384
1385 ;; Remove dependency on tensorboard, a complicated but probably
1386 ;; optional package.
1387 (substitute* "tensorflow/tools/pip_package/setup.py"
1388 ((".*'tensorboard >.*") ""))
1389 #t))
1390 (add-after 'python3.7-compatibility 'chdir
1391 (lambda _ (chdir "tensorflow/contrib/cmake") #t))
1392 (add-after 'chdir 'disable-downloads
1393 (lambda* (#:key inputs #:allow-other-keys)
1394 (substitute* (find-files "external" "\\.cmake$")
1395 (("GIT_REPOSITORY.*") "")
1396 (("GIT_TAG.*") "")
1397 (("PREFIX ")
1398 "DOWNLOAD_COMMAND \"\"\nPREFIX "))
1399
1400 ;; Use packages from Guix
1401 (let ((grpc (assoc-ref inputs "grpc")))
1402 (substitute* "CMakeLists.txt"
1403 ;; Sqlite
1404 (("include\\(sqlite\\)") "")
1405 (("\\$\\{sqlite_STATIC_LIBRARIES\\}")
1406 (string-append (assoc-ref inputs "sqlite")
1407 "/lib/libsqlite3.so"))
1408 (("sqlite_copy_headers_to_destination") "")
1409
1410 ;; PNG
1411 (("include\\(png\\)") "")
1412 (("\\$\\{png_STATIC_LIBRARIES\\}")
1413 (string-append (assoc-ref inputs "libpng")
1414 "/lib/libpng16.so"))
1415 (("png_copy_headers_to_destination") "")
1416
1417 ;; JPEG
1418 (("include\\(jpeg\\)") "")
1419 (("\\$\\{jpeg_STATIC_LIBRARIES\\}")
1420 (string-append (assoc-ref inputs "libjpeg")
1421 "/lib/libjpeg.so"))
1422 (("jpeg_copy_headers_to_destination") "")
1423
1424 ;; GIF
1425 (("include\\(gif\\)") "")
1426 (("\\$\\{gif_STATIC_LIBRARIES\\}")
1427 (string-append (assoc-ref inputs "giflib")
1428 "/lib/libgif.so"))
1429 (("gif_copy_headers_to_destination") "")
1430
1431 ;; lmdb
1432 (("include\\(lmdb\\)") "")
1433 (("\\$\\{lmdb_STATIC_LIBRARIES\\}")
1434 (string-append (assoc-ref inputs "lmdb")
1435 "/lib/liblmdb.so"))
1436 (("lmdb_copy_headers_to_destination") "")
1437
1438 ;; Protobuf
1439 (("include\\(protobuf\\)") "")
1440 (("protobuf_copy_headers_to_destination") "")
1441 (("^ +protobuf") "")
1442
1443 ;; gRPC
1444 (("include\\(grpc\\)")
1445 "find_package(grpc REQUIRED NAMES gRPC)")
1446 (("list\\(APPEND tensorflow_EXTERNAL_DEPENDENCIES grpc\\)") "")
1447
1448 ;; Eigen
1449 (("include\\(eigen\\)")
1450 (string-append "find_package(eigen REQUIRED NAMES Eigen3)
1451set(eigen_INCLUDE_DIRS ${CMAKE_CURRENT_BINARY_DIR}/external/eigen_archive "
1452 (assoc-ref inputs "eigen") "/include/eigen3)"))
1453 (("^ +eigen") "")
1454
1455 ;; snappy
1456 (("include\\(snappy\\)")
1457 "add_definitions(-DTF_USE_SNAPPY)")
1458 (("list\\(APPEND tensorflow_EXTERNAL_DEPENDENCIES snappy\\)") "")
1459
1460 ;; jsoncpp
1461 (("include\\(jsoncpp\\)") "")
1462 (("^ +jsoncpp") ""))
1463
1464 (substitute* "tf_core_framework.cmake"
1465 ((" grpc") "")
1466 (("\\$\\{GRPC_BUILD\\}/grpc_cpp_plugin")
1467 (which "grpc_cpp_plugin"))
1468 ;; Link with gRPC libraries
1469 (("add_library\\(tf_protos_cc.*" m)
1470 (string-append m
1471 (format #f "\ntarget_link_libraries(tf_protos_cc PRIVATE \
1472~a/lib/libgrpc++_unsecure.a \
1473~a/lib/libgrpc_unsecure.a \
1474~a/lib/libaddress_sorting.a \
1475~a/lib/libgpr.a \
1476~a//lib/libcares.so
1477)\n"
1478 grpc grpc grpc grpc
1479 (assoc-ref inputs "c-ares"))))))
1480 (substitute* "tf_tools.cmake"
1481 (("add_dependencies\\(\\$\\{proto_text.*") ""))
1482 ;; Remove dependency on bundled grpc
1483 (substitute* "tf_core_distributed_runtime.cmake"
1484 (("tf_core_cpu grpc") "tf_core_cpu"))
1485
1486 ;; This directory is a dependency of many targets.
1487 (mkdir-p "protobuf")
1488 #t))
1489 (add-after 'configure 'unpack-third-party-sources
1490 (lambda* (#:key inputs #:allow-other-keys)
1491 ;; This is needed to configure bundled packages properly.
1492 (setenv "CONFIG_SHELL" (which "bash"))
1493 (for-each
1494 (lambda (name)
1495 (let* ((what (assoc-ref inputs (string-append name "-src")))
1496 (name* (string-map (lambda (c)
1497 (if (char=? c #\-)
1498 #\_ c)) name))
1499 (where (string-append "../build/" name* "/src/" name*)))
1500 (cond
1501 ((string-suffix? ".zip" what)
1502 (mkdir-p where)
1503 (with-directory-excursion where
1504 (invoke "unzip" what)))
1505 ((string-suffix? ".tar.gz" what)
1506 (mkdir-p where)
1507 (invoke "tar" "xf" what
1508 "-C" where "--strip-components=1"))
1509 (else
1510 (let ((parent (dirname where)))
1511 (mkdir-p parent)
1512 (with-directory-excursion parent
1513 (when (file-exists? name*)
1514 (delete-file-recursively name*))
1515 (copy-recursively what name*)
1516 (map make-file-writable
1517 (find-files name* ".*"))))))))
1518 (list "boringssl"
1519 "cub"
1520 "double-conversion"
1521 "farmhash"
1522 "fft2d"
1523 "highwayhash"
1524 "nsync"
1525 "re2"))
1526
1527 (rename-file "../build/cub/src/cub/cub-1.8.0/"
1528 "../build/cub/src/cub/cub/")
1529 #t))
1530 (add-after 'unpack 'fix-python-build
1531 (lambda* (#:key inputs outputs #:allow-other-keys)
1532 (mkdir-p "protobuf-src")
1533 (invoke "tar" "xf" (assoc-ref inputs "protobuf:src")
1534 "-C" "protobuf-src" "--strip-components=1")
1535 (mkdir-p "eigen-src")
1536 (invoke "tar" "xf" (assoc-ref inputs "eigen:src")
1537 "-C" "eigen-src" "--strip-components=1")
1538
1539 (substitute* "tensorflow/contrib/cmake/tf_python.cmake"
1540 ;; Ensure that all Python dependencies can be found at build time.
1541 (("PYTHONPATH=\\$\\{CMAKE_CURRENT_BINARY_DIR\\}/tf_python" m)
1542 (string-append m ":" (getenv "PYTHONPATH")))
1543 ;; Take protobuf source files from our source package.
1544 (("\\$\\{CMAKE_CURRENT_BINARY_DIR\\}/protobuf/src/protobuf/src/google")
1545 (string-append (getcwd) "/protobuf-src/src/google")))
1546
1547 (substitute* '("tensorflow/contrib/cmake/tf_shared_lib.cmake"
1548 "tensorflow/contrib/cmake/tf_python.cmake")
1549 ;; Take Eigen source files from our source package.
1550 (("\\$\\{CMAKE_CURRENT_BINARY_DIR\\}/eigen/src/eigen/")
1551 (string-append (getcwd) "/eigen-src/"))
1552 ;; Take Eigen headers from our own package.
1553 (("\\$\\{CMAKE_CURRENT_BINARY_DIR\\}/external/eigen_archive")
1554 (string-append (assoc-ref inputs "eigen") "/include/eigen3")))
1555
1556 ;; Correct the RUNPATH of ops libraries generated for Python.
1557 ;; TODO: this doesn't work :(
1558 ;; /gnu/store/...-tensorflow-1.9.0/lib/python3.7/site-packages/tensorflow/contrib/seq2seq/python/ops/lib_beam_search_ops.so:
1559 ;; warning: RUNPATH contains bogus entries: ("/tmp/guix-build-tensorflow-1.9.0.drv-0/source/tensorflow/contrib/build")
1560 ;; /gnu/store/...-tensorflow-1.9.0/lib/python3.7/site-packages/tensorflow/contrib/seq2seq/python/ops/lib_beam_search_ops.so:
1561 ;; error: depends on 'libpywrap_tensorflow_internal.so', which
1562 ;; cannot be found in RUNPATH ...
1563 (substitute* "tensorflow/contrib/cmake/tf_cc_ops.cmake"
1564 (("set_target_properties.*")
1565 (string-append "set_target_properties(${_AT_TARGET} PROPERTIES \
1566COMPILE_FLAGS ${target_compile_flags} \
1567INSTALL_RPATH_USE_LINK_PATH TRUE \
1568INSTALL_RPATH " (assoc-ref outputs "out") "/lib)\n")))
1569 #t))
1570 (add-after 'build 'build-pip-package
1571 (lambda* (#:key outputs #:allow-other-keys)
1572 (setenv "LDFLAGS"
1573 (string-append "-Wl,-rpath="
1574 (assoc-ref outputs "out") "/lib"))
1575 (invoke "make" "tf_python_build_pip_package")
1576 #t))
1577 (add-after 'build-pip-package 'install-python
1578 (lambda* (#:key outputs #:allow-other-keys)
1579 (let ((out (assoc-ref outputs "out"))
1580 (wheel (car (find-files "../build/tf_python/dist/" "\\.whl$"))))
1581 (invoke "python" "-m" "pip" "install" wheel
1582 (string-append "--prefix=" out))
1583
1584 ;; XXX: broken RUNPATH, see fix-python-build phase.
1585 (delete-file
1586 (string-append
1587 out "/lib/python3.7/site-packages/tensorflow/contrib/"
1588 "seq2seq/python/ops/lib_beam_search_ops.so"))
1589 #t))))))
1590 (native-inputs
1591 `(("pkg-config" ,pkg-config)
7373eb83
MB
1592 ("protobuf:native" ,protobuf-3.6) ; protoc
1593 ("protobuf:src" ,(package-source protobuf-3.6))
4fa16c9a 1594 ("eigen:src" ,(package-source eigen-for-tensorflow))
0fdec2a3
MB
1595 ;; install_pip_packages.sh wants setuptools 39.1.0 specifically.
1596 ("python-setuptools" ,python-setuptools-for-tensorflow)
1597
4fa16c9a
RW
1598 ;; The commit hashes and URLs for third-party source code are taken
1599 ;; from "tensorflow/workspace.bzl".
1600 ("boringssl-src"
1601 ,(let ((commit "ee7aa02")
1602 (revision "1"))
1603 (origin
1604 (method git-fetch)
1605 (uri (git-reference
1606 (url "https://boringssl.googlesource.com/boringssl")
1607 (commit commit)))
1608 (file-name (string-append "boringssl-0-" revision
1609 (string-take commit 7)
1610 "-checkout"))
1611 (sha256
1612 (base32
1613 "1jf693q0nw0adsic6cgmbdx6g7wr4rj4vxa8j1hpn792fqhd8wgw")))))
1614 ("cub-src"
1615 ,(let ((version "1.8.0"))
1616 (origin
1617 (method url-fetch)
1618 (uri (string-append "https://mirror.bazel.build/github.com/NVlabs/"
1619 "cub/archive/" version ".zip"))
1620 (file-name (string-append "cub-" version ".zip"))
1621 (sha256
1622 (base32
1623 "1hsqikqridb90dkxkjr2918dcry6pfh46ccnwrzawl56aamhdykb")))))
1624 ("double-conversion-src"
1625 ,(let ((commit "5664746")
1626 (revision "1"))
1627 (origin
1628 (method git-fetch)
1629 (uri (git-reference
1630 (url "https://github.com/google/double-conversion.git")
1631 (commit commit)))
1632 (file-name
1633 (git-file-name "double-conversion"
1634 (string-append "0-" revision "."
1635 (string-take commit 7))))
1636 (sha256
1637 (base32
1638 "1h5lppqqxcvdg5jq42i5msgwx20ryij3apvmndflngrgdpc04gn1")))))
1639 ("farmhash-src"
1640 ,(let ((commit "816a4ae622e964763ca0862d9dbd19324a1eaf45"))
1641 (origin
1642 (method url-fetch)
1643 (uri (string-append
1644 "https://mirror.bazel.build/github.com/google/farmhash/archive/"
1645 commit ".tar.gz"))
1646 (file-name (string-append "farmhash-0-" (string-take commit 7)
1647 ".tar.gz"))
1648 (sha256
1649 (base32
1650 "185b2xdxl4d4cnsnv6abg8s22gxvx8673jq2yaq85bz4cdy58q35")))))
1651 ;; The license notice on the home page at
1652 ;; http://www.kurims.kyoto-u.ac.jp/~ooura/fft.html says:
1653 ;; Copyright Takuya OOURA, 1996-2001
1654 ;;
1655 ;; You may use, copy, modify and distribute this code for any purpose
1656 ;; (include commercial use) and without fee. Please refer to this
1657 ;; package when you modify this code.
1658 ;;
1659 ;; We take the identical tarball from the Bazel mirror, because the URL
1660 ;; at the home page is not versioned and might change.
1661 ("fft2d-src"
1662 ,(origin
1663 (method url-fetch)
1664 (uri "https://mirror.bazel.build/www.kurims.kyoto-u.ac.jp/~ooura/fft.tgz")
1665 (file-name "fft2d.tar.gz")
1666 (sha256
1667 (base32
1668 "15jjkfvhqvl2c0753d2di8hz0pyzn598g74wqy79awdrf1y67fsj"))))
1669 ("highwayhash-src"
1670 ,(let ((commit "be5edafc2e1a455768e260ccd68ae7317b6690ee")
1671 (revision "1"))
1672 (origin
1673 (method git-fetch)
1674 (uri (git-reference
1675 (url "https://github.com/google/highwayhash.git")
1676 (commit commit)))
1677 (file-name (string-append "highwayhash-0-" revision
1678 (string-take commit 7)
1679 "-checkout"))
1680 (sha256
1681 (base32
1682 "154jwf98cyy54hldr94pgjn85zynly3abpnc1avmb8a18lzwjyb6")))))
1683 ("nsync-src"
1684 ,(let ((version "0559ce013feac8db639ee1bf776aca0325d28777")
1685 (revision "1"))
1686 (origin
1687 (method url-fetch)
1688 (uri (string-append "https://mirror.bazel.build/"
1689 "github.com/google/nsync/archive/"
1690 version ".tar.gz"))
1691 (file-name (string-append "nsync-0." revision
1692 "-" (string-take version 7)
1693 ".tar.gz"))
1694 (sha256
1695 (base32
1696 "0qdkyqym34x739mmzv97ah5r7ph462v5xkxqxvidmcfqbi64b132")))))
1697 ("re2-src"
1698 ,(let ((commit "e7efc48")
1699 (revision "1"))
1700 (origin
1701 (method git-fetch)
1702 (uri (git-reference
1703 (url "https://github.com/google/re2")
1704 (commit commit)))
1705 (file-name (string-append "re2-0-" revision
1706 (string-take commit 7)
1707 "-checkout"))
1708 (sha256
1709 (base32
1710 "161g9841rjfsy5pn52fcis0s9hdr7rxvb06pad38j5rppfihvign")))))
1711 ("googletest" ,googletest)
1712 ("swig" ,swig)
1713 ("unzip" ,unzip)))
1714 (propagated-inputs
1715 `(("python-absl-py" ,python-absl-py)
1716 ("python-astor" ,python-astor)
1717 ("python-gast" ,python-gast)
1718 ("python-grpcio" ,python-grpcio)
1719 ("python-numpy" ,python-numpy)
7373eb83 1720 ("python-protobuf" ,python-protobuf-3.6)
4fa16c9a
RW
1721 ("python-six" ,python-six)
1722 ("python-termcolo" ,python-termcolor)
1723 ("python-wheel" ,python-wheel)))
1724 (inputs
3b458d54 1725 `(("c-ares" ,c-ares)
4fa16c9a
RW
1726 ("eigen" ,eigen-for-tensorflow)
1727 ("gemmlowp" ,gemmlowp-for-tensorflow)
1728 ("lmdb" ,lmdb)
1729 ("libjpeg" ,libjpeg)
1730 ("libpng" ,libpng)
1731 ("giflib" ,giflib)
80a8583a 1732 ("grpc" ,grpc-1.16.1 "static")
447fafe3 1733 ("grpc:bin" ,grpc-1.16.1)
4fa16c9a
RW
1734 ("jsoncpp" ,jsoncpp-for-tensorflow)
1735 ("snappy" ,snappy)
1736 ("sqlite" ,sqlite)
7373eb83 1737 ("protobuf" ,protobuf-3.6)
4fa16c9a
RW
1738 ("python" ,python-wrapper)
1739 ("zlib" ,zlib)))
1740 (home-page "https://tensorflow.org")
1741 (synopsis "Machine learning framework")
1742 (description
1743 "TensorFlow is a flexible platform for building and training machine
1744learning models. It provides a library for high performance numerical
1745computation and includes high level Python APIs, including both a sequential
1746API for beginners that allows users to build models quickly by plugging
1747together building blocks and a subclassing API with an imperative style for
1748advanced research.")
1749 (license license:asl2.0)))
d60b064d
NG
1750
1751(define-public python-iml
1752 (package
1753 (name "python-iml")
1754 (version "0.6.2")
1755 (source
1756 (origin
1757 (method url-fetch)
1758 (uri (pypi-uri "iml" version))
1759 (sha256
1760 (base32
1761 "1k8szlpm19rcwcxdny9qdm3gmaqq8akb4xlvrzyz8c2d679aak6l"))))
1762 (build-system python-build-system)
1763 (propagated-inputs
1764 `(("ipython" ,python-ipython)
1765 ("nose" ,python-nose)
1766 ("numpy" ,python-numpy)
1767 ("pandas" ,python-pandas)
1768 ("scipy" ,python-scipy)))
1769 (home-page "http://github.com/interpretable-ml/iml")
1770 (synopsis "Interpretable Machine Learning (iML) package")
1771 (description "Interpretable ML (iML) is a set of data type objects,
1772visualizations, and interfaces that can be used by any method designed to
1773explain the predictions of machine learning models (or really the output of
1774any function). It currently contains the interface and IO code from the Shap
1775project, and it will potentially also do the same for the Lime project.")
1776 (license license:expat)))
d93ad191
RW
1777
1778(define-public python-keras-applications
1779 (package
1780 (name "python-keras-applications")
1781 (version "1.0.8")
1782 (source
1783 (origin
1784 (method url-fetch)
1785 (uri (pypi-uri "Keras_Applications" version))
1786 (sha256
1787 (base32
1788 "1rcz31ca4axa6kzhjx4lwqxbg4wvlljkj8qj9a7p9sfd5fhzjyam"))))
1789 (build-system python-build-system)
1790 ;; The tests require Keras, but this package is needed to build Keras.
1791 (arguments '(#:tests? #f))
1792 (propagated-inputs
1793 `(("python-h5py" ,python-h5py)
1794 ("python-numpy" ,python-numpy)))
1795 (native-inputs
1796 `(("python-pytest" ,python-pytest)
1797 ("python-pytest-cov" ,python-pytest-cov)
1798 ("python-pytest-pep8" ,python-pytest-pep8)
1799 ("python-pytest-xdist" ,python-pytest-xdist)))
1800 (home-page "https://github.com/keras-team/keras-applications")
1801 (synopsis "Reference implementations of popular deep learning models")
1802 (description
1803 "This package provides reference implementations of popular deep learning
1804models for use with the Keras deep learning framework.")
1805 (license license:expat)))
4abc5066
RW
1806
1807(define-public python-keras-preprocessing
1808 (package
1809 (name "python-keras-preprocessing")
1810 (version "1.1.0")
1811 (source
1812 (origin
1813 (method url-fetch)
1814 (uri (pypi-uri "Keras_Preprocessing" version))
1815 (sha256
1816 (base32
1817 "1r98nm4k1svsqjyaqkfk23i31bl1kcfcyp7094yyj3c43phfp3as"))))
1818 (build-system python-build-system)
1819 (propagated-inputs
1820 `(("python-numpy" ,python-numpy)
1821 ("python-six" ,python-six)))
1822 (native-inputs
1823 `(("python-pandas" ,python-pandas)
1824 ("python-pillow" ,python-pillow)
1825 ("python-pytest" ,python-pytest)
1826 ("python-pytest-cov" ,python-pytest-cov)
1827 ("python-pytest-xdist" ,python-pytest-xdist)
1828 ("tensorflow" ,tensorflow)))
1829 (home-page "https://github.com/keras-team/keras-preprocessing/")
1830 (synopsis "Data preprocessing and augmentation for deep learning models")
1831 (description
1832 "Keras Preprocessing is the data preprocessing and data augmentation
1833module of the Keras deep learning library. It provides utilities for working
1834with image data, text data, and sequence data.")
1835 (license license:expat)))
f1765b57
RW
1836
1837(define-public python-keras
1838 (package
1839 (name "python-keras")
1840 (version "2.2.4")
1841 (source
1842 (origin
1843 (method url-fetch)
1844 (uri (pypi-uri "Keras" version))
b16e0827 1845 (patches (search-patches "python-keras-integration-test.patch"))
f1765b57
RW
1846 (sha256
1847 (base32
1848 "1j8bsqzh49vjdxy6l1k4iwax5vpjzniynyd041xjavdzvfii1dlh"))))
1849 (build-system python-build-system)
1850 (arguments
1851 `(#:phases
1852 (modify-phases %standard-phases
1853 (add-after 'unpack 'remove-tests-for-unavailable-features
1854 (lambda _
1855 (delete-file "keras/backend/theano_backend.py")
1856 (delete-file "keras/backend/cntk_backend.py")
1857 (delete-file "tests/keras/backend/backend_test.py")
1858
1859 ;; FIXME: This doesn't work because Tensorflow is missing the
1860 ;; coder ops library.
1861 (delete-file "tests/keras/test_callbacks.py")
1862 #t))
1863 (replace 'check
1864 (lambda _
1865 ;; These tests attempt to download data files from the internet.
1866 (delete-file "tests/integration_tests/test_datasets.py")
1867 (delete-file "tests/integration_tests/imagenet_utils_test.py")
1868
1869 (setenv "PYTHONPATH"
1870 (string-append (getcwd) "/build/lib:"
1871 (getenv "PYTHONPATH")))
1872 (invoke "py.test" "-v"
1873 "-p" "no:cacheprovider"
1874 "--ignore" "keras/utils"))))))
1875 (propagated-inputs
1876 `(("python-h5py" ,python-h5py)
1877 ("python-keras-applications" ,python-keras-applications)
1878 ("python-keras-preprocessing" ,python-keras-preprocessing)
1879 ("python-numpy" ,python-numpy)
1880 ("python-pydot" ,python-pydot)
1881 ("python-pyyaml" ,python-pyyaml)
1882 ("python-scipy" ,python-scipy)
1883 ("python-six" ,python-six)
1884 ("tensorflow" ,tensorflow)
1885 ("graphviz" ,graphviz)))
1886 (native-inputs
1887 `(("python-pandas" ,python-pandas)
1888 ("python-pytest" ,python-pytest)
1889 ("python-pytest-cov" ,python-pytest-cov)
1890 ("python-pytest-pep8" ,python-pytest-pep8)
1891 ("python-pytest-timeout" ,python-pytest-timeout)
1892 ("python-pytest-xdist" ,python-pytest-xdist)
1893 ("python-sphinx" ,python-sphinx)
1894 ("python-requests" ,python-requests)))
1895 (home-page "https://github.com/keras-team/keras")
1896 (synopsis "High-level deep learning framework")
1897 (description "Keras is a high-level neural networks API, written in Python
1898and capable of running on top of TensorFlow. It was developed with a focus on
1899enabling fast experimentation. Use Keras if you need a deep learning library
1900that:
1901
1902@itemize
1903@item Allows for easy and fast prototyping (through user friendliness,
1904 modularity, and extensibility).
1905@item Supports both convolutional networks and recurrent networks, as well as
1906 combinations of the two.
1907@item Runs seamlessly on CPU and GPU.
1908@end itemize\n")
1909 (license license:expat)))
6e760872
GLV
1910
1911(define-public sbcl-cl-libsvm-format
1912 (let ((commit "3300f84fd8d9f5beafc114f543f9d83417c742fb")
1913 (revision "0"))
1914 (package
1915 (name "sbcl-cl-libsvm-format")
1916 (version (git-version "0.1.0" revision commit))
1917 (source
1918 (origin
1919 (method git-fetch)
1920 (uri (git-reference
1921 (url "https://github.com/masatoi/cl-libsvm-format.git")
1922 (commit commit)))
1923 (file-name (git-file-name name version))
1924 (sha256
1925 (base32
1926 "0284aj84xszhkhlivaigf9qj855fxad3mzmv3zfr0qzb5k0nzwrg"))))
1927 (build-system asdf-build-system/sbcl)
1928 (native-inputs
1929 `(("prove" ,sbcl-prove)
1930 ("prove-asdf" ,sbcl-prove-asdf)))
1931 (inputs
1932 `(("alexandria" ,sbcl-alexandria)))
1933 (synopsis "LibSVM data format reader for Common Lisp")
1934 (description
1935 "This Common Lisp library provides a fast reader for data in LibSVM
1936format.")
1937 (home-page "https://github.com/masatoi/cl-libsvm-format")
1938 (license license:expat))))
1939
1940(define-public cl-libsvm-format
1941 (sbcl-package->cl-source-package sbcl-cl-libsvm-format))
1942
1943(define-public ecl-cl-libsvm-format
1944 (sbcl-package->ecl-package sbcl-cl-libsvm-format))
7a15aab8
GLV
1945
1946(define-public sbcl-cl-online-learning
1947 (let ((commit "fc7a34f4f161cd1c7dd747d2ed8f698947781423")
1948 (revision "0"))
1949 (package
1950 (name "sbcl-cl-online-learning")
1951 (version (git-version "0.5" revision commit))
1952 (source
1953 (origin
1954 (method git-fetch)
1955 (uri (git-reference
1956 (url "https://github.com/masatoi/cl-online-learning.git")
1957 (commit commit)))
1958 (file-name (git-file-name name version))
1959 (sha256
1960 (base32
1961 "14x95rlg80ay5hv645ki57pqvy12v28hz4k1w0f6bsfi2rmpxchq"))))
1962 (build-system asdf-build-system/sbcl)
1963 (native-inputs
1964 `(("prove" ,sbcl-prove)
1965 ("prove-asdf" ,sbcl-prove-asdf)))
1966 (inputs
1967 `(("cl-libsvm-format" ,sbcl-cl-libsvm-format)
1968 ("cl-store" ,sbcl-cl-store)))
1969 (arguments
1970 `(;; FIXME: Tests pass but then the check phase crashes
1971 #:tests? #f))
1972 (synopsis "Online Machine Learning for Common Lisp")
1973 (description
1974 "This library contains a collection of machine learning algorithms for
1975online linear classification written in Common Lisp.")
1976 (home-page "https://github.com/masatoi/cl-online-learning")
1977 (license license:expat))))
1978
1979(define-public cl-online-learning
1980 (sbcl-package->cl-source-package sbcl-cl-online-learning))
1981
1982(define-public ecl-cl-online-learning
1983 (sbcl-package->ecl-package sbcl-cl-online-learning))
5a65fede
GLV
1984
1985(define-public sbcl-cl-random-forest
1986 (let ((commit "85fbdd4596d40e824f70f1b7cf239cf544e49d51")
1987 (revision "0"))
1988 (package
1989 (name "sbcl-cl-random-forest")
1990 (version (git-version "0.1" revision commit))
1991 (source
1992 (origin
1993 (method git-fetch)
1994 (uri (git-reference
1995 (url "https://github.com/masatoi/cl-random-forest.git")
1996 (commit commit)))
1997 (file-name (git-file-name name version))
1998 (sha256
1999 (base32
2000 "097xv60i1ndz68sg9p4pc7c5gvyp9i1xgw966b4wwfq3x6hbz421"))))
2001 (build-system asdf-build-system/sbcl)
2002 (native-inputs
2003 `(("prove" ,sbcl-prove)
2004 ("prove-asdf" ,sbcl-prove-asdf)
2005 ("trivial-garbage" ,sbcl-trivial-garbage)))
2006 (inputs
2007 `(("alexandria" ,sbcl-alexandria)
2008 ("cl-libsvm-format" ,sbcl-cl-libsvm-format)
2009 ("cl-online-learning" ,sbcl-cl-online-learning)
2010 ("lparallel" ,sbcl-lparallel)))
2011 (arguments
2012 `(;; The tests download data from the Internet
2013 #:tests? #f
2014 #:phases
2015 (modify-phases %standard-phases
2016 (add-after 'unpack 'add-sb-cltl2-dependency
2017 (lambda _
2018 ;; sb-cltl2 is required by lparallel when using sbcl, but it is
2019 ;; not loaded automatically.
2020 (substitute* "cl-random-forest.asd"
2021 (("\\(in-package :cl-user\\)")
2022 "(in-package :cl-user) #+sbcl (require :sb-cltl2)"))
2023 #t)))))
2024 (synopsis "Random Forest and Global Refinement for Common Lisp")
2025 (description
2026 "CL-random-forest is an implementation of Random Forest for multiclass
2027classification and univariate regression written in Common Lisp. It also
2028includes an implementation of Global Refinement of Random Forest.")
2029 (home-page "https://github.com/masatoi/cl-random-forest")
2030 (license license:expat))))
2031
2032(define-public cl-random-forest
2033 (sbcl-package->cl-source-package sbcl-cl-random-forest))
2034
2035(define-public ecl-cl-random-forest
2036 (sbcl-package->ecl-package sbcl-cl-random-forest))
58b13287
GL
2037
2038(define-public gloo
2039 (let ((version "0.0.0") ; no proper version tag
2040 (commit "ca528e32fea9ca8f2b16053cff17160290fc84ce")
2041 (revision "0"))
2042 (package
2043 (name "gloo")
2044 (version (git-version version revision commit))
2045 (source
2046 (origin
2047 (method git-fetch)
2048 (uri (git-reference
2049 (url "https://github.com/facebookincubator/gloo.git")
2050 (commit commit)))
2051 (file-name (git-file-name name version))
2052 (sha256
2053 (base32
2054 "1q9f80zy75f6njrzrqkmhc0g3qxs4gskr7ns2jdqanxa2ww7a99w"))))
2055 (build-system cmake-build-system)
2056 (native-inputs
2057 `(("googletest" ,googletest)))
2058 (arguments
2059 `(#:configure-flags '("-DBUILD_TEST=1")
2060 #:phases
2061 (modify-phases %standard-phases
2062 (replace 'check
2063 (lambda _
2064 (invoke "make" "gloo_test")
2065 #t)))))
2066 (synopsis "Collective communications library")
2067 (description
2068 "Gloo is a collective communications library. It comes with a
2069number of collective algorithms useful for machine learning applications.
2070These include a barrier, broadcast, and allreduce.")
2071 (home-page "https://github.com/facebookincubator/gloo")
2072 (license license:bsd-3))))
5e42d197
BG
2073
2074(define-public python-umap-learn
2075 (package
2076 (name "python-umap-learn")
2077 (version "0.3.10")
2078 (source
2079 (origin
2080 (method url-fetch)
2081 (uri (pypi-uri "umap-learn" version))
2082 (sha256
2083 (base32
2084 "02ada2yy6km6zgk2836kg1c97yrcpalvan34p8c57446finnpki1"))))
2085 (build-system python-build-system)
2086 (native-inputs
e2ca10a4
RJ
2087 `(("python-joblib" ,python-joblib)
2088 ("python-nose" ,python-nose)))
5e42d197
BG
2089 (propagated-inputs
2090 `(("python-numba" ,python-numba)
2091 ("python-numpy" ,python-numpy)
2092 ("python-scikit-learn" ,python-scikit-learn)
2093 ("python-scipy" ,python-scipy)))
2094 (home-page "https://github.com/lmcinnes/umap")
2095 (synopsis
2096 "Uniform Manifold Approximation and Projection")
2097 (description
2098 "Uniform Manifold Approximation and Projection is a dimension reduction
2099technique that can be used for visualisation similarly to t-SNE, but also for
2100general non-linear dimension reduction.")
2101 (license license:bsd-3)))