diff options
author | Anas Nashif <anas.nashif@intel.com> | 2012-11-06 07:10:54 -0800 |
---|---|---|
committer | Anas Nashif <anas.nashif@intel.com> | 2012-11-06 07:10:54 -0800 |
commit | ede95f2eabeab645352a36af072ee998c400bca1 (patch) | |
tree | fcd5dc9c73c1bdc0444deee28a9b329f62a2ed7b /src/BHRZ03_Certificate.inlines.hh | |
download | ppl-ede95f2eabeab645352a36af072ee998c400bca1.tar.gz ppl-ede95f2eabeab645352a36af072ee998c400bca1.tar.bz2 ppl-ede95f2eabeab645352a36af072ee998c400bca1.zip |
Imported Upstream version 0.11.2upstream/0.11.2upstream
Diffstat (limited to 'src/BHRZ03_Certificate.inlines.hh')
-rw-r--r-- | src/BHRZ03_Certificate.inlines.hh | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/src/BHRZ03_Certificate.inlines.hh b/src/BHRZ03_Certificate.inlines.hh new file mode 100644 index 000000000..692548845 --- /dev/null +++ b/src/BHRZ03_Certificate.inlines.hh @@ -0,0 +1,63 @@ +/* BHRZ03_Certificate class implementation: inline functions. + Copyright (C) 2001-2010 Roberto Bagnara <bagnara@cs.unipr.it> + Copyright (C) 2010-2011 BUGSENG srl (http://bugseng.com) + +This file is part of the Parma Polyhedra Library (PPL). + +The PPL is free software; you can redistribute it and/or modify it +under the terms of the GNU General Public License as published by the +Free Software Foundation; either version 3 of the License, or (at your +option) any later version. + +The PPL 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 +along with this program; if not, write to the Free Software Foundation, +Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1307, USA. + +For the most up-to-date information see the Parma Polyhedra Library +site: http://www.cs.unipr.it/ppl/ . */ + +#ifndef PPL_BHRZ03_Certificate_inlines_hh +#define PPL_BHRZ03_Certificate_inlines_hh 1 + +namespace Parma_Polyhedra_Library { + +inline +BHRZ03_Certificate::BHRZ03_Certificate() + : affine_dim(0), lin_space_dim(0), num_constraints(0), num_points(1), + num_rays_null_coord() { + // This is the certificate for a zero-dim universe polyhedron. + PPL_ASSERT(OK()); +} + +inline +BHRZ03_Certificate::BHRZ03_Certificate(const BHRZ03_Certificate& y) + : affine_dim(y.affine_dim), lin_space_dim(y.lin_space_dim), + num_constraints(y.num_constraints), num_points(y.num_points), + num_rays_null_coord(y.num_rays_null_coord) { +} + +inline +BHRZ03_Certificate::~BHRZ03_Certificate() { +} + +inline bool +BHRZ03_Certificate::is_stabilizing(const Polyhedron& ph) const { + return compare(ph) == 1; +} + +inline bool +BHRZ03_Certificate::Compare::operator()(const BHRZ03_Certificate& x, + const BHRZ03_Certificate& y) const { + // For an efficient evaluation of the multiset ordering based + // on this lgo relation, we want larger elements to come first. + return x.compare(y) == 1; +} + +} // namespace Parma_Polyhedra_Library + +#endif // !defined(PPL_BHRZ03_Certificate_inlines_hh) |