ltlfilt: add support for --to-delta2

* bin/ltlfilt.cc: Implement this option.
* tests/core/delta2.test: New file.
* tests/Makefile.am: Add it.
* NEWS: Mention it.
This commit is contained in:
Alexandre Duret-Lutz 2024-07-25 16:34:11 +02:00
parent 41abe3f831
commit bcdfe44c44
4 changed files with 44 additions and 1 deletions

2
NEWS
View file

@ -9,6 +9,8 @@ New in spot 2.12.0.dev (not yet released)
- ltlfilt learned --pi1, --sigma1, --delta1, --pi2, --sigma2, and - ltlfilt learned --pi1, --sigma1, --delta1, --pi2, --sigma2, and
--delta2 to filter according to classes Π₁,Σ₁,Δ₁,Π₂,Σ₂, and Δ₂. --delta2 to filter according to classes Π₁,Σ₁,Δ₁,Π₂,Σ₂, and Δ₂.
- ltlfilt learned --to-delta2 to transform an LTL formula into Δ₂.
Library: Library:
- restrict_dead_end_edges_here() can reduce non-determinism (but - restrict_dead_end_edges_here() can reduce non-determinism (but

View file

@ -38,6 +38,7 @@
#include <spot/misc/timer.hh> #include <spot/misc/timer.hh>
#include <spot/tl/simplify.hh> #include <spot/tl/simplify.hh>
#include <spot/tl/sonf.hh> #include <spot/tl/sonf.hh>
#include <spot/tl/delta2.hh>
#include <spot/tl/length.hh> #include <spot/tl/length.hh>
#include <spot/tl/relabel.hh> #include <spot/tl/relabel.hh>
#include <spot/tl/unabbrev.hh> #include <spot/tl/unabbrev.hh>
@ -115,6 +116,7 @@ enum {
OPT_SYNTACTIC_RECURRENCE, OPT_SYNTACTIC_RECURRENCE,
OPT_SYNTACTIC_SAFETY, OPT_SYNTACTIC_SAFETY,
OPT_SYNTACTIC_SI, OPT_SYNTACTIC_SI,
OPT_TO_DELTA2,
OPT_UNABBREVIATE, OPT_UNABBREVIATE,
OPT_UNIVERSAL, OPT_UNIVERSAL,
}; };
@ -161,6 +163,8 @@ static const argp_option options[] =
{ "remove-x", OPT_REMOVE_X, nullptr, 0, { "remove-x", OPT_REMOVE_X, nullptr, 0,
"remove X operators (valid only for stutter-insensitive properties)", "remove X operators (valid only for stutter-insensitive properties)",
0 }, 0 },
{ "to-delta2", OPT_TO_DELTA2, nullptr, 0,
"rewrite LTL formula in Δ₂-form", 0 },
{ "unabbreviate", OPT_UNABBREVIATE, "STR", OPTION_ARG_OPTIONAL, { "unabbreviate", OPT_UNABBREVIATE, "STR", OPTION_ARG_OPTIONAL,
"remove all occurrences of the operators specified by STR, which " "remove all occurrences of the operators specified by STR, which "
"must be a substring of \"eFGiMRW^\", where 'e', 'i', and '^' stand " "must be a substring of \"eFGiMRW^\", where 'e', 'i', and '^' stand "
@ -349,7 +353,7 @@ static int opt_max_count = -1;
static long int match_count = 0; static long int match_count = 0;
static const char* from_ltlf = nullptr; static const char* from_ltlf = nullptr;
static const char* sonf = nullptr; static const char* sonf = nullptr;
static bool to_delta2 = false;
// We want all these variables to be destroyed when we exit main, to // We want all these variables to be destroyed when we exit main, to
// make sure it happens before all other global variables (like the // make sure it happens before all other global variables (like the
@ -579,6 +583,9 @@ parse_opt(int key, char* arg, struct argp_state*)
case OPT_STUTTER_INSENSITIVE: case OPT_STUTTER_INSENSITIVE:
stutter_insensitive = true; stutter_insensitive = true;
break; break;
case OPT_TO_DELTA2:
to_delta2 = true;
break;
case OPT_UNABBREVIATE: case OPT_UNABBREVIATE:
if (arg) if (arg)
unabbreviate += arg; unabbreviate += arg;
@ -734,6 +741,9 @@ namespace
} }
} }
if (to_delta2)
f = spot::to_delta2(f);
switch (relabeling) switch (relabeling)
{ {
case ApRelabeling: case ApRelabeling:

View file

@ -236,6 +236,7 @@ TESTS_twa = \
core/renault.test \ core/renault.test \
core/nondet.test \ core/nondet.test \
core/det.test \ core/det.test \
core/delta2.test \
core/semidet.test \ core/semidet.test \
core/neverclaimread.test \ core/neverclaimread.test \
core/parseaut.test \ core/parseaut.test \

30
tests/core/delta2.test Normal file
View file

@ -0,0 +1,30 @@
#!/bin/sh
# -*- coding: utf-8 -*-
# Copyright (C) by the Spot authors, see the AUTHORS file for details.
#
# This file is part of Spot, a model checking library.
#
# Spot is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
#
# Spot is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
# License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
. ./defs
set -e
genltl --dac-p --eh-p --hkrss-p --sb-p --sejk-p \
--stats='%F:%L,%f' > formulas.txt
ltlfilt --to-delta2 --delta2 -F formulas.txt/2 > res.txt
ltlfilt --to-delta2 -v --delta2 -F formulas.txt/2 --stats='%<' || :
test `wc -l < formulas.txt` -eq `wc -l < res.txt`
ltlcross -F formulas.txt/2 \
'ltl2tgba' 'ltlfilt --to-delta2 -f %f | ltl2tgba -G >%O'