dlvhex
2.5.0
|
00001 /* dlvhex -- Answer-Set Programming with external interfaces. 00002 * Copyright (C) 2005-2007 Roman Schindlauer 00003 * Copyright (C) 2006-2015 Thomas Krennwallner 00004 * Copyright (C) 2009-2016 Peter Schüller 00005 * Copyright (C) 2011-2016 Christoph Redl 00006 * Copyright (C) 2015-2016 Tobias Kaminski 00007 * Copyright (C) 2015-2016 Antonius Weinzierl 00008 * 00009 * This file is part of dlvhex. 00010 * 00011 * dlvhex is free software; you can redistribute it and/or modify it 00012 * under the terms of the GNU Lesser General Public License as 00013 * published by the Free Software Foundation; either version 2.1 of 00014 * the License, or (at your option) any later version. 00015 * 00016 * dlvhex is distributed in the hope that it will be useful, but 00017 * WITHOUT ANY WARRANTY; without even the implied warranty of 00018 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00019 * Lesser General Public License for more details. 00020 * 00021 * You should have received a copy of the GNU Lesser General Public 00022 * License along with dlvhex; if not, write to the Free Software 00023 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 00024 * 02110-1301 USA. 00025 */ 00026 00035 #ifndef UNFOUNDEDSETCHECKHEURISTICSINTERFACE_H 00036 #define UNFOUNDEDSETCHECKHEURISTICSINTERFACE_H 00037 00038 #include "dlvhex2/PlatformDefinitions.h" 00039 #include "dlvhex2/fwd.h" 00040 #include "dlvhex2/ID.h" 00041 #include "dlvhex2/Registry.h" 00042 #include "dlvhex2/AnnotatedGroundProgram.h" 00043 00044 #include <boost/unordered_map.hpp> 00045 #include <boost/shared_ptr.hpp> 00046 00047 DLVHEX_NAMESPACE_BEGIN 00048 00058 // ============================== Base ============================== 00059 00063 class DLVHEX_EXPORT UnfoundedSetCheckHeuristics 00064 { 00065 protected: 00069 RegistryPtr reg; 00070 00072 const AnnotatedGroundProgram& groundProgram; 00073 00075 InterpretationPtr previouslyAssignedAndVerifiedAtoms; 00076 00078 InterpretationPtr notYetVerifiedExternalAtoms; 00079 00081 std::map<IDAddress, std::set<int> > rulesOfAtom; 00082 00084 std::vector<int> atomsInRule, assignedAndVerifiedAtomsInRule; 00085 00087 std::set<ID> skipProgram; 00088 public: 00089 UnfoundedSetCheckHeuristics(const AnnotatedGroundProgram& groundProgram, RegistryPtr reg); 00090 00100 virtual bool doUFSCheck(InterpretationConstPtr verifiedAuxes, InterpretationConstPtr partialAssignment, InterpretationConstPtr assigned, InterpretationConstPtr changed) = 0; 00101 00110 virtual void notify(InterpretationConstPtr verifiedAuxes, InterpretationConstPtr partialAssignment, InterpretationConstPtr assigned, InterpretationConstPtr changed); 00111 00121 void updateSkipProgram(InterpretationConstPtr verifiedAuxes, InterpretationConstPtr partialAssignment, InterpretationConstPtr assigned, InterpretationConstPtr changed); 00122 00129 inline const std::set<ID>& getSkipProgram() const { return skipProgram; } 00130 }; 00131 00132 typedef boost::shared_ptr<UnfoundedSetCheckHeuristics> UnfoundedSetCheckHeuristicsPtr; 00133 00137 class DLVHEX_EXPORT UnfoundedSetCheckHeuristicsFactory 00138 { 00139 public: 00145 virtual UnfoundedSetCheckHeuristicsPtr createHeuristics(const AnnotatedGroundProgram& groundProgram, RegistryPtr reg) = 0; 00146 00150 virtual ~UnfoundedSetCheckHeuristicsFactory(){} 00151 }; 00152 00153 typedef boost::shared_ptr<UnfoundedSetCheckHeuristicsFactory> UnfoundedSetCheckHeuristicsFactoryPtr; 00154 00155 DLVHEX_NAMESPACE_END 00156 #endif 00157 00158 // vim:expandtab:ts=4:sw=4: 00159 // mode: C++ 00160 // End: