Gymbo
|
Represents a derived class for symbolic execution engine for probabilistic programs. More...
#include <psymbolic.h>
Public Member Functions | |
void | register_random_var (int var_id) |
bool | solve (bool is_target, int pc, SymState &state) |
Solves path constraints and updates the symbolic state. More... | |
Trace | run (Prog &prog, std::unordered_set< int > &target_pcs, SymState &state, int maxDepth=256) |
Run probabilistic symbolic execution on a program. More... | |
BaseExecutor (GDOptimizer optimizer, int maxSAT=256, int maxUNSAT=256, int max_num_trials=10, bool ignore_memory=false, bool use_dpll=false, int verbose_level=0, bool return_trace=false) | |
Constructor for BaseExecutor. More... | |
![]() | |
BaseExecutor (GDOptimizer optimizer, int maxSAT=256, int maxUNSAT=256, int max_num_trials=10, bool ignore_memory=false, bool use_dpll=false, int verbose_level=0, bool return_trace=false) | |
Constructor for BaseExecutor. More... | |
Public Attributes | |
std::unordered_set< int > | random_vars |
Set of random variables'IDs. More... | |
PathConstraintsTable | constraints_cache |
Cache for storing and reusing path constraints. More... | |
ProbPathConstraintsTable | prob_constraints_table |
![]() | |
GDOptimizer | optimizer |
int | maxSAT |
The maximum number of SAT constraints to collect. More... | |
int | maxUNSAT |
The maximum number of UNSAT constraints to collect. More... | |
int | max_num_trials |
int | verbose_level |
The level of verbosity. More... | |
bool | ignore_memory |
bool | use_dpll |
bool | return_trace |
Represents a derived class for symbolic execution engine for probabilistic programs.
|
inline |
Constructor for BaseExecutor.
optimizer | The gradient descent optimizer for parameter optimization. |
maxSAT | The maximum number of SAT constraints to collect. |
maxUNSAT | The maximum number of UNSAT constraints to collect. |
max_num_trials | The maximum number of trials for each gradient descent. |
ignore_memory | If set to true, constraints derived from memory will be ignored. |
use_dpll | If set to true, use DPLL to decide the initial assignment for each term. |
verbose_level | The level of verbosity. |
return_trace | If set to true, save the trace at each pc and return them (default false). |
|
inline |
|
inlinevirtual |
Run probabilistic symbolic execution on a program.
This function performs probabilistic symbolic execution on a given program, considering variable distributions, symbolic states, and path constraints. It explores different execution paths and updates the constraints and probabilities accordingly.
prog | The program to symbolically execute. |
target_pcs | Set of pc where gymbo executes path-constraints solving. If this set is empty or contains -1, gymbo solves all path-constraints. |
state | The initial symbolic state for execution. |
maxDepth | Maximum exploration depth during symbolic execution. |
Implements gymbo::BaseExecutor.
|
inlinevirtual |
Solves path constraints and updates the symbolic state.
This function checks the satisfiability of the path constraints using an SMT solver or a probabilistic branching algorithm. It updates the symbolic state based on the result and stores the solution in a cache for future use.
is_target | Whether the program counter is a target. |
pc | The program counter. |
state | The symbolic state. |
Implements gymbo::BaseExecutor.
PathConstraintsTable gymbo::PSExecutor::constraints_cache |
Cache for storing and reusing path constraints.
ProbPathConstraintsTable gymbo::PSExecutor::prob_constraints_table |
Table for storing probabilistic path constraints.
std::unordered_set<int> gymbo::PSExecutor::random_vars |
Set of random variables'IDs.