omg_rabinctrl.h
Go to the documentation of this file.
1 /** @file omg_rabinctrl.h
2 
3 Controller synthesis for Rabin automata
4 
5 */
6 
7 /* FAU Discrete Event Systems Library (libfaudes)
8 
9  Copyright (C) 2010, 2025 Thomas Moor
10 
11  This library is free software; you can redistribute it and/or
12  modify it under the terms of the GNU Lesser General Public
13  License as published by the Free Software Foundation; either
14  version 2.1 of the License, or (at your option) any later version.
15 
16  This library is distributed in the hope that it will be useful,
17  but WITHOUT ANY WARRANTY; without even the implied warranty of
18  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19  Lesser General Public License for more details.
20 
21  You should have received a copy of the GNU Lesser General Public
22  License along with this library; if not, write to the Free Software
23  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
24 
25 
26 #ifndef FAUDES_OMG_RABINCTRL_H
27 #define FAUDES_OMG_RABINCTRL_H
28 
29 #include "corefaudes.h"
30 #include "omg_rabinaut.h"
31 
32 namespace faudes {
33 
34 
35 /**
36  * Controllability prefix for Rabin automata.
37  *
38  * Computation of the controllability prefix as proposed by
39  * Thistle/Wonham in "Supervision of infinite behavior of Discrete Event Systems, 1994,
40  * using the fixpoint iteration from "Control of w-Automata, Church's Problem, and the
41  * Emptiness Problem for Tree w-Automata", 1992.
42  *
43  * @param rRAut
44  * Automaton to control
45  * @param rSigmaCtrl
46  * Set of controllable events
47  * @param rCtrlPfx
48  * State set that marks the controllability prefix.
49  *
50  * @ingroup OmgPlugin
51  */
52 extern FAUDES_API void RabinCtrlPfx(
53  const RabinAutomaton& rRAut, const EventSet& rSigmaCtrl,
54  StateSet& rCtrlPfx);
55 
56 
57 } // namespace faudes
58 
59 #endif
60 
#define FAUDES_API
Definition: cfl_platform.h:80
IndexSet StateSet
Definition: cfl_indexset.h:273
NameSet EventSet
Definition: cfl_nameset.h:534
void RabinCtrlPfx(const RabinAutomaton &rRAut, const EventSet &rSigmaCtrl, StateSet &rCtrlPfx)
TrGenerator< RabinAcceptance, AttributeVoid, AttributeCFlags, AttributeVoid > RabinAutomaton
Definition: omg_rabinaut.h:224

libFAUDES 2.33h --- 2025.06.18 --- c++ api documentaion by doxygen