Skip to content

Latest commit

 

History

History
112 lines (85 loc) · 5 KB

File metadata and controls

112 lines (85 loc) · 5 KB

Travis Build Status

Open-science experiments about Correctness Attraction

See Correctness Attraction: A Study of Stability of Software Behavior Under Runtime Perturbation (Benjamin Danglot, Philippe Preux, Benoit Baudry and Martin Monperrus), In Empirical Software Engineering, Springer Verlag, 2017.

@article{danglot2016correctness,
 title = {{Correctness Attraction: A Study of Stability of Software Behavior Under Runtime Perturbation}},
 author = {Danglot, Benjamin and Preux, Philippe and Baudry, Benoit and Monperrus, Martin},
 journal = {{Empirical Software Engineering}},
 publisher = {{Springer Verlag}},
 year = {2017},
 doi = {10.1007/s10664-017-9571-8},
}

Considered programs

  • quicksort: Quicksort without memory version.
  • zip: LZW compression.
  • md5: MD5 hash function.
  • sudoku: a Sudoku solver.
  • simplex: solver of linear program with the Simplex algorithm from math3 of Apache lib.
  • laguerre: root finder of polynomial function from math3 of Apache lib.
  • mersenne: an implementation of the Mersenne-Twister PRNG: link
  • rsa: asymmetric cryptosystem from Bouncy Castle
  • rc4: symetric key stream cipher from Bouncy Castle
  • tea: tiny encription algorithm in java, translation of this implementation
  • torrent: implementation of bittorent protocol retrieve here.
  • bitcoin: implementation of bitcoin node in java found here.
  • classifier: a Naive bayes classifier from Weka.
  • canny : edges detector : source
  • sat : SAT4J solver find here
  • lcs : longuest common subsequence, dynamic programming version.

If the source is not specified, sources come from RosettaCode

about quicksort-visualization: This package is out of the experiments because it is used to draw perturbation envelop of quicksort algorithm.

Perturbations

In order to explore it, we use 5 explorations:

  • Add 1 at each call of each perturbation Point.
  • Add N, an increasing magnitude at each call of each perturbation points.
  • Add 1 with an increasing random probability.
  • Negation of Boolean at each call of each perturbation Point.
  • Negation of Boolean with an increasing random probability.
  • Minus 1 at each call of each perturbation Point.

Run

Run the systematical call exploration with plus one perturbator model on quicksort, with 20 array of 100 integers with verbose mode:

git clone 
https://github.com/Spirals-Team/correctness-attraction-experiments.git
cd correctness-attraction-experiments
./src/script/light-install.sh

mvn exec:java -Dexec.mainClass="experiment.Main" -Dexec.args="-v -s qs -nb 20 -size 100 -exp call one"

Run the task size exploration on md5:

mvn exec:java -Dexec.mainClass="experiment.Main" -Dexec.args="-s md5 -run tasksize"

GUI

Run the gui on zip:

mvn exec:java -Dexec.mainClass="experiment.Main" -Dexec.args="-s zip -run gui"

Advanced usage

In order to install all projects, launch the following script, it will install everything you will need to run experiments but it will take a while and need at least gradle version 2.13 installed and in your path.

./src/script/install.sh
mvn exec:java -Dexec.mainClass="experiment.Main" -Dexec.args="<options>"

Options available :

  • -size <integer> specify the size of each task
  • -nb <integer> specify the number of task
  • -time <integer> specify the number of seconds to wait until timeout
  • -v or -verbose to active Runner verbose mode
  • -s <subject> to specify the subject
  • value for <subject> : qs zip rc4 laguerre tea torrent rsa sudoku bayes simplex mt md5 bc
  • -exp <exp> specify the exp
  • value for <exp> call rnd heatmap
  • for call and rnd exp you have to specify which <exploration> just after it.
  • value for <exploration> : pone mone magnitude boolean
  • you can specify an array of magnitude to be used just after the key-word magnitude
  • a list of integer separated with ":" (1:2:3 for example)
  • after the exploration, you can specify the random rates list used by rnd explorer just as for the magnitude (but with float)
  • -run tasksize tasknumber to run the exploration of the impact of the size or the number of task
  • runs will be executed before everything else, you must specify a subject (with -s) before
  • you can type -run gui to run the demo gui with success meter
  • -help display this help