Skip to content

Latest commit

 

History

History
408 lines (286 loc) · 16 KB

File metadata and controls

408 lines (286 loc) · 16 KB

Exploring and Evaluating Interplays of BPpy with Deep Reinforcement Learning and Formal Methods

  • To run the artifact we used:
    • macOS 11.7.5
    • Intel(R) Core(TM) i7-9750H CPU @ 2.60GHz
    • memory: 16 GB
    • disk: 256 GB

Installation and Usage

The artifact contains all experiments presented in the paper.

To run all experiments, the first step is to pull the docker image from dockerhub:

docker pull annonymouswriter/bp-evaluation:latest

and then run it:

docker run -it annonymouswriter/bp-evaluation:latest

When running the container, the current directory will be BPpyEvaluation.

Inside the BPpyEvaluation directory there are separate directories for each experiment discussed in the paper, as elaborated below.

Experiments

SMT solvers (Section 3)

(The experiments presented in the paper used an Intel(R) Xeon(R) CPU X5550)

The code for running the SMT solvers experiments (Section 3) is in the smt_solvers directory:

cd smt_solvers

Cinderella-Stepmother problem

The cinderella_experiments.py file accepts the parameters:

  • n - the number of buckets.
  • c - the number of adjacent buckets Cinderella empties.
  • b - The maximum number of water units a bucket can contain.
  • a - The number of water units the stepmother pours into the buckets
  • n_e - the number of times to repeat the experiment.

For instance, for a scaled down evaluation of the experiment execute the cinderella_experiments.py program with the following parameters:

python3 cinderella_experiments.py -n 5 -c 2 -b 10 -n_e 3

To repeat the experiment presented in Figure 2(a), execute the cinderella_experiments.py script with the following parameters (this may take few hours and may require additional resources):

python3 cinderella_experiments.py -n 5 -c 2 -b 25 -n_e 10

The script outputs a table with the results presented in Figure 2(a).

Bit-Flip problem

The bit_flipping_experiments.py file accepts the parameters:

  • n - maximal number of rows
  • m - maximal number of columns
  • n_e - The number of times to run the experiment

For instance, a scaled down evaluation of the experiment presented in Figure 2, execute the bit_flipping_experiments.py program with the following parameters:

python3 bit_flipping_experiments.py -n 3 -m 4 -n_e 5

To repeat the full experiment presented in Figure 2(b), execute the bit_flipping_experiments.py program with the following parameters (this may take few hours and may require additional resources):

python3 bit_flipping_experiments.py -n 4 -m 5 -n_e 10

The script outputs a table with the results presented in Figure 2.

Circled Polygon problem

The z3_circle_examples.py file accepts the parameters:

  • n_0 - the initial number of edges to start the experiment.
  • n_m - the final number of edges to finish the experiment.
  • n_e - the number of times to repeat the experiment.

For example, running a scaled-down evaluation of the circled-polygon experiment:

python3 z3_circle_examples.py -n_0 4 -n_m 10 -n_e 20

To repeat the experiment presented in Figure 2(c), execute the z3_circle_examples.py program with the following parameters(this may take few hours and may require additional resources):

python3 z3_circle_examples.py -n_0 4 -n_m 200 -n_e 30

The script outputs a table with the results presented in Figure 4.

Symbolic Model Checking (Section 4)

(The experiment presented in the paper used an Intel Xeon E5-2620 CPU with 16GB allocated RAM and a timeout value set to 60 minutes)

The code for running the symbolic model checking experiments (Section 4) are in the model_checking directory:

cd model_checking

The folder contains two subfolders: BPpyModelChecker for the BPpy's symbolic model checker experiments and BPjsModelChecking for running BPjs's model checker.

BPpy's Symbolic Model Checker

cd BPpyModelChecker

The main.py file accepts the following parameters:

  • example - one of: hot_cold2,dining_philosophers2,ttt2
  • two problem parameters - n and m
  • bounded mc - 1 for true and 0 otherwise

For example, running unbounded symbolic model checking for the hot cold example with n=30 and m=1:

python3 main.py hot_cold2 30 1 0

and running bounded symbolic model checking for the dining philosophers example with n=3:

python3 main.py dining_philosophers2 3 1 1

The data in Table 1 concerning BPpy can be obtained by running the following scripts using the bash command (this may take multiple days and may require additional resources):

  • scripts/bounded.sh - the script will create a csv file run_all_bppy_bounded_output.csv with the results of the time and memory of BPpy's bounded model checking.
  • scripts/unbounded.sh - the script will create a csv file run_all_bppy_unbounded_output.csv with the results of the time and memory of BPpy's unbounded model checking.

BPjs's Model Checker

cd BPjsModelChecking

Running the examples above using BPjs's model checker:

mvn exec:java -Dexec.args="hot_cold 30 1 true false"
mvn exec:java -Dexec.args="dining_philosophers 3 true true"

The data in Table 1 concerning BPjs can be obtained by running the following scripts using the bash command (this may take multiple days and may require additional resources):

  • scripts/bounded.sh - the script will create a csv file run_all_bpjs_bounded_output.csv with the results of the time and memory of BPjs's bounded model checking.
  • scripts/unbounded.sh - the script will create a csv file run_all_bpjs_unbounded_output.csv with the results of the time and memory of BPjs's unbounded model checking.

Probabilistic Model Checking (Section 5)

(The experiment presented in the paper used an Intel Xeon E5-2620 CPU)

The code for running the probabilistic model checking experiments (Section 5) is in the prob_modeling directory:

cd prob_modeling

Each subdirectory contains a demonstration of the respective b-program evaluation for a given parameter range, in addition to the scripts used during the experiments (named modeling or sampling). Running the demos performs the sampling followed by model translation and verification.

Monty Hall

The code for the Monty Hall experiment is located in the monty_hall directory.

cd monty_hall

The demo must be run from within that directory.

demo.py accepts the following parameters:

  • min - the minimum number of doors
  • max - the maximum number of doors
  • --samples - the number of samples taken

For example, running the Monty Hall demo on a minimum of 3 and maximum of 4 doors, taking 10000 samples:

python3 demo.py 3 4 --samples 10000

The script outputs the sampling results to different csv files in the samples subdirectory. For instance, the results of the above command reproduce the ones shown in Figure 3(a), and are saved to samples/sample_3d1p1o.csv.

This command also produces the results for the analysis shown in Table 2 (albeit with different parameters), which are saved to translation_overview.csv.
Larger parameters inputs, as shown in the same table, may take multiple days and require additional resources. Note that since the demo script does not timeout, a scaled down evaluation can instead be achieved via the demo by running the following command (this can take few minutes):

python3 demo.py 7 7 --samples 10000

Dice Problem

The code for the dice problem experiment is located in the dice_program directory.

cd dice_program

The demo must be run from within that directory.

demo.py accepts the following parameters:

  • min - the minimum number of dice sides
  • max - the maximum number of dice sides
  • --samples - the number of samples taken

For example, running the experiment on a minimum of 6 and maximum of 30 sides, taking 10000 samples for each parameter:

python3 demo.py 6 30 --samples 10000

As in the monty hall experiment, the script outputs sampling results to different csv files in the samples subdirectory and translation evaluation to translation_overview.csv. Table 3 is the overview as generated by the example command.

Bitflip

The code for the Bitflip experiment is located in the bitflip directory.

cd bitflip

The demo.py file runs only the sampling for the given parameters, and accepts the following:

  • n - number of rows in the matrix
  • m - number of columns in the matrix
  • --samples - number of iterations to use for sampling

For example, running the experiment for a 3x3 matrix and 1000 samples:

python3 demo.py 3 3 --samples 1000

sample_all.sh reproduces a scaled down version of the comparison found in Table 4, only generating 1000 samples and timing out after 6 minutes(this may take few hours and may require additional resources):

bash sample_all.sh

Deep Reinforcement Learning (Section 6)

The code for running the deep reinforcement learning experiments (Section 6) is in the drl directory:

cd drl

Pancake example

The pancake_single_trace_drl.py file contain the experiment of finding a single valid trace using DRL (the evaluation presented in the paper used an Intel Xeon E5-2620 CPU). It accepts the parameters:

  • n - number of pancakes in the example
  • b - thickness bound
  • learning rounds for the DRL algorithm.

For example, running pancake_single_trace_drl.py for n=200, b=25:

python3 pancake_single_trace_drl.py 200 25 100000

The pancake_single_trace_search.py file contain the experiment of finding a single valid trace using search. It accepts the parameters:

  • n - number of pancakes in the example
  • b - thickness bound

For example, running pancake_single_trace_search.py for n=200, b=25 - warning - this can take few minutes

python3 pancake_single_trace_search.py 200 25

The full evaluation results presented in Table 9 can be obtained by running the following scripts using the bash command (this may take multiple days and may require additional resources):

  • scripts/single_trace_drl.sh - the script will create a csv file, run_single_trace_drl_output.csv, with the memory and time of the DRL algorithm in the table.
  • scripts/single_trace_search.sh - the script will create a csv file, run_single_trace_search_output.csv, with the memory and time of the search algorithm in the table.

The pancake_multiple_traces_drl.py file contain the experiment of finding a valid non-deterministic policy for the pancake example (the evaluation presented in the paper used an NVIDIA GeForce RTX 4090 GPU). It accepts the following parameters:

  • n - number of pancakes in the example
  • b - thickness bound
  • number of evaluated traces
  • learning rounds for the DRL algorithm
  • algorithm used - on of DQN,QRDQN

For example, running pancake_multiple_traces_drl.py for n=200, b=25 - warning - this can take few minutes

python3 pancake_multiple_traces_drl.py 200 25 500 100000 DQN

This is a reduced evaluation which outputs a table similar with the results presented in the appendix.

The full evaluation results presented in the appendix can be obtained by running the script scripts/multiple_traces.sh using the bash command (this may take multiple days and may require additional resources). The script dumps a csv file for each algorithm with a table with the results. For instance, the results of the DQN algorithm with the parameters in scripts/multiple_traces.sh will be saved to output/200251000000DQN/results.csv

Cinderella-Stepmother example

The cinderella_single_trace_drl.py file contain the experiment of finding a single valid trace using DRL (the evaluation presented in the paper used an Intel Xeon E5-2620 CPU). It accepts the parameters:

  • A - the number water units Cinderella’s stepmother distributes across the buckets in each round
  • B - capacity of each bucket
  • C - number of adjacent buckets that Cinderella empties in each round
  • N - number of buckets
  • STEPS - number of learning rounds

For example, running cinderella_single_trace_drl.py for A=5, B=50, C=2, and N=5:

python3 cinderella_single_trace_drl.py 5 50 2 5 1000000

The cinderella_single_trace_search.py file contain the experiment of finding a single valid trace using search . It accepts the parameters:

  • A - the number water units Cinderella’s stepmother distributes across the buckets in each round
  • B - capacity of each bucket
  • C - number of adjacent buckets that Cinderella empties in each round
  • N - number of buckets

For example, running cinderella_single_trace_drl.py for A=5, B=50, C=2, and N=5:

python3 cinderella_single_trace_search.py 5 50 2 5

The full evaluation results presented in the appendix "Cinderella-Stepmother Problem DRL Results" (this may take multiple days and may require additional resources): can be obtained by running the following scripts using the bash command:

  • scripts/cinderella_single_trace_drl.sh - the script will create a csv file, run_single_trace_drl_output.csv, with the memory and time of the DRL algorithm in the table.
  • scripts/cinderella_single_trace_search.sh. - the script will create a csv file, run_single_trace_search_output.csv, with the memory and time of the search algorithm in the table.

The cinderella_multiple_traces_drl.py file contain the experiment of finding a valid non-deterministic policy for the cinderella example (the evaluation presented in the paper used an NVIDIA GeForce RTX 4090 GPU). It accepts the parameters:

  • A - the number water units Cinderella’s stepmother distributes across the buckets in each round
  • B - capacity of each bucket
  • C - number of adjacent buckets that Cinderella empties in each round
  • N - number of buckets
  • number of evaluated traces
  • learning rounds for the DRL algorithm
  • algorithm used - on of DQN,QRDQN

For example, running cinderella_multiple_traces_drl.py for A=5, B=50, C=2, and N=5 - warning - this can take few minutes

python3 cinderella_multiple_traces_drl.py 5 50 2 5 1000 100000 DQN

The full evaluation results presented in the appendix "Cinderella-Stepmother Problem DRL Results" can be obtained by running the script scripts/cinderella_multiple_traces.sh using the bash command (this may take multiple days and may require additional resources). The script dumps a csv file for each algorithm with a table with the results presented in the appendix. For instance, the results of the DQN algorithm with the parameters in scripts/cinderella_multiple_traces.sh will be saved to output/550251000000DQN/results.csv

(DRL + Probabilities + SMT Solvers) (Section 7)

(the evaluation presented in the paper used an NVIDIA GeForce RTX 4090 GPU)

The code for running the experiments of Section 7 is also in the drl directory:

cd drl

The bit_flipping.py file contain the experiment presented in Section 7. It accepts the parameters:

  • N - number of matrix rows
  • M - number of matrix columns
  • learning rounds for the DRL algorithm.

For example, running bit_flipping.py for N=3, M=3 (this may take few hours and may require additional resources):

python3 bit_flipping.py 3 3 100000

The script saves the results presented in the evaluation in a csv file. For instance, the results for the command above will be saved in output/33100000/results.csv.

The full evaluation results presented in Figure 11 can be obtained by running the script scripts/bit_flip_all.sh using the bash command (this may take few hours and may require additional resources).

To compute the random and greedy baselines, run the bit_flip_random.py that accepts the parameters:

  • N - number of matrix rows
  • M - number of matrix columns
  • greedy or random (1 for greedy, 0 for random)
  • number of samples

For example (this may take few minutes):

python3 bit_flip_random.py 3 3 1 1000