spot 2.12.2
|
Generate random SERE. More...
#include <spot/tl/randomltl.hh>
Public Member Functions | |
random_sere (const atomic_prop_set *ap) | |
const atomic_prop_set * | ap () const |
Return the set of atomic proposition used to build formulae. 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 formulae. More... | |
bool | has_unary_ops () const |
whether we can use unary operators More... | |
Public Attributes | |
random_boolean | rb |
Protected Member Functions | |
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_ |
Generate random SERE.
This class recursively constructs SERE of a given size. The formulae will use the use atomic propositions from the set of propositions passed to the constructor, in addition to the constant and all SERE operators supported by Spot.
By default each operator has equal chance to be selected.
spot::random_sere::random_sere | ( | const atomic_prop_set * | ap | ) |
Create a random SERE generator using atomic propositions from ap.
The default priorities are defined as follows:
eword 1 boolform 1 star 1 star_b 1 equal_b 1 goto_b 1 and 1 andNLM 1 or 1 concat 1 fusion 1
Where "boolfrom" designates a Boolean formula generated by random_boolean.
These priorities can be changed use the parse_options method.
In addition, you can set the properties of the Boolean formula generator used to build Boolean subformulae using the parse_options method of the rb
attribute.
|
inlineinherited |
Return the set of atomic proposition used to build formulae.
|
inherited |
Print the priorities of each operator, constants, and atomic propositions.
|
inherited |
Generate a formula of size n.
It is possible to obtain formulae 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
|
inherited |
Update the priorities used to generate the formulae.
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.