spot  2.11.6
cobuchi.hh
1 // -*- coding: utf-8 -*-
2 // Copyright (C) 2017-2019, 2022 Laboratoire de Recherche et Développement
3 // de l'Epita (LRDE).
4 //
5 // This file is part of Spot, a model checking library.
6 //
7 // Spot is free software; you can redistribute it and/or modify it
8 // 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 // (at your option) any later version.
11 //
12 // Spot is distributed in the hope that it will be useful, but WITHOUT
13 // ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14 // or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
15 // License for more details.
16 //
17 // 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 #pragma once
21 
22 #include <spot/misc/bitvect.hh>
23 #include <spot/twa/fwd.hh>
24 
25 #include <vector>
26 
27 namespace spot
28 {
37  struct nca_st_info
38  {
39  unsigned clause_num;
40  unsigned state_num;
41  bitvect* all_dst;
42 
43  nca_st_info(unsigned clause, unsigned st, bitvect* dst)
44  {
45  clause_num = clause;
46  state_num = st;
47  all_dst = dst;
48  }
49 
50  ~nca_st_info()
51  {
52  delete all_dst;
53  }
54  };
55 
56  typedef std::vector<struct nca_st_info*> vect_nca_info;
57 
70  SPOT_API twa_graph_ptr
71  nsa_to_nca(const_twa_graph_ptr aut,
72  bool named_states = false,
73  vect_nca_info* nca_info = nullptr);
74 
84  SPOT_API twa_graph_ptr
85  dnf_to_nca(const_twa_graph_ptr aut,
86  bool named_states = false,
87  vect_nca_info* nca_info = nullptr);
88 
97  SPOT_API twa_graph_ptr
98  to_nca(const_twa_graph_ptr aut, bool named_states = false);
99 
108  SPOT_API twa_graph_ptr
109  nsa_to_dca(const_twa_graph_ptr aut, bool named_states = false);
110 
119  SPOT_API twa_graph_ptr
120  dnf_to_dca(const_twa_graph_ptr aut, bool named_states = false);
121 
131  SPOT_API twa_graph_ptr
132  to_dca(const_twa_graph_ptr aut, bool named_states = false);
133 }
A bit vector.
Definition: bitvect.hh:52
Definition: automata.hh:27
twa_graph_ptr dnf_to_dca(const_twa_graph_ptr aut, bool named_states=false)
Converts an aut. with acceptance in DNF to a det. co-Büchi aut.
twa_graph_ptr dnf_to_nca(const_twa_graph_ptr aut, bool named_states=false, vect_nca_info *nca_info=nullptr)
Converts an aut. with acceptance in DNF to a nondet. co-Büchi aut.
twa_graph_ptr to_dca(const_twa_graph_ptr aut, bool named_states=false)
Converts any ω-automata to deterministic co-buchi.
twa_graph_ptr to_nca(const_twa_graph_ptr aut, bool named_states=false)
Converts any ω-automata to non-deterministic co-buchi.
twa_graph_ptr nsa_to_dca(const_twa_graph_ptr aut, bool named_states=false)
Converts a nondet Streett-like aut. to a det. co-Büchi aut.
twa_graph_ptr nsa_to_nca(const_twa_graph_ptr aut, bool named_states=false, vect_nca_info *nca_info=nullptr)
Converts a nondet Streett-like aut. to a nondet. co-Büchi aut.
Definition: cobuchi.hh:38

Please direct any question, comment, or bug report to the Spot mailing list at spot@lrde.epita.fr.
Generated on Fri Feb 27 2015 10:00:07 for spot by doxygen 1.9.1