File: perfHistory.md

package info (click to toggle)
vecgeom 1.2.8%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 24,016 kB
  • sloc: cpp: 88,803; ansic: 6,888; python: 1,035; sh: 582; sql: 538; makefile: 23
file content (44 lines) | stat: -rw-r--r-- 1,724 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44

Performance history
===================

Performance scripts can be used to document the evolution of performance of shape algorithms.

Instructions for the impatient
______________________________

Maybe you want to try the script/perfHistory.sh script and provide feedback?

First run it from the area where your Benchmark binaries are build. Remove all *Benchmark binaries you don't want to
run (e.g. leave the BoxBenchmark and TrapBenchmark only, if you will), then run the script (assuming that ${TOPDIR}
points to the top of your local source code/git repository):

  export TOPDIR=/path/to/VecGeom
  cd ${TOPDIR}/build
  cmake .. -DCMAKE_BUILD_TYPE=Release -DGEANT4=ON -DROOT=ON -DBACKEND=VC -DBENCHMARK=ON -D<etc...>  #.. see instructions

  make -j8                      # all benchmarks will be built, or
  make -j8 TrapezoidBenchmark   # for specific benchmarks 

  #.. You'll probably need this symlink
  ln -sf ${TOPDIR}/scripts/average.py
  source ${TOPDIR}/scripts/perfHistory.sh

This will create a subdirectory named with the first 8 characters from your "git status" commit (note that any local
source code changes will affect performance, but will not be associated with the commit name of the directory. So I
suggest to create one commit per measurement conditions, even if most commits will never make into the official
repository.

Then add the commits you want to include in your comparison plots, in the file scripts/plotEvolution.py, variable
commits (a list), and run it:

  python scripts/plotEvolution.py


Let us know if you have any problems, by filing a bug report on JIRA (https://its.cern.ch/jira/projects/VECGEOM/issues/)


For the patient
---------------

Just wait some more...  LOL :-)