spot 2.13
|
Generate random LTL formulas. More...
#include <spot/tl/randomltl.hh>
Public Member Functions | |
random_ltl (const atomic_prop_set *ap, const atomic_prop_set *output_ap=nullptr, std::function< bool(formula)> is_output=nullptr, const atomic_prop_set *subformulas=nullptr) | |
const atomic_prop_set * | ap () const |
Return the set of atomic proposition used to build formulas. More... | |
const atomic_prop_set * | output_ap () const |
Return the set of atomic proposition used to build formulas. More... | |
std::function< bool(formula)> | is_output_fun () const |
const atomic_prop_set * | patterns () const |
Return the set of patterns (sub-formulas) used to build formulas. More... | |
bool | draw_literals () const |
Check whether relabeling APs should use literals. More... | |
void | draw_literals (bool lit) |
Set whether relabeling APs should use literals. More... | |
formula | generate (int n) const |
Generate a formula of size n. More... | |
std::ostream & | dump_priorities (std::ostream &os) const |
Print the priorities of each operator, constants, and atomic propositions. More... | |
const char * | parse_options (char *options) |
Update the priorities used to generate the formulas. More... | |
bool | has_unary_ops () const |
whether we can use unary operators More... | |
Protected Member Functions | |
void | setup_proba_ (const atomic_prop_set *patterns) |
random_ltl (int size, const atomic_prop_set *ap, const atomic_prop_set *output_ap=nullptr, std::function< bool(formula)> is_output=nullptr) | |
void | update_sums () |
Protected Attributes | |
unsigned | proba_size_ |
op_proba * | proba_ |
double | total_1_ |
op_proba * | proba_2_ |
double | total_2_ |
op_proba * | proba_2_or_more_ |
double | total_2_and_more_ |
const atomic_prop_set * | ap_ |
const atomic_prop_set * | output_ap_ = nullptr |
const atomic_prop_set * | patterns_ = nullptr |
std::function< bool(formula)> | is_output_ = nullptr |
bool | draw_literals_ |
Generate random LTL formulas.
This class recursively constructs LTL formulas of a given size. The formulas will use the use atomic propositions from the set of propositions passed to the constructor, in addition to the constant and all LTL operators supported by Spot.
By default each operator has equal chance to be selected. Also, each atomic proposition has as much chance as each constant (i.e., true and false) to be picked. This can be tuned using parse_options().
spot::random_ltl::random_ltl | ( | const atomic_prop_set * | ap, |
const atomic_prop_set * | output_ap = nullptr , |
||
std::function< bool(formula)> | is_output = nullptr , |
||
const atomic_prop_set * | subformulas = nullptr |
||
) |
Create a random LTL generator using atomic propositions from ap.
The default priorities are defined as follows, depending on the presence of subformulas.
ap n sub n false 1 false 1 true 1 true 1 not 1 not 1 F 1 F 1 G 1 G 1 X 1 X 1 equiv 1 equiv 1 implies 1 implies 1 xor 1 xor 1 R 1 R 1 U 1 U 1 W 1 W 1 M 1 M 1 and 1 and 1 or 1 or 1
Where n
is the number of atomic propositions in the set passed to the constructor.
This means that each operator has equal chance to be selected. Also, each atomic proposition has as much chance as each constant (i.e., true and false) to be picked.
These priorities can be changed use the parse_options method.
If a set of subformulas is passed to the constructor, the generator will build a Boolean formulas using patterns as atoms. Atomic propositions in patterns will be rewritten randomly by drawing some from ap. The probability of false/true to be generated default to 0 in this case.
|
inlineinherited |
Return the set of atomic proposition used to build formulas.
|
inlineinherited |
Check whether relabeling APs should use literals.
|
inlineinherited |
Set whether relabeling APs should use literals.
|
inherited |
Print the priorities of each operator, constants, and atomic propositions.
|
inherited |
Generate a formula of size n.
It is possible to obtain formulas that are smaller than n, because some simple simplifications are performed by the AST. (For instance the formula a | a
is automatically reduced to a
by spot::multop.)
|
inlineinherited |
whether we can use unary operators
|
inlineinherited |
Return the set of atomic proposition used to build formulas.
|
inherited |
Update the priorities used to generate the formulas.
options should be comma-separated list of KEY=VALUE assignments, using keys from the above list. For instance "xor=0, F=3"
will prevent xor
from being used, and will raise the relative probability of occurrences of the F
operator.
|
inlineinherited |
Return the set of patterns (sub-formulas) used to build formulas.