2016-08-13 06:11:35 -04:00
|
|
|
;;; GNU Guix --- Functional package management for GNU
|
2017-02-01 07:35:32 -05:00
|
|
|
;;; Copyright © 2016, 2017 Marius Bakke <mbakke@fastmail.com>
|
2017-10-03 14:14:50 -04:00
|
|
|
;;; Copyright © 2017 Dave Love <fx@gnu.org>
|
2020-03-14 11:14:48 -04:00
|
|
|
;;; Copyright © 2018, 2019, 2020 Tobias Geerinckx-Rice <me@tobias.gr>
|
2019-03-06 15:55:14 -05:00
|
|
|
;;; Copyright © 2018, 2019 Ricardo Wurmus <rekado@elephly.net>
|
2019-01-30 18:05:03 -05:00
|
|
|
;;; Copyright © 2019 Eric Bavier <bavier@member.fsf.org>
|
2019-06-14 17:07:56 -04:00
|
|
|
;;; Copyright © 2019 Gábor Boskovits <boskovits@gmail.com>
|
2019-12-20 16:35:12 -05:00
|
|
|
;;; Copyright © 2019 Ludovic Courtès <ludo@gnu.org>
|
2020-02-21 18:37:23 -05:00
|
|
|
;;; Copyright © 2020 Vincent Legoll <vincent.legoll@gmail.com>
|
2020-10-23 09:11:52 -04:00
|
|
|
;;; Copyright © 2020 malte Frank Gerdes <malte.f.gerdes@gmail.com>
|
2021-02-18 08:28:57 -05:00
|
|
|
;;; Copyright © 2020, 2021 Maxim Cournoyer <maxim.cournoyer@gmail.com>
|
2020-12-20 08:19:04 -05:00
|
|
|
;;; Copyright © 2020 Greg Hogan <code@greghogan.com>
|
2016-08-13 06:11:35 -04:00
|
|
|
;;;
|
|
|
|
;;; This file is part of GNU Guix.
|
|
|
|
;;;
|
|
|
|
;;; GNU Guix is free software; you can redistribute it and/or modify it
|
|
|
|
;;; under the terms of the GNU General Public License as published by
|
|
|
|
;;; the Free Software Foundation; either version 3 of the License, or (at
|
|
|
|
;;; your option) any later version.
|
|
|
|
;;;
|
|
|
|
;;; GNU Guix is distributed in the hope that it will be useful, but
|
|
|
|
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
;;; GNU General Public License for more details.
|
|
|
|
;;;
|
|
|
|
;;; You should have received a copy of the GNU General Public License
|
|
|
|
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
(define-module (gnu packages benchmark)
|
|
|
|
#:use-module ((guix licenses) #:prefix license:)
|
|
|
|
#:use-module (guix packages)
|
|
|
|
#:use-module (guix download)
|
2019-01-30 18:05:03 -05:00
|
|
|
#:use-module (guix git-download)
|
2019-06-14 17:07:56 -04:00
|
|
|
#:use-module (guix build-system cmake)
|
2016-08-13 06:11:35 -04:00
|
|
|
#:use-module (guix build-system gnu)
|
2020-11-18 11:11:44 -05:00
|
|
|
#:use-module (guix build-system python)
|
2019-06-14 17:07:56 -04:00
|
|
|
#:use-module (gnu packages)
|
|
|
|
#:use-module (gnu packages check)
|
2016-08-13 06:11:35 -04:00
|
|
|
#:use-module (gnu packages compression)
|
2017-02-01 07:35:32 -05:00
|
|
|
#:use-module (gnu packages linux)
|
|
|
|
#:use-module (gnu packages maths)
|
2017-10-03 14:14:50 -04:00
|
|
|
#:use-module (gnu packages mpi)
|
2020-02-21 18:37:23 -05:00
|
|
|
#:use-module (gnu packages perl)
|
2017-01-15 13:36:25 -05:00
|
|
|
#:use-module (gnu packages python)
|
2019-12-04 02:56:36 -05:00
|
|
|
#:use-module (gnu packages python-science)
|
2020-11-18 11:11:44 -05:00
|
|
|
#:use-module (gnu packages python-web)
|
gnu: Separate Python core packages from the rest.
* gnu/packages/python.scm: Move hundreds of package definitions from here...
* gnu/packages/python-xyz.scm: ...to this new module.
* gnu/local.mk (GNU_SYSTEM_MODULES): Add it.
* gnu/packages/ada.scm,
gnu/packages/admin.scm,
gnu/packages/android.scm,
gnu/packages/audio.scm,
gnu/packages/backup.scm,
gnu/packages/benchmark.scm,
gnu/packages/bioinformatics.scm,
gnu/packages/bittorrent.scm,
gnu/packages/calendar.scm,
gnu/packages/check.scm,
gnu/packages/chemistry.scm,
gnu/packages/cluster.scm,
gnu/packages/compression.scm,
gnu/packages/connman.scm,
gnu/packages/crypto.scm,
gnu/packages/cups.scm,
gnu/packages/databases.scm,
gnu/packages/dav.scm,
gnu/packages/direct-connect.scm,
gnu/packages/disk.scm,
gnu/packages/django.scm,
gnu/packages/dlang.scm,
gnu/packages/docker.scm,
gnu/packages/ebook.scm,
gnu/packages/elf.scm,
gnu/packages/emacs.scm,
gnu/packages/emulators.scm,
gnu/packages/engineering.scm,
gnu/packages/enlightenment.scm,
gnu/packages/finance.scm,
gnu/packages/fltk.scm,
gnu/packages/fontutils.scm,
gnu/packages/freedesktop.scm,
gnu/packages/game-development.scm,
gnu/packages/games.scm,
gnu/packages/geo.scm,
gnu/packages/gl.scm,
gnu/packages/glib.scm,
gnu/packages/gnome.scm,
gnu/packages/gnupg.scm,
gnu/packages/gnuzilla.scm,
gnu/packages/graph.scm,
gnu/packages/graphics.scm,
gnu/packages/graphviz.scm,
gnu/packages/gtk.scm,
gnu/packages/ham-radio.scm,
gnu/packages/image-processing.scm,
gnu/packages/image-viewers.scm,
gnu/packages/image.scm,
gnu/packages/irc.scm,
gnu/packages/jrnl.scm,
gnu/packages/julia.scm,
gnu/packages/kde-frameworks.scm,
gnu/packages/key-mon.scm,
gnu/packages/libffi.scm,
gnu/packages/libreoffice.scm,
gnu/packages/libusb.scm,
gnu/packages/lirc.scm,
gnu/packages/logging.scm,
gnu/packages/machine-learning.scm,
gnu/packages/mail.scm,
gnu/packages/mate.scm,
gnu/packages/maths.scm,
gnu/packages/medical.scm,
gnu/packages/messaging.scm,
gnu/packages/monitoring.scm,
gnu/packages/mp3.scm,
gnu/packages/mpd.scm,
gnu/packages/music.scm,
gnu/packages/networking.scm,
gnu/packages/nutrition.scm,
gnu/packages/openldap.scm,
gnu/packages/openstack.scm,
gnu/packages/package-management.scm,
gnu/packages/password-utils.scm,
gnu/packages/patchutils.scm,
gnu/packages/pdf.scm,
gnu/packages/photo.scm,
gnu/packages/polkit.scm,
gnu/packages/protobuf.scm,
gnu/packages/python-crypto.scm,
gnu/packages/python-web.scm,
gnu/packages/qt.scm,
gnu/packages/rdf.scm,
gnu/packages/ruby.scm,
gnu/packages/search.scm,
gnu/packages/selinux.scm,
gnu/packages/serialization.scm,
gnu/packages/shells.scm,
gnu/packages/simulation.scm,
gnu/packages/ssh.scm,
gnu/packages/statistics.scm,
gnu/packages/storage.scm,
gnu/packages/sync.scm,
gnu/packages/terminals.scm,
gnu/packages/textutils.scm,
gnu/packages/time.scm,
gnu/packages/tls.scm,
gnu/packages/tor.scm,
gnu/packages/tryton.scm,
gnu/packages/version-control.scm,
gnu/packages/video.scm,
gnu/packages/virtualization.scm,
gnu/packages/vpn.scm,
gnu/packages/web-browsers.scm,
gnu/packages/web.scm,
gnu/packages/wicd.scm,
gnu/packages/xdisorg.scm,
gnu/packages/xorg.scm: Update module references.
2019-01-15 08:21:30 -05:00
|
|
|
#:use-module (gnu packages python-xyz)
|
2017-10-03 14:14:50 -04:00
|
|
|
#:use-module (gnu packages storage)
|
|
|
|
#:use-module (ice-9 match))
|
2016-08-13 06:11:35 -04:00
|
|
|
|
|
|
|
(define-public fio
|
|
|
|
(package
|
|
|
|
(name "fio")
|
2020-12-06 17:30:31 -05:00
|
|
|
(version "3.25")
|
2016-08-13 06:11:35 -04:00
|
|
|
(source (origin
|
|
|
|
(method url-fetch)
|
2019-12-06 23:19:39 -05:00
|
|
|
(uri (string-append "https://brick.kernel.dk/snaps/"
|
2018-11-07 10:10:58 -05:00
|
|
|
"fio-" version ".tar.bz2"))
|
2016-08-13 06:11:35 -04:00
|
|
|
(sha256
|
|
|
|
(base32
|
2020-12-06 17:30:31 -05:00
|
|
|
"16r734an459cz1ax3jyhxc269i3syzdkll4qbv18wqaxpm5y34v6"))))
|
2016-08-13 06:11:35 -04:00
|
|
|
(build-system gnu-build-system)
|
|
|
|
(arguments
|
2017-02-24 08:32:37 -05:00
|
|
|
'(#:test-target "test"
|
2016-08-13 06:11:35 -04:00
|
|
|
#:phases
|
|
|
|
(modify-phases %standard-phases
|
2017-02-01 07:35:32 -05:00
|
|
|
(add-after
|
|
|
|
'unpack 'patch-paths
|
|
|
|
(lambda* (#:key inputs outputs #:allow-other-keys)
|
|
|
|
(let ((out (assoc-ref outputs "out"))
|
|
|
|
(gnuplot (string-append (assoc-ref inputs "gnuplot")
|
|
|
|
"/bin/gnuplot")))
|
|
|
|
(substitute* "tools/plot/fio2gnuplot"
|
|
|
|
(("/usr/share/fio") (string-append out "/share/fio"))
|
|
|
|
;; FIXME (upstream): The 'gnuplot' executable is used inline
|
|
|
|
;; in various os.system() calls mixed with *.gnuplot filenames.
|
|
|
|
(("; do gnuplot") (string-append "; do " gnuplot))
|
|
|
|
(("gnuplot mymath") (string-append gnuplot " mymath"))
|
|
|
|
(("gnuplot mygraph") (string-append gnuplot " mygraph")))
|
|
|
|
#t)))
|
2016-08-13 06:11:35 -04:00
|
|
|
(replace 'configure
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
;; The configure script doesn't understand some of the
|
|
|
|
;; GNU options, so we can't use #:configure-flags.
|
|
|
|
(let ((out (assoc-ref outputs "out")))
|
2018-04-19 17:11:49 -04:00
|
|
|
(invoke "./configure"
|
|
|
|
(string-append "--prefix=" out))
|
|
|
|
#t)))
|
2017-03-27 18:08:36 -04:00
|
|
|
;; The main `fio` executable is fairly small and self contained.
|
|
|
|
;; Moving the auxiliary python and gnuplot scripts to a separate
|
|
|
|
;; output saves almost 400 MiB on the closure.
|
|
|
|
(add-after 'install 'move-outputs
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
(let ((oldbin (string-append (assoc-ref outputs "out") "/bin"))
|
|
|
|
(newbin (string-append (assoc-ref outputs "utils") "/bin")))
|
|
|
|
(mkdir-p newbin)
|
|
|
|
(for-each (lambda (file)
|
|
|
|
(let ((src (string-append oldbin "/" file))
|
|
|
|
(dst (string-append newbin "/" file)))
|
|
|
|
(link src dst)
|
|
|
|
(delete-file src)))
|
2017-05-21 10:28:25 -04:00
|
|
|
'("fio2gnuplot" "fiologparser_hist.py"
|
|
|
|
"fiologparser.py"))
|
2017-03-27 18:08:36 -04:00
|
|
|
;; Make sure numpy et.al is found.
|
|
|
|
(wrap-program (string-append newbin "/fiologparser_hist.py")
|
|
|
|
`("PYTHONPATH" ":" prefix (,(getenv "PYTHONPATH"))))
|
|
|
|
#t))))))
|
|
|
|
(outputs '("out" "utils"))
|
2016-08-13 06:11:35 -04:00
|
|
|
(inputs
|
2017-01-15 13:36:25 -05:00
|
|
|
`(("ceph" ,ceph "lib")
|
|
|
|
("libaio" ,libaio)
|
2017-02-01 07:35:32 -05:00
|
|
|
("gnuplot" ,gnuplot)
|
|
|
|
("zlib" ,zlib)
|
|
|
|
("python-numpy" ,python2-numpy)
|
|
|
|
("python-pandas" ,python2-pandas)
|
|
|
|
("python" ,python-2)))
|
2016-08-13 06:11:35 -04:00
|
|
|
(home-page "https://github.com/axboe/fio")
|
|
|
|
(synopsis "Flexible I/O tester")
|
|
|
|
(description
|
|
|
|
"fio is a tool that will spawn a number of threads or processes doing a
|
|
|
|
particular type of I/O action as specified by the user. The typical use of fio
|
|
|
|
is to write a job file matching the I/O load one wants to simulate.")
|
|
|
|
;; The software is distributed under the GPL2, but a handful of components
|
|
|
|
;; are covered by other licenses.
|
|
|
|
(license (list license:gpl2 license:gpl2+ license:bsd-2
|
|
|
|
license:public-domain))))
|
2017-10-03 14:14:50 -04:00
|
|
|
|
|
|
|
;; Parameterized in anticipation of m(va)pich support
|
2019-12-20 16:35:12 -05:00
|
|
|
(define (intel-mpi-benchmarks mpi)
|
2017-10-03 14:14:50 -04:00
|
|
|
(package
|
2019-12-20 16:35:12 -05:00
|
|
|
(name (string-append "intel-mpi-benchmarks"
|
|
|
|
(if (string=? (package-name mpi) "openmpi")
|
|
|
|
""
|
|
|
|
(string-append "-" (package-name mpi)))))
|
2020-12-20 08:19:04 -05:00
|
|
|
(version "2019.6")
|
2019-12-20 16:35:12 -05:00
|
|
|
(source (origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
gnu: Remove ".git" from "https://github/…/….git".
Until now, 'lookup-origin' and thus 'lookup-origin-revision' in (guix
swh) would sometimes return #f for these because the ".git" URLs are
redirects to the non-".git" URLs. Consequently, 'guix lint -c archival'
would keep saying "scheduled Software Heritage archival"; likewise, the
fallback download code would fail.
* gnu/packages/ada.scm,
gnu/packages/admin.scm,
gnu/packages/aidc.scm,
gnu/packages/algebra.scm,
gnu/packages/android.scm,
gnu/packages/animation.scm,
gnu/packages/arcan.scm,
gnu/packages/assembly.scm,
gnu/packages/audio.scm,
gnu/packages/authentication.scm,
gnu/packages/avr.scm,
gnu/packages/axoloti.scm,
gnu/packages/backup.scm,
gnu/packages/bash.scm,
gnu/packages/benchmark.scm,
gnu/packages/bioconductor.scm,
gnu/packages/bioinformatics.scm,
gnu/packages/bittorrent.scm,
gnu/packages/boost.scm,
gnu/packages/build-tools.scm,
gnu/packages/c.scm,
gnu/packages/calendar.scm,
gnu/packages/cdrom.scm,
gnu/packages/check.scm,
gnu/packages/chemistry.scm,
gnu/packages/chez.scm,
gnu/packages/clojure.scm,
gnu/packages/code.scm,
gnu/packages/compression.scm,
gnu/packages/compton.scm,
gnu/packages/coq.scm,
gnu/packages/cpp.scm,
gnu/packages/cran.scm,
gnu/packages/crypto.scm,
gnu/packages/curl.scm,
gnu/packages/databases.scm,
gnu/packages/datastructures.scm,
gnu/packages/debug.scm,
gnu/packages/disk.scm,
gnu/packages/distributed.scm,
gnu/packages/django.scm,
gnu/packages/dlang.scm,
gnu/packages/dns.scm,
gnu/packages/docker.scm,
gnu/packages/education.scm,
gnu/packages/efi.scm,
gnu/packages/elixir.scm,
gnu/packages/emacs-xyz.scm,
gnu/packages/embedded.scm,
gnu/packages/emulators.scm,
gnu/packages/engineering.scm,
gnu/packages/erlang.scm,
gnu/packages/fabric-management.scm,
gnu/packages/file-systems.scm,
gnu/packages/finance.scm,
gnu/packages/firmware.scm,
gnu/packages/flashing-tools.scm,
gnu/packages/fonts.scm,
gnu/packages/fontutils.scm,
gnu/packages/fpga.scm,
gnu/packages/game-development.scm,
gnu/packages/games.scm,
gnu/packages/genealogy.scm,
gnu/packages/genimage.scm,
gnu/packages/geo.scm,
gnu/packages/gimp.scm,
gnu/packages/gl.scm,
gnu/packages/gnome-xyz.scm,
gnu/packages/gnome.scm,
gnu/packages/gnuzilla.scm,
gnu/packages/golang.scm,
gnu/packages/gpodder.scm,
gnu/packages/graph.scm,
gnu/packages/graphics.scm,
gnu/packages/graphviz.scm,
gnu/packages/groff.scm,
gnu/packages/groovy.scm,
gnu/packages/gtk.scm,
gnu/packages/guile-xyz.scm,
gnu/packages/guile.scm,
gnu/packages/hardware.scm,
gnu/packages/haskell-apps.scm,
gnu/packages/haskell-xyz.scm,
gnu/packages/hexedit.scm,
gnu/packages/i2p.scm,
gnu/packages/ibus.scm,
gnu/packages/image-processing.scm,
gnu/packages/image-viewers.scm,
gnu/packages/image.scm,
gnu/packages/ipfs.scm,
gnu/packages/java-graphics.scm,
gnu/packages/java-maths.scm,
gnu/packages/java.scm,
gnu/packages/javascript.scm,
gnu/packages/jrnl.scm,
gnu/packages/julia.scm,
gnu/packages/jupyter.scm,
gnu/packages/kodi.scm,
gnu/packages/language.scm,
gnu/packages/lego.scm,
gnu/packages/less.scm,
gnu/packages/libusb.scm,
gnu/packages/linux.scm,
gnu/packages/lirc.scm,
gnu/packages/lisp-xyz.scm,
gnu/packages/llvm.scm,
gnu/packages/logging.scm,
gnu/packages/lolcode.scm,
gnu/packages/lua.scm,
gnu/packages/lxde.scm,
gnu/packages/lxqt.scm,
gnu/packages/machine-learning.scm,
gnu/packages/mail.scm,
gnu/packages/markup.scm,
gnu/packages/maths.scm,
gnu/packages/maven.scm,
gnu/packages/mes.scm,
gnu/packages/messaging.scm,
gnu/packages/monitoring.scm,
gnu/packages/mpd.scm,
gnu/packages/music.scm,
gnu/packages/networking.scm,
gnu/packages/node-xyz.scm,
gnu/packages/ocaml.scm,
gnu/packages/ocr.scm,
gnu/packages/onc-rpc.scm,
gnu/packages/opencl.scm,
gnu/packages/opencog.scm,
gnu/packages/pantheon.scm,
gnu/packages/password-utils.scm,
gnu/packages/patchutils.scm,
gnu/packages/pdf.scm,
gnu/packages/perl6.scm,
gnu/packages/phabricator.scm,
gnu/packages/popt.scm,
gnu/packages/printers.scm,
gnu/packages/prolog.scm,
gnu/packages/protobuf.scm,
gnu/packages/pulseaudio.scm,
gnu/packages/python-crypto.scm,
gnu/packages/python-web.scm,
gnu/packages/python-xyz.scm,
gnu/packages/qt.scm,
gnu/packages/radio.scm,
gnu/packages/rails.scm,
gnu/packages/rdf.scm,
gnu/packages/rednotebook.scm,
gnu/packages/rpc.scm,
gnu/packages/rsync.scm,
gnu/packages/ruby.scm,
gnu/packages/rust.scm,
gnu/packages/scheme.scm,
gnu/packages/screen.scm,
gnu/packages/security-token.scm,
gnu/packages/selinux.scm,
gnu/packages/serialization.scm,
gnu/packages/shells.scm,
gnu/packages/shellutils.scm,
gnu/packages/simh.scm,
gnu/packages/sml.scm,
gnu/packages/ssh.scm,
gnu/packages/statistics.scm,
gnu/packages/stenography.scm,
gnu/packages/sync.scm,
gnu/packages/syncthing.scm,
gnu/packages/synergy.scm,
gnu/packages/telephony.scm,
gnu/packages/terminals.scm,
gnu/packages/tex.scm,
gnu/packages/texinfo.scm,
gnu/packages/text-editors.scm,
gnu/packages/textutils.scm,
gnu/packages/time.scm,
gnu/packages/tmux.scm,
gnu/packages/tor.scm,
gnu/packages/toys.scm,
gnu/packages/version-control.scm,
gnu/packages/video.scm,
gnu/packages/vim.scm,
gnu/packages/virtualization.scm,
gnu/packages/vlang.scm,
gnu/packages/vnc.scm,
gnu/packages/vpn.scm,
gnu/packages/web-browsers.scm,
gnu/packages/web.scm,
gnu/packages/wireservice.scm,
gnu/packages/wm.scm,
gnu/packages/wxwidgets.scm,
gnu/packages/xdisorg.scm,
gnu/packages/xml.scm,
gnu/packages/xorg.scm,
tests/lint.scm: Remove trailing ".git" from 'git-reference' URL.
2020-07-12 16:53:28 -04:00
|
|
|
(url "https://github.com/intel/mpi-benchmarks")
|
2019-12-20 16:35:12 -05:00
|
|
|
(commit (string-append "IMB-v" version))))
|
|
|
|
(file-name (git-file-name name version))
|
|
|
|
(sha256
|
|
|
|
(base32
|
2020-12-20 08:19:04 -05:00
|
|
|
"02hxbk9g9nl59bk5qcfl3djj7b58vsqys340m1xdbyqwcrbnahh9"))
|
|
|
|
(modules '((guix build utils)))
|
|
|
|
(snippet
|
|
|
|
'(begin
|
|
|
|
;; Some source configuration files in the original tarball
|
|
|
|
;; have inappropriate execute permissions, which interferes
|
|
|
|
;; with the install phase below.
|
|
|
|
(for-each (lambda (file) (chmod file #o444))
|
|
|
|
(find-files "WINDOWS" "."))
|
|
|
|
#t))))
|
2017-10-03 14:14:50 -04:00
|
|
|
(build-system gnu-build-system)
|
|
|
|
(inputs
|
|
|
|
`(("mpi" ,mpi)))
|
|
|
|
(arguments
|
|
|
|
`(#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(delete 'configure)
|
|
|
|
(delete 'check)
|
|
|
|
(replace 'install
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
2019-12-20 16:35:12 -05:00
|
|
|
(define (benchmark? file stat)
|
|
|
|
(and (string-prefix? "IMB-" (basename file))
|
|
|
|
(executable-file? file)))
|
|
|
|
|
2017-10-03 14:14:50 -04:00
|
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
|
|
(bin (string-append out "/bin")))
|
2019-12-20 16:35:12 -05:00
|
|
|
(for-each (lambda (file)
|
|
|
|
(install-file file bin))
|
|
|
|
(find-files "." benchmark?))
|
|
|
|
#t))))
|
|
|
|
|
|
|
|
;; The makefile doesn't express all the dependencies, it seems.
|
|
|
|
#:parallel-build? #t
|
|
|
|
|
|
|
|
#:make-flags '("CC=mpicc" "CXX=mpicxx")))
|
2017-10-03 14:14:50 -04:00
|
|
|
(home-page "https://software.intel.com/en-us/articles/intel-mpi-benchmarks")
|
2019-12-20 16:35:12 -05:00
|
|
|
(synopsis "Benchmarks for the Message Passing Interface (MPI)")
|
2017-10-03 14:14:50 -04:00
|
|
|
(description
|
|
|
|
"This package provides benchmarks for implementations of the @dfn{Message
|
|
|
|
Passing Interface} (MPI). It contains MPI performance measurements for
|
|
|
|
point-to-point and global communication, and file, operations for a range of
|
|
|
|
message sizes. The generated benchmark data fully characterize:
|
|
|
|
|
|
|
|
@itemize
|
|
|
|
@item
|
|
|
|
Performance of a cluster system, including node performance, network latency,
|
|
|
|
and throughput;
|
|
|
|
@item
|
|
|
|
Efficiency of the MPI implementation.
|
|
|
|
@end itemize")
|
|
|
|
(license license:cpl1.0)))
|
|
|
|
|
2019-12-20 16:35:12 -05:00
|
|
|
(define-public intel-mpi-benchmarks/openmpi
|
|
|
|
(intel-mpi-benchmarks openmpi))
|
|
|
|
|
|
|
|
(define-public imb-openmpi
|
|
|
|
(deprecated-package "imb-openmpi" intel-mpi-benchmarks/openmpi))
|
2019-03-06 15:55:14 -05:00
|
|
|
|
|
|
|
(define-public multitime
|
|
|
|
(package
|
|
|
|
(name "multitime")
|
|
|
|
(version "1.4")
|
|
|
|
(source (origin
|
|
|
|
(method url-fetch)
|
|
|
|
(uri (string-append "https://tratt.net/laurie/src/"
|
|
|
|
"multitime/releases/"
|
|
|
|
"multitime-" version ".tar.gz"))
|
|
|
|
(sha256
|
|
|
|
(base32
|
|
|
|
"0iyfsdrbyqa7a4ifrh19l9a48hgv7ld6m0d8yf9bkl12q0qw91fx"))))
|
|
|
|
(build-system gnu-build-system)
|
|
|
|
(arguments '(#:tests? #f)) ; there are no tests
|
|
|
|
(home-page "https://tratt.net/laurie/src/multitime/")
|
|
|
|
(synopsis "Time command execution over multiple executions")
|
|
|
|
(description
|
|
|
|
"The @code{time} utility is a simple and often effective way of measuring
|
|
|
|
how long a command takes to run (wall time). Unfortunately, running a command
|
|
|
|
once can give misleading timings. @code{multitime} is, in essence, a simple
|
|
|
|
extension to @code{time} which runs a command multiple times and prints the
|
|
|
|
timing means, standard deviations, mins, medians, and maxes having done so.
|
|
|
|
This can give a much better understanding of the command's performance.")
|
|
|
|
(license license:expat)))
|
2019-06-14 17:07:56 -04:00
|
|
|
|
|
|
|
(define-public benchmark
|
|
|
|
(package
|
|
|
|
(name "benchmark")
|
2020-10-23 09:11:52 -04:00
|
|
|
(version "1.5.2")
|
2019-06-14 17:07:56 -04:00
|
|
|
(source (origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
gnu: Remove ".git" from "https://github/…/….git".
Until now, 'lookup-origin' and thus 'lookup-origin-revision' in (guix
swh) would sometimes return #f for these because the ".git" URLs are
redirects to the non-".git" URLs. Consequently, 'guix lint -c archival'
would keep saying "scheduled Software Heritage archival"; likewise, the
fallback download code would fail.
* gnu/packages/ada.scm,
gnu/packages/admin.scm,
gnu/packages/aidc.scm,
gnu/packages/algebra.scm,
gnu/packages/android.scm,
gnu/packages/animation.scm,
gnu/packages/arcan.scm,
gnu/packages/assembly.scm,
gnu/packages/audio.scm,
gnu/packages/authentication.scm,
gnu/packages/avr.scm,
gnu/packages/axoloti.scm,
gnu/packages/backup.scm,
gnu/packages/bash.scm,
gnu/packages/benchmark.scm,
gnu/packages/bioconductor.scm,
gnu/packages/bioinformatics.scm,
gnu/packages/bittorrent.scm,
gnu/packages/boost.scm,
gnu/packages/build-tools.scm,
gnu/packages/c.scm,
gnu/packages/calendar.scm,
gnu/packages/cdrom.scm,
gnu/packages/check.scm,
gnu/packages/chemistry.scm,
gnu/packages/chez.scm,
gnu/packages/clojure.scm,
gnu/packages/code.scm,
gnu/packages/compression.scm,
gnu/packages/compton.scm,
gnu/packages/coq.scm,
gnu/packages/cpp.scm,
gnu/packages/cran.scm,
gnu/packages/crypto.scm,
gnu/packages/curl.scm,
gnu/packages/databases.scm,
gnu/packages/datastructures.scm,
gnu/packages/debug.scm,
gnu/packages/disk.scm,
gnu/packages/distributed.scm,
gnu/packages/django.scm,
gnu/packages/dlang.scm,
gnu/packages/dns.scm,
gnu/packages/docker.scm,
gnu/packages/education.scm,
gnu/packages/efi.scm,
gnu/packages/elixir.scm,
gnu/packages/emacs-xyz.scm,
gnu/packages/embedded.scm,
gnu/packages/emulators.scm,
gnu/packages/engineering.scm,
gnu/packages/erlang.scm,
gnu/packages/fabric-management.scm,
gnu/packages/file-systems.scm,
gnu/packages/finance.scm,
gnu/packages/firmware.scm,
gnu/packages/flashing-tools.scm,
gnu/packages/fonts.scm,
gnu/packages/fontutils.scm,
gnu/packages/fpga.scm,
gnu/packages/game-development.scm,
gnu/packages/games.scm,
gnu/packages/genealogy.scm,
gnu/packages/genimage.scm,
gnu/packages/geo.scm,
gnu/packages/gimp.scm,
gnu/packages/gl.scm,
gnu/packages/gnome-xyz.scm,
gnu/packages/gnome.scm,
gnu/packages/gnuzilla.scm,
gnu/packages/golang.scm,
gnu/packages/gpodder.scm,
gnu/packages/graph.scm,
gnu/packages/graphics.scm,
gnu/packages/graphviz.scm,
gnu/packages/groff.scm,
gnu/packages/groovy.scm,
gnu/packages/gtk.scm,
gnu/packages/guile-xyz.scm,
gnu/packages/guile.scm,
gnu/packages/hardware.scm,
gnu/packages/haskell-apps.scm,
gnu/packages/haskell-xyz.scm,
gnu/packages/hexedit.scm,
gnu/packages/i2p.scm,
gnu/packages/ibus.scm,
gnu/packages/image-processing.scm,
gnu/packages/image-viewers.scm,
gnu/packages/image.scm,
gnu/packages/ipfs.scm,
gnu/packages/java-graphics.scm,
gnu/packages/java-maths.scm,
gnu/packages/java.scm,
gnu/packages/javascript.scm,
gnu/packages/jrnl.scm,
gnu/packages/julia.scm,
gnu/packages/jupyter.scm,
gnu/packages/kodi.scm,
gnu/packages/language.scm,
gnu/packages/lego.scm,
gnu/packages/less.scm,
gnu/packages/libusb.scm,
gnu/packages/linux.scm,
gnu/packages/lirc.scm,
gnu/packages/lisp-xyz.scm,
gnu/packages/llvm.scm,
gnu/packages/logging.scm,
gnu/packages/lolcode.scm,
gnu/packages/lua.scm,
gnu/packages/lxde.scm,
gnu/packages/lxqt.scm,
gnu/packages/machine-learning.scm,
gnu/packages/mail.scm,
gnu/packages/markup.scm,
gnu/packages/maths.scm,
gnu/packages/maven.scm,
gnu/packages/mes.scm,
gnu/packages/messaging.scm,
gnu/packages/monitoring.scm,
gnu/packages/mpd.scm,
gnu/packages/music.scm,
gnu/packages/networking.scm,
gnu/packages/node-xyz.scm,
gnu/packages/ocaml.scm,
gnu/packages/ocr.scm,
gnu/packages/onc-rpc.scm,
gnu/packages/opencl.scm,
gnu/packages/opencog.scm,
gnu/packages/pantheon.scm,
gnu/packages/password-utils.scm,
gnu/packages/patchutils.scm,
gnu/packages/pdf.scm,
gnu/packages/perl6.scm,
gnu/packages/phabricator.scm,
gnu/packages/popt.scm,
gnu/packages/printers.scm,
gnu/packages/prolog.scm,
gnu/packages/protobuf.scm,
gnu/packages/pulseaudio.scm,
gnu/packages/python-crypto.scm,
gnu/packages/python-web.scm,
gnu/packages/python-xyz.scm,
gnu/packages/qt.scm,
gnu/packages/radio.scm,
gnu/packages/rails.scm,
gnu/packages/rdf.scm,
gnu/packages/rednotebook.scm,
gnu/packages/rpc.scm,
gnu/packages/rsync.scm,
gnu/packages/ruby.scm,
gnu/packages/rust.scm,
gnu/packages/scheme.scm,
gnu/packages/screen.scm,
gnu/packages/security-token.scm,
gnu/packages/selinux.scm,
gnu/packages/serialization.scm,
gnu/packages/shells.scm,
gnu/packages/shellutils.scm,
gnu/packages/simh.scm,
gnu/packages/sml.scm,
gnu/packages/ssh.scm,
gnu/packages/statistics.scm,
gnu/packages/stenography.scm,
gnu/packages/sync.scm,
gnu/packages/syncthing.scm,
gnu/packages/synergy.scm,
gnu/packages/telephony.scm,
gnu/packages/terminals.scm,
gnu/packages/tex.scm,
gnu/packages/texinfo.scm,
gnu/packages/text-editors.scm,
gnu/packages/textutils.scm,
gnu/packages/time.scm,
gnu/packages/tmux.scm,
gnu/packages/tor.scm,
gnu/packages/toys.scm,
gnu/packages/version-control.scm,
gnu/packages/video.scm,
gnu/packages/vim.scm,
gnu/packages/virtualization.scm,
gnu/packages/vlang.scm,
gnu/packages/vnc.scm,
gnu/packages/vpn.scm,
gnu/packages/web-browsers.scm,
gnu/packages/web.scm,
gnu/packages/wireservice.scm,
gnu/packages/wm.scm,
gnu/packages/wxwidgets.scm,
gnu/packages/xdisorg.scm,
gnu/packages/xml.scm,
gnu/packages/xorg.scm,
tests/lint.scm: Remove trailing ".git" from 'git-reference' URL.
2020-07-12 16:53:28 -04:00
|
|
|
(url "https://github.com/google/benchmark")
|
2019-06-14 17:07:56 -04:00
|
|
|
(commit (string-append "v" version))))
|
|
|
|
(file-name (git-file-name name version))
|
|
|
|
(sha256
|
|
|
|
(base32
|
2020-10-23 09:11:52 -04:00
|
|
|
"13rxagpzw6bal6ajlmrxlh9kgfvcixn6j734b2bvfqz7lch8n0pa"))))
|
2019-06-14 17:07:56 -04:00
|
|
|
(build-system cmake-build-system)
|
|
|
|
(native-inputs
|
2020-10-23 09:11:52 -04:00
|
|
|
`(("googletest-source" ,(package-source googletest))
|
|
|
|
("googletest" ,googletest)))
|
|
|
|
(arguments
|
|
|
|
`(#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(add-after 'unpack 'unpack-googletest
|
|
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
|
|
(copy-recursively (assoc-ref inputs "googletest-source")
|
|
|
|
"googletest")
|
|
|
|
#t)))))
|
2019-06-14 17:07:56 -04:00
|
|
|
(home-page "https://github.com/google/benchmark")
|
|
|
|
(synopsis "Microbenchmark support library")
|
|
|
|
(description
|
2020-10-23 09:11:52 -04:00
|
|
|
"Benchmark is a library to benchmark code snippets, similar to unit
|
|
|
|
tests.")
|
2019-06-14 17:07:56 -04:00
|
|
|
(license license:asl2.0)))
|
2020-02-21 18:37:23 -05:00
|
|
|
|
|
|
|
(define-public bonnie++
|
|
|
|
(package
|
|
|
|
(name "bonnie++")
|
|
|
|
(version "1.98")
|
|
|
|
(source (origin
|
|
|
|
(method url-fetch)
|
|
|
|
(uri (string-append "https://www.coker.com.au/bonnie++/bonnie++-"
|
|
|
|
version ".tgz"))
|
|
|
|
(sha256
|
|
|
|
(base32
|
|
|
|
"010bmlmi0nrlp3aq7p624sfaj5a65lswnyyxk3cnz1bqig0cn2vf"))))
|
|
|
|
(build-system gnu-build-system)
|
|
|
|
(native-inputs
|
|
|
|
`(("perl" ,perl)))
|
|
|
|
(arguments '(#:tests? #f)) ; there are no tests
|
|
|
|
(home-page "https://doc.coker.com.au/projects/bonnie/")
|
|
|
|
(synopsis "Hard drive and file system benchmark suite")
|
|
|
|
(description
|
|
|
|
"Bonnie++ is a benchmark suite that is aimed at performing a number of
|
|
|
|
simple tests of hard drive and file system performance. Bonnie++ allows you to
|
|
|
|
benchmark how your file systems perform with respect to data read and write
|
|
|
|
speed, the number of seeks that can be performed per second, and the number of
|
|
|
|
file metadata operations that can be performed per second.")
|
|
|
|
(license license:gpl2))) ;GPL 2 only, see copyright.txt
|
2020-11-18 11:11:44 -05:00
|
|
|
|
|
|
|
(define-public python-locust
|
|
|
|
(package
|
|
|
|
(name "python-locust")
|
2021-02-18 08:28:57 -05:00
|
|
|
(version "1.4.3")
|
2020-11-18 11:11:44 -05:00
|
|
|
(source
|
|
|
|
(origin
|
|
|
|
(method url-fetch)
|
|
|
|
(uri (pypi-uri "locust" version))
|
|
|
|
(sha256
|
|
|
|
(base32
|
2021-02-18 08:28:57 -05:00
|
|
|
"0vmw151xcaznd2j85n96iyv9fniss0bkk91xn4maw2gwzym424xk"))))
|
2020-11-18 11:11:44 -05:00
|
|
|
(build-system python-build-system)
|
|
|
|
(arguments
|
|
|
|
`(#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(add-before 'check 'extend-PATH
|
|
|
|
;; Add the 'locust' script to PATH, which is used in the test
|
|
|
|
;; suite.
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
(let ((out (assoc-ref outputs "out")))
|
|
|
|
(setenv "PATH" (string-append out "/bin:"
|
2021-02-18 08:28:57 -05:00
|
|
|
(getenv "PATH"))))))
|
2020-11-18 11:11:44 -05:00
|
|
|
(replace 'check
|
|
|
|
(lambda _
|
|
|
|
(invoke "python" "-m" "pytest"
|
|
|
|
"-k" (string-join
|
|
|
|
(list
|
|
|
|
;; These tests return "non-zero exit status 1".
|
|
|
|
"not test_default_headless_spawn_options"
|
|
|
|
"not test_default_headless_spawn_options_with_shape"
|
|
|
|
"not test_headless_spawn_options_wo_run_time"
|
2021-02-18 08:28:57 -05:00
|
|
|
;; These tests depend on networking.
|
|
|
|
"not test_html_report_option"
|
2020-11-18 11:11:44 -05:00
|
|
|
"not test_web_options"
|
|
|
|
;; This test fails because of the warning "System open
|
|
|
|
;; file limit '1024' is below minimum setting '10000'".
|
2021-02-18 08:28:57 -05:00
|
|
|
"not test_skip_logging"
|
|
|
|
;; On some (slow?) machines, the following tests
|
|
|
|
;; fail, with the processes returning exit code
|
|
|
|
;; -15 instead of the expected 42 and 0,
|
|
|
|
;; respectively (see:
|
|
|
|
;; https://github.com/locustio/locust/issues/1708).
|
|
|
|
"not test_custom_exit_code"
|
|
|
|
"not test_webserver") " and ")))))))
|
2020-11-18 11:11:44 -05:00
|
|
|
(propagated-inputs
|
|
|
|
`(("python-configargparse" ,python-configargparse)
|
|
|
|
("python-flask" ,python-flask)
|
|
|
|
("python-flask-basicauth" ,python-flask-basicauth)
|
|
|
|
("python-gevent" ,python-gevent)
|
|
|
|
("python-geventhttpclient" ,python-geventhttpclient)
|
|
|
|
("python-msgpack" ,python-msgpack)
|
|
|
|
("python-psutil" ,python-psutil)
|
|
|
|
("python-pyzmq" ,python-pyzmq)
|
|
|
|
("python-requests" ,python-requests)
|
|
|
|
("python-werkzeug" ,python-werkzeug)))
|
|
|
|
(native-inputs
|
|
|
|
`(("python-mock" ,python-mock)
|
|
|
|
("python-pyquery" ,python-pyquery)
|
|
|
|
("python-pytest" ,python-pytest))) ;for more easily skipping tests
|
|
|
|
(home-page "https://locust.io/")
|
|
|
|
(synopsis "Distributed load testing framework")
|
|
|
|
(description "Locust is a performance testing tool that aims to be easy to
|
|
|
|
use, scriptable and scalable. The test scenarios are described in plain
|
|
|
|
Python. It provides a web-based user interface to visualize the results in
|
|
|
|
real-time, but can also be run non-interactively. Locust is primarily geared
|
|
|
|
toward testing HTTP-based applications or services, but it can be customized to
|
2021-02-18 08:28:57 -05:00
|
|
|
test any system or protocol.
|
|
|
|
|
|
|
|
Note: Locust will complain if the available open file descriptors limit for
|
|
|
|
the user is too low. To raise such limit on a Guix System, refer to
|
|
|
|
@samp{info guix --index-search=pam-limits-service}.")
|
2020-11-18 11:11:44 -05:00
|
|
|
(license license:expat)))
|