mirror of
https://github.com/Z3Prover/z3
synced 2025-04-15 13:28:47 +00:00
148 lines
3.9 KiB
C++
148 lines
3.9 KiB
C++
/*++
|
|
Copyright (c) 2011 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
sat_config.h
|
|
|
|
Abstract:
|
|
|
|
SAT main configuration options.
|
|
Sub-components have their own options.
|
|
|
|
Author:
|
|
|
|
Leonardo de Moura (leonardo) 2011-05-21.
|
|
|
|
Revision History:
|
|
|
|
--*/
|
|
#ifndef SAT_CONFIG_H_
|
|
#define SAT_CONFIG_H_
|
|
|
|
#include "util/params.h"
|
|
|
|
namespace sat {
|
|
|
|
enum phase_selection {
|
|
PS_ALWAYS_TRUE,
|
|
PS_ALWAYS_FALSE,
|
|
PS_CACHING,
|
|
PS_RANDOM
|
|
};
|
|
|
|
enum restart_strategy {
|
|
RS_GEOMETRIC,
|
|
RS_LUBY
|
|
};
|
|
|
|
enum gc_strategy {
|
|
GC_DYN_PSM,
|
|
GC_PSM,
|
|
GC_GLUE,
|
|
GC_GLUE_PSM,
|
|
GC_PSM_GLUE
|
|
};
|
|
|
|
enum branching_heuristic {
|
|
BH_VSIDS,
|
|
BH_CHB,
|
|
BH_LRB
|
|
};
|
|
|
|
enum pb_solver {
|
|
PB_SOLVER,
|
|
PB_CIRCUIT,
|
|
PB_SORTING,
|
|
PB_TOTALIZER
|
|
};
|
|
|
|
enum reward_t {
|
|
ternary_reward,
|
|
unit_literal_reward,
|
|
heule_schur_reward,
|
|
heule_unit_reward,
|
|
march_cu_reward
|
|
};
|
|
|
|
struct config {
|
|
unsigned long long m_max_memory;
|
|
phase_selection m_phase;
|
|
unsigned m_phase_caching_on;
|
|
unsigned m_phase_caching_off;
|
|
restart_strategy m_restart;
|
|
unsigned m_restart_initial;
|
|
double m_restart_factor; // for geometric case
|
|
unsigned m_restart_max;
|
|
unsigned m_inprocess_max;
|
|
double m_random_freq;
|
|
unsigned m_random_seed;
|
|
unsigned m_burst_search;
|
|
unsigned m_max_conflicts;
|
|
unsigned m_num_threads;
|
|
unsigned m_local_search_threads;
|
|
bool m_local_search;
|
|
bool m_lookahead_search;
|
|
bool m_lookahead_simplify;
|
|
unsigned m_lookahead_cube_cutoff;
|
|
double m_lookahead_cube_fraction;
|
|
reward_t m_lookahead_reward;
|
|
|
|
bool m_incremental;
|
|
unsigned m_simplify_mult1;
|
|
double m_simplify_mult2;
|
|
unsigned m_simplify_max;
|
|
|
|
gc_strategy m_gc_strategy;
|
|
unsigned m_gc_initial;
|
|
unsigned m_gc_increment;
|
|
unsigned m_gc_small_lbd;
|
|
unsigned m_gc_k;
|
|
|
|
bool m_minimize_lemmas;
|
|
bool m_dyn_sub_res;
|
|
bool m_core_minimize;
|
|
bool m_core_minimize_partial;
|
|
bool m_drat;
|
|
symbol m_drat_file;
|
|
bool m_drat_check_unsat;
|
|
bool m_drat_check_sat;
|
|
|
|
bool m_dimacs_display;
|
|
bool m_dimacs_inprocess_display;
|
|
|
|
symbol m_always_true;
|
|
symbol m_always_false;
|
|
symbol m_caching;
|
|
symbol m_random;
|
|
symbol m_geometric;
|
|
symbol m_luby;
|
|
|
|
symbol m_dyn_psm;
|
|
symbol m_psm;
|
|
symbol m_glue;
|
|
symbol m_glue_psm;
|
|
symbol m_psm_glue;
|
|
|
|
pb_solver m_pb_solver;
|
|
|
|
// branching heuristic settings.
|
|
branching_heuristic m_branching_heuristic;
|
|
bool m_anti_exploration;
|
|
double m_step_size_init;
|
|
double m_step_size_dec;
|
|
double m_step_size_min;
|
|
double m_reward_multiplier;
|
|
double m_reward_offset;
|
|
|
|
// simplifier configurations used outside of sat_simplifier
|
|
bool m_elim_vars;
|
|
|
|
config(params_ref const & p);
|
|
void updt_params(params_ref const & p);
|
|
static void collect_param_descrs(param_descrs & d);
|
|
};
|
|
};
|
|
|
|
#endif
|