gen: prefix ltl_pattern identifiers with LTL_
This helps with autocompletion in IPython, and it will prevent us from mixing LTL patterns with automata patterns (once we have more than one automata generator). * spot/gen/formulas.hh: Here. * spot/gen/formulas.cc, bin/genltl.cc, tests/python/gen.ipynb, tests/python/gen.py: Adjust.
This commit is contained in:
parent
0c69649ba1
commit
ca7f72bb4b
5 changed files with 166 additions and 171 deletions
|
|
@ -1054,73 +1054,73 @@ namespace spot
|
|||
switch (pattern)
|
||||
{
|
||||
// Keep this alphabetically-ordered!
|
||||
case AND_F:
|
||||
case LTL_AND_F:
|
||||
return combunop_n("p", n, op::F, true);
|
||||
case AND_FG:
|
||||
case LTL_AND_FG:
|
||||
return FG_n("p", n, true);
|
||||
case AND_GF:
|
||||
case LTL_AND_GF:
|
||||
return GF_n("p", n, true);
|
||||
case CCJ_ALPHA:
|
||||
case LTL_CCJ_ALPHA:
|
||||
return formula::And({E_n("p", n), E_n("q", n)});
|
||||
case CCJ_BETA:
|
||||
case LTL_CCJ_BETA:
|
||||
return formula::And({N_n("p", n), N_n("q", n)});
|
||||
case CCJ_BETA_PRIME:
|
||||
case LTL_CCJ_BETA_PRIME:
|
||||
return formula::And({N_prime_n("p", n), N_prime_n("q", n)});
|
||||
case DAC_PATTERNS:
|
||||
case LTL_DAC_PATTERNS:
|
||||
return dac_pattern(n);
|
||||
case EH_PATTERNS:
|
||||
case LTL_EH_PATTERNS:
|
||||
return eh_pattern(n);
|
||||
case GH_Q:
|
||||
case LTL_GH_Q:
|
||||
return Q_n("p", n);
|
||||
case GH_R:
|
||||
case LTL_GH_R:
|
||||
return R_n("p", n);
|
||||
case GO_THETA:
|
||||
case LTL_GO_THETA:
|
||||
return fair_response("p", "q", "r", n);
|
||||
case HKRSS_PATTERNS:
|
||||
case LTL_HKRSS_PATTERNS:
|
||||
return hkrss_pattern(n);
|
||||
case KR_N:
|
||||
case LTL_KR_N:
|
||||
return kr2_exp(n, "a", "b", "c", "d");
|
||||
case KR_NLOGN:
|
||||
case LTL_KR_NLOGN:
|
||||
return kr1_exp(n, "a", "b", "c", "d", "y", "z");
|
||||
case KV_PSI:
|
||||
case LTL_KV_PSI:
|
||||
return kv_exp(n, "a", "b", "c", "d");
|
||||
case OR_FG:
|
||||
case LTL_OR_FG:
|
||||
return FG_n("p", n, false);
|
||||
case OR_G:
|
||||
case LTL_OR_G:
|
||||
return combunop_n("p", n, op::G, false);
|
||||
case OR_GF:
|
||||
case LTL_OR_GF:
|
||||
return GF_n("p", n, false);
|
||||
case P_PATTERNS:
|
||||
case LTL_P_PATTERNS:
|
||||
return p_pattern(n);
|
||||
case R_LEFT:
|
||||
case LTL_R_LEFT:
|
||||
return bin_n("p", n, op::R, false);
|
||||
case R_RIGHT:
|
||||
case LTL_R_RIGHT:
|
||||
return bin_n("p", n, op::R, true);
|
||||
case RV_COUNTER_CARRY:
|
||||
case LTL_RV_COUNTER_CARRY:
|
||||
return ltl_counter_carry("b", "m", "c", n, false);
|
||||
case RV_COUNTER_CARRY_LINEAR:
|
||||
case LTL_RV_COUNTER_CARRY_LINEAR:
|
||||
return ltl_counter_carry("b", "m", "c", n, true);
|
||||
case RV_COUNTER:
|
||||
case LTL_RV_COUNTER:
|
||||
return ltl_counter("b", "m", n, false);
|
||||
case RV_COUNTER_LINEAR:
|
||||
case LTL_RV_COUNTER_LINEAR:
|
||||
return ltl_counter("b", "m", n, true);
|
||||
case SB_PATTERNS:
|
||||
case LTL_SB_PATTERNS:
|
||||
return sb_pattern(n);
|
||||
case TV_F1:
|
||||
case LTL_TV_F1:
|
||||
return tv_f1("p", "q", n);
|
||||
case TV_F2:
|
||||
case LTL_TV_F2:
|
||||
return tv_f2("p", "q", n);
|
||||
case TV_G1:
|
||||
case LTL_TV_G1:
|
||||
return tv_g1("p", "q", n);
|
||||
case TV_G2:
|
||||
case LTL_TV_G2:
|
||||
return tv_g2("p", "q", n);
|
||||
case TV_UU:
|
||||
case LTL_TV_UU:
|
||||
return tv_uu("p", n);
|
||||
case U_LEFT:
|
||||
case LTL_U_LEFT:
|
||||
return bin_n("p", n, op::U, false);
|
||||
case U_RIGHT:
|
||||
case LTL_U_RIGHT:
|
||||
return bin_n("p", n, op::U, true);
|
||||
case LAST_CLASS:
|
||||
case LTL_END:
|
||||
break;
|
||||
}
|
||||
throw std::runtime_error("unsupported pattern");
|
||||
|
|
@ -1168,10 +1168,10 @@ namespace spot
|
|||
// Make sure we do not forget to update the above table every
|
||||
// time a new pattern is added.
|
||||
static_assert(sizeof(class_name)/sizeof(*class_name)
|
||||
== LAST_CLASS - FIRST_CLASS, "size mismatch");
|
||||
if (pattern < FIRST_CLASS || pattern >= LAST_CLASS)
|
||||
== LTL_END - LTL_BEGIN, "size mismatch");
|
||||
if (pattern < LTL_BEGIN || pattern >= LTL_END)
|
||||
throw std::runtime_error("unsupported pattern");
|
||||
return class_name[pattern - FIRST_CLASS];
|
||||
return class_name[pattern - LTL_BEGIN];
|
||||
}
|
||||
|
||||
int ltl_pattern_max(ltl_pattern_id pattern)
|
||||
|
|
@ -1179,50 +1179,50 @@ namespace spot
|
|||
switch (pattern)
|
||||
{
|
||||
// Keep this alphabetically-ordered!
|
||||
case AND_F:
|
||||
case AND_FG:
|
||||
case AND_GF:
|
||||
case CCJ_ALPHA:
|
||||
case CCJ_BETA:
|
||||
case CCJ_BETA_PRIME:
|
||||
case LTL_AND_F:
|
||||
case LTL_AND_FG:
|
||||
case LTL_AND_GF:
|
||||
case LTL_CCJ_ALPHA:
|
||||
case LTL_CCJ_BETA:
|
||||
case LTL_CCJ_BETA_PRIME:
|
||||
return 0;
|
||||
case DAC_PATTERNS:
|
||||
case LTL_DAC_PATTERNS:
|
||||
return 55;
|
||||
case EH_PATTERNS:
|
||||
case LTL_EH_PATTERNS:
|
||||
return 12;
|
||||
case GH_Q:
|
||||
case GH_R:
|
||||
case GO_THETA:
|
||||
case LTL_GH_Q:
|
||||
case LTL_GH_R:
|
||||
case LTL_GO_THETA:
|
||||
return 0;
|
||||
case HKRSS_PATTERNS:
|
||||
case LTL_HKRSS_PATTERNS:
|
||||
return 55;
|
||||
case KR_N:
|
||||
case KR_NLOGN:
|
||||
case KV_PSI:
|
||||
case OR_FG:
|
||||
case OR_G:
|
||||
case OR_GF:
|
||||
case LTL_KR_N:
|
||||
case LTL_KR_NLOGN:
|
||||
case LTL_KV_PSI:
|
||||
case LTL_OR_FG:
|
||||
case LTL_OR_G:
|
||||
case LTL_OR_GF:
|
||||
return 0;
|
||||
case P_PATTERNS:
|
||||
case LTL_P_PATTERNS:
|
||||
return 20;
|
||||
case R_LEFT:
|
||||
case R_RIGHT:
|
||||
case RV_COUNTER_CARRY:
|
||||
case RV_COUNTER_CARRY_LINEAR:
|
||||
case RV_COUNTER:
|
||||
case RV_COUNTER_LINEAR:
|
||||
case LTL_R_LEFT:
|
||||
case LTL_R_RIGHT:
|
||||
case LTL_RV_COUNTER_CARRY:
|
||||
case LTL_RV_COUNTER_CARRY_LINEAR:
|
||||
case LTL_RV_COUNTER:
|
||||
case LTL_RV_COUNTER_LINEAR:
|
||||
return 0;
|
||||
case SB_PATTERNS:
|
||||
case LTL_SB_PATTERNS:
|
||||
return 27;
|
||||
case TV_F1:
|
||||
case TV_F2:
|
||||
case TV_G1:
|
||||
case TV_G2:
|
||||
case TV_UU:
|
||||
case U_LEFT:
|
||||
case U_RIGHT:
|
||||
case LTL_TV_F1:
|
||||
case LTL_TV_F2:
|
||||
case LTL_TV_G1:
|
||||
case LTL_TV_G2:
|
||||
case LTL_TV_UU:
|
||||
case LTL_U_LEFT:
|
||||
case LTL_U_RIGHT:
|
||||
return 0;
|
||||
case LAST_CLASS:
|
||||
case LTL_END:
|
||||
break;
|
||||
}
|
||||
throw std::runtime_error("unsupported pattern");
|
||||
|
|
|
|||
|
|
@ -166,51 +166,51 @@ namespace spot
|
|||
namespace gen
|
||||
{
|
||||
enum ltl_pattern_id {
|
||||
FIRST_CLASS = 256,
|
||||
AND_F = FIRST_CLASS,
|
||||
AND_FG,
|
||||
AND_GF,
|
||||
CCJ_ALPHA,
|
||||
CCJ_BETA,
|
||||
CCJ_BETA_PRIME,
|
||||
DAC_PATTERNS,
|
||||
EH_PATTERNS,
|
||||
GH_Q,
|
||||
GH_R,
|
||||
GO_THETA,
|
||||
HKRSS_PATTERNS,
|
||||
KR_N,
|
||||
KR_NLOGN,
|
||||
KV_PSI,
|
||||
OR_FG,
|
||||
OR_G,
|
||||
OR_GF,
|
||||
P_PATTERNS,
|
||||
R_LEFT,
|
||||
R_RIGHT,
|
||||
RV_COUNTER,
|
||||
RV_COUNTER_CARRY,
|
||||
RV_COUNTER_CARRY_LINEAR,
|
||||
RV_COUNTER_LINEAR,
|
||||
SB_PATTERNS,
|
||||
TV_F1,
|
||||
TV_F2,
|
||||
TV_G1,
|
||||
TV_G2,
|
||||
TV_UU,
|
||||
U_LEFT,
|
||||
U_RIGHT,
|
||||
LAST_CLASS,
|
||||
LTL_BEGIN = 256,
|
||||
LTL_AND_F = LTL_BEGIN,
|
||||
LTL_AND_FG,
|
||||
LTL_AND_GF,
|
||||
LTL_CCJ_ALPHA,
|
||||
LTL_CCJ_BETA,
|
||||
LTL_CCJ_BETA_PRIME,
|
||||
LTL_DAC_PATTERNS,
|
||||
LTL_EH_PATTERNS,
|
||||
LTL_GH_Q,
|
||||
LTL_GH_R,
|
||||
LTL_GO_THETA,
|
||||
LTL_HKRSS_PATTERNS,
|
||||
LTL_KR_N,
|
||||
LTL_KR_NLOGN,
|
||||
LTL_KV_PSI,
|
||||
LTL_OR_FG,
|
||||
LTL_OR_G,
|
||||
LTL_OR_GF,
|
||||
LTL_P_PATTERNS,
|
||||
LTL_R_LEFT,
|
||||
LTL_R_RIGHT,
|
||||
LTL_RV_COUNTER,
|
||||
LTL_RV_COUNTER_CARRY,
|
||||
LTL_RV_COUNTER_CARRY_LINEAR,
|
||||
LTL_RV_COUNTER_LINEAR,
|
||||
LTL_SB_PATTERNS,
|
||||
LTL_TV_F1,
|
||||
LTL_TV_F2,
|
||||
LTL_TV_G1,
|
||||
LTL_TV_G2,
|
||||
LTL_TV_UU,
|
||||
LTL_U_LEFT,
|
||||
LTL_U_RIGHT,
|
||||
LTL_END
|
||||
};
|
||||
|
||||
/// \brief generate an LTL from a known pattern
|
||||
///
|
||||
/// The pattern is specified using one value from the ltl_pattern_id
|
||||
/// enum. See the man page of the `genltl` binary for a
|
||||
/// description of those pattern, and bibliographic references.
|
||||
/// description of those patterns, and bibliographic references.
|
||||
SPOT_API formula ltl_pattern(ltl_pattern_id pattern, int n);
|
||||
|
||||
/// \brief convert an ltl_pattern value into a name
|
||||
/// \brief convert an ltl_pattern_id value into a name
|
||||
///
|
||||
/// The returned name is suitable to be used as an option
|
||||
/// key for the genltl binary.
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue