strength.cc 2.07 KB
Newer Older
1
// -*- coding: utf-8 -*-
2
3
// Copyright (C) 2010, 2011, 2013, 2014, 2015 Laboratoire de Recherche
// et Développement de l'Epita (LRDE)
4
5
6
7
8
//
// 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
9
// the Free Software Foundation; either version 3 of the License, or
10
11
12
13
14
15
16
17
// (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
18
// along with this program.  If not, see <http://www.gnu.org/licenses/>.
19

20
#include "strength.hh"
21
22
#include "misc/hash.hh"
#include <deque>
23
24
25
26

namespace spot
{
  bool
27
  is_terminal_automaton(const const_twa_graph_ptr& aut, scc_info* si)
28
  {
29
30
    if (aut->prop_terminal())
      return true;
31
    // Create an scc_info if the user did not give one to us.
32
33
34
    bool need_si = !si;
    if (need_si)
      si = new scc_info(aut);
35
    si->determine_unknown_acceptance();
36
37
38

    bool result = true;

39
    for (auto& scc: *si)
40
      {
41
	if (scc.is_rejecting())
42
43
	  continue;
	// Accepting SCCs should have only one state.
44
	auto& st = scc.states();
45
46
47
48
49
	if (st.size() != 1)
	  {
	    result = false;
	    break;
	  }
50
	// The state should have only one edge that is a
51
	// self-loop labelled by true.
52
53
54
55
56
57
58
59
	auto src = st.front();
	auto out = aut->out(src);
	auto it = out.begin();
	assert(it != out.end());
	result =
	  (it->cond == bddtrue) && (it->dst == src) && (++it == out.end());
	if (!result)
	  break;
60
61
      }

62
63
    if (need_si)
      delete si;
64
65
66
    return result;
  }

67
  bool is_safety_mwdba(const const_twa_graph_ptr& aut)
68
  {
69
    if (!(aut->acc().is_buchi() || aut->acc().is_tt()))
70
71
72
      throw std::runtime_error
	("is_safety_mwdba() should be called on a Buchi automaton");

73
    for (auto& t: aut->edges())
74
75
      if (!aut->acc().accepting(t.acc))
	return false;
76
    return true;
77
  }
78
79
80
81



}