/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */ /* * Main authors: * Christian Schulte * * Copyright: * Christian Schulte, 2008 * * Last modified: * $Date: 2010-09-01 00:19:34 +1000 (Wed, 01 Sep 2010) $ by $Author: schulte $ * $Revision: 11366 $ * * This file is part of Gecode, the generic constraint * development environment: * http://www.gecode.org * * Permission is hereby granted, free of charge, to any person obtaining * a copy of this software and associated documentation files (the * "Software"), to deal in the Software without restriction, including * without limitation the rights to use, copy, modify, merge, publish, * distribute, sublicense, and/or sell copies of the Software, and to * permit persons to whom the Software is furnished to do so, subject to * the following conditions: * * The above copyright notice and this permission notice shall be * included in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * */ namespace Gecode { /** * \brief Base class for variables * \ingroup TaskVarView */ class Var {}; /** * \brief Variables as interfaces to variable implementations * \ingroup TaskVarView */ template class VarImpVar : public Var { protected: /// Pointer to variable implementation VarImp* x; /// Default constructor VarImpVar(void); /// Initialize with variable implementation \a y VarImpVar(VarImp* y); public: /// The variable implementation type corresponding to the variable typedef VarImp VarImpType; /// \name Generic variable information //@{ /// Return variable implementation of variable VarImp* varimp(void) const; /// Return degree (number of subscribed propagators and advisors) unsigned int degree(void) const; /// Return accumulated failure count (plus degree) double afc(void) const; //@} /// \name Domain tests //@{ /// Test whether view is assigned bool assigned(void) const; //@} /// \name Cloning //@{ /// Update this variable to be a clone of variable \a y void update(Space& home, bool share, VarImpVar& y); //@} /// \name Variable comparison //@{ /// Test whether variable is the same as \a y bool same(const VarImpVar& y) const; /// Test whether variable comes before \a y (arbitrary order) bool before(const VarImpVar& y) const; //@} }; /* * Variable: contains a pointer to a variable implementation * */ template forceinline VarImpVar::VarImpVar(void) : x(NULL) {} template forceinline VarImpVar::VarImpVar(VarImp* y) : x(y) {} template forceinline VarImp* VarImpVar::varimp(void) const { return x; } template forceinline unsigned int VarImpVar::degree(void) const { return x->degree(); } template forceinline double VarImpVar::afc(void) const { return x->afc(); } template forceinline bool VarImpVar::assigned(void) const { return x->assigned(); } template forceinline void VarImpVar::update(Space& home, bool share, VarImpVar& y) { x = y.x->copy(home,share); } template forceinline bool VarImpVar::same(const VarImpVar& y) const { return varimp() == y.varimp(); } template forceinline bool VarImpVar::before(const VarImpVar& y) const { return varimp() < y.varimp(); } } // STATISTICS: kernel-var