safety.cc 1.97 KB
Newer Older
1
// -*- coding: utf-8 -*-
2
// Copyright (C) 2010, 2011, 2013, 2014 Laboratoire de Recherche et
3
// 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 "safety.hh"
21
22
#include "misc/hash.hh"
#include <deque>
23
24
25
26

namespace spot
{
  bool
27
28
  is_guarantee_automaton(const const_tgba_digraph_ptr& aut,
			 const scc_info* sm)
29
  {
30
    // Create an scc_info if the user did not give one to us.
31
32
    bool need_sm = !sm;
    if (need_sm)
33
      sm = new scc_info(aut);
34
35
36
37

    bool result = true;

    unsigned scc_count = sm->scc_count();
38
    for (unsigned scc = 0; scc < scc_count; ++scc)
39
      {
40
	if (!sm->is_accepting_scc(scc))
41
42
	  continue;
	// Accepting SCCs should have only one state.
43
	auto& st = sm->states_of(scc);
44
45
46
47
48
49
50
	if (st.size() != 1)
	  {
	    result = false;
	    break;
	  }
	// The state should have only one transition that is a
	// self-loop labelled by true.
51
52
53
54
55
56
57
58
	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;
59
60
61
62
63
64
65
      }

    if (need_sm)
      delete sm;
    return result;
  }

66
  bool is_safety_mwdba(const const_tgba_digraph_ptr& aut)
67
  {
68
69
70
71
72
    for (auto& t: aut->transitions())
      if (!aut->is_dead_transition(t))
	if (!aut->acc().accepting(t.acc))
	  return false;
    return true;
73
  }
74
75
76
77



}