From bfae9a7f7d1fc4923bc3c65779ea2162ad0b9f16 Mon Sep 17 00:00:00 2001 From: Lukas Holik Date: Mon, 25 Sep 2023 22:52:28 +0200 Subject: [PATCH] is_lang_empty via get_useful_states (much faster) --- src/nfa/operations.cc | 10 ++++++++++ tests-integration/src/bench-bool-comb-cox-inter.cc | 6 ++++++ 2 files changed, 16 insertions(+) diff --git a/src/nfa/operations.cc b/src/nfa/operations.cc index 114f834bd..fbdad7d7b 100644 --- a/src/nfa/operations.cc +++ b/src/nfa/operations.cc @@ -516,6 +516,16 @@ bool mata::nfa::Nfa::is_prfx_in_lang(const Run& run) const { } bool mata::nfa::Nfa::is_lang_empty(Run* cex) const { + //TOOD: hot fix for performance reasons for TACAS. + // Perhaps make the get_useful_states return a witness on demand somehow. + if (!cex) { + BoolVector useful_states = get_useful_states(); + for (auto useful: useful_states) + if (useful) + return false; + return true; + } + std::list worklist(initial.begin(), initial.end()); std::unordered_set processed(initial.begin(), initial.end()); diff --git a/tests-integration/src/bench-bool-comb-cox-inter.cc b/tests-integration/src/bench-bool-comb-cox-inter.cc index ee135743e..c916d0407 100644 --- a/tests-integration/src/bench-bool-comb-cox-inter.cc +++ b/tests-integration/src/bench-bool-comb-cox-inter.cc @@ -35,9 +35,15 @@ int main(int argc, char *argv[]) { TIME_BEGIN(intersection); Nfa intersect_aut = intersection(lhs, rhs); TIME_END(intersection); + std::cout<<"states: "<