spot 2.14
bdddict.hh
1// -*- coding: utf-8 -*-
2// Copyright (C) by the Spot authors, see the AUTHORS file for details.
3//
4// This file is part of Spot, a model checking library.
5//
6// Spot is free software; you can redistribute it and/or modify it
7// under the terms of the GNU General Public License as published by
8// the Free Software Foundation; either version 3 of the License, or
9// (at your option) any later version.
10//
11// Spot is distributed in the hope that it will be useful, but WITHOUT
12// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13// or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
14// License for more details.
15//
16// You should have received a copy of the GNU General Public License
17// along with this program. If not, see <http://www.gnu.org/licenses/>.
18
19#pragma once
20
21#include <list>
22#include <set>
23#include <map>
24#include <iosfwd>
25#include <bddx.h>
26#include <vector>
27#include <memory>
28#include <spot/tl/formula.hh>
29
30namespace spot
31{
33 class bdd_dict_priv;
34
51 class SPOT_API bdd_dict
52 {
53 bdd_dict_priv* priv_;
54 public:
55
56 bdd_dict();
57
63
65 typedef std::map<formula, int> fv_map;
67 typedef std::map<int, formula> vf_map;
68
71
73 typedef std::set<const void*> ref_set;
74
75 enum var_type { anon = 0, var, acc };
76 struct bdd_info {
77 bdd_info() noexcept: type(anon) {}
78 var_type type;
79 formula f; // Used unless t==anon.
80 ref_set refs;
81 };
82 typedef std::vector<bdd_info> bdd_info_map;
83 // Map BDD variables to their meaning.
84 bdd_info_map bdd_map;
85
97 int register_proposition(formula f, const void* for_me);
98
99 template <typename T>
100 int register_proposition(formula f, std::shared_ptr<T> for_me)
101 {
102 return register_proposition(f, for_me.get());
103 }
105
112 int has_registered_proposition(formula f, const void* me);
113
114 template <typename T>
115 int has_registered_proposition(formula f, std::shared_ptr<T> for_me)
116 {
117 return has_registered_proposition(f, for_me.get());
118 }
120
121 // \brief return the BDD variable associated to a registered
122 // proposition.
123 //
124 // Throws std::out_of_range if the \a is not a known proposition.
125 int varnum(formula f)
126 {
127 return var_map.at(f);
128 }
129
141 int register_acceptance_variable(formula f, const void* for_me);
142
143 template <typename T>
144 int register_acceptance_variable(formula f, std::shared_ptr<T> for_me)
145 {
146 return register_acceptance_variable(f, for_me.get());
147 }
149
158 int register_anonymous_variables(int n, const void* for_me);
159
160 template <typename T>
161 int register_anonymous_variables(int n, std::shared_ptr<T> for_me)
162 {
163 return register_anonymous_variables(n, for_me.get());
164 }
166
174 void register_all_variables_of(const void* from_other, const void* for_me);
175
176 template <typename T>
177 void register_all_variables_of(const void* from_other,
178 std::shared_ptr<T> for_me)
179 {
180 register_all_variables_of(from_other, for_me.get());
181 }
182
183 template <typename T>
184 void register_all_variables_of(std::shared_ptr<T> from_other,
185 const void* for_me)
186 {
187 register_all_variables_of(from_other.get(), for_me);
188 }
189
190 template <typename T, typename U>
191 void register_all_variables_of(std::shared_ptr<T> from_other,
192 std::shared_ptr<U> for_me)
193 {
194 register_all_variables_of(from_other.get(), for_me.get());
195 }
197
205 void register_all_propositions_of(const void* from_other,
206 const void* for_me);
207
208 template <typename T>
209 void register_all_propositions_of(const void* from_other,
210 std::shared_ptr<T> for_me)
211 {
212 register_all_propositions_of(from_other, for_me.get());
213 }
214
215 template <typename T>
216 void register_all_propositions_of(std::shared_ptr<T> from_other,
217 const void* for_me)
218 {
219 register_all_propotitions_of(from_other.get(), for_me);
220 }
221
222 template <typename T, typename U>
223 void register_all_propositions_of(std::shared_ptr<T> from_other,
224 std::shared_ptr<U> for_me)
225 {
226 register_all_propositions_of(from_other.get(), for_me.get());
227 }
229
233 void unregister_all_my_variables(const void* me);
234
237 void unregister_variable(int var, const void* me);
238
239 template <typename T>
240 void unregister_variable(int var, std::shared_ptr<T> me)
241 {
242 unregister_variable(var, me.get());
243 }
245
248 std::ostream& dump(std::ostream& os) const;
249
261 void assert_emptiness() const;
262
263 private:
264 // Disallow copy.
265 bdd_dict(const bdd_dict& other) = delete;
266 bdd_dict& operator=(const bdd_dict& other) = delete;
267 };
268
269 typedef std::shared_ptr<bdd_dict> bdd_dict_ptr;
270
271 inline bdd_dict_ptr make_bdd_dict()
272 {
273 return std::make_shared<bdd_dict>();
274 }
275
277 {
278 public:
279 operator bdd_dict_ptr() const
280 {
281 return dict_;
282 }
283
284 bdd_dict_ptr get_dict() const
285 {
286 return dict_;
287 }
288
289 int register_proposition(formula f)
290 {
291 return dict_->register_proposition(f, this);
292 }
293
294 int register_proposition(const std::string& f)
295 {
296 return register_proposition(formula::ap(f));
297 }
298
300 {
301 dict_->unregister_all_my_variables(this);
302 }
303
304 private:
305 bdd_dict_ptr dict_ = make_bdd_dict();
306 };
307
308}
Definition: bdddict.hh:277
Map BDD variables to formulae.
Definition: bdddict.hh:52
std::set< const void * > ref_set
BDD-variable reference counts.
Definition: bdddict.hh:73
void register_all_propositions_of(std::shared_ptr< T > from_other, std::shared_ptr< U > for_me)
Duplicate the proposition usage of another object.
Definition: bdddict.hh:223
void register_all_propositions_of(const void *from_other, std::shared_ptr< T > for_me)
Duplicate the proposition usage of another object.
Definition: bdddict.hh:209
std::ostream & dump(std::ostream &os) const
Dump all variables for debugging.
int register_acceptance_variable(formula f, const void *for_me)
Register an acceptance variable.
void assert_emptiness() const
Make sure the dictionary is empty.
void register_all_propositions_of(std::shared_ptr< T > from_other, const void *for_me)
Duplicate the proposition usage of another object.
Definition: bdddict.hh:216
void register_all_variables_of(std::shared_ptr< T > from_other, const void *for_me)
Duplicate the variable usage of another object.
Definition: bdddict.hh:184
std::map< int, formula > vf_map
BDD-variable-to-formula maps.
Definition: bdddict.hh:67
std::map< formula, int > fv_map
Formula-to-BDD-variable maps.
Definition: bdddict.hh:65
void unregister_variable(int var, std::shared_ptr< T > me)
Release a variable used by me.
Definition: bdddict.hh:240
int register_proposition(formula f, const void *for_me)
Register an atomic proposition.
void unregister_all_my_variables(const void *me)
Release all variables used by an object.
int register_proposition(formula f, std::shared_ptr< T > for_me)
Register an atomic proposition.
Definition: bdddict.hh:100
int register_anonymous_variables(int n, const void *for_me)
Register anonymous BDD variables.
int has_registered_proposition(formula f, std::shared_ptr< T > for_me)
whether a proposition has already been registered
Definition: bdddict.hh:115
void register_all_variables_of(const void *from_other, std::shared_ptr< T > for_me)
Duplicate the variable usage of another object.
Definition: bdddict.hh:177
int has_registered_proposition(formula f, const void *me)
whether a proposition has already been registered
void register_all_propositions_of(const void *from_other, const void *for_me)
Duplicate the proposition usage of another object.
fv_map var_map
Maps atomic propositions to BDD variables.
Definition: bdddict.hh:69
void unregister_variable(int var, const void *me)
Release a variable used by me.
int register_anonymous_variables(int n, std::shared_ptr< T > for_me)
Register anonymous BDD variables.
Definition: bdddict.hh:161
void register_all_variables_of(std::shared_ptr< T > from_other, std::shared_ptr< U > for_me)
Duplicate the variable usage of another object.
Definition: bdddict.hh:191
fv_map acc_map
Maps acceptance conditions to BDD variables.
Definition: bdddict.hh:70
int register_acceptance_variable(formula f, std::shared_ptr< T > for_me)
Register an acceptance variable.
Definition: bdddict.hh:144
~bdd_dict()
Destroy the BDD dict.
void register_all_variables_of(const void *from_other, const void *for_me)
Duplicate the variable usage of another object.
Main class for temporal logic formula.
Definition: formula.hh:786
static formula ap(const std::string &name)
Build an atomic proposition.
Definition: formula.hh:933
LTL/PSL formula interface.
Definition: automata.hh:26
Definition: bdddict.hh:76

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.4