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 00034 #ifndef EXTERNALATOMVERIFICATIONTREE_H_INCLUDED__ 00035 #define EXTERNALATOMVERIFICATIONTREE_H_INCLUDED__ 00036 00037 #include "dlvhex2/PlatformDefinitions.h" 00038 #include "dlvhex2/fwd.h" 00039 #include "dlvhex2/ID.h" 00040 #include "dlvhex2/Registry.h" 00041 #include "dlvhex2/Nogood.h" 00042 00043 #include <boost/unordered_map.hpp> 00044 #include <boost/shared_ptr.hpp> 00045 00046 DLVHEX_NAMESPACE_BEGIN 00047 00056 class ExternalAtomVerificationTree{ 00057 public: 00059 struct Node{ 00060 typedef boost::shared_ptr<Node> Ptr; 00062 ID label; 00064 InterpretationPtr verified; 00066 std::vector<Ptr> childNodes; 00067 }; 00068 typedef Node::Ptr NodePtr; 00069 NodePtr root; 00071 ExternalAtomVerificationTree(); 00076 void addNogood(const Nogood& iong, RegistryPtr reg, bool includeNegated); 00081 std::string toString(RegistryPtr reg, int indent = 0, NodePtr root = NodePtr()); 00087 InterpretationConstPtr getVerifiedAuxiliaries(InterpretationConstPtr partialInterpretation, InterpretationConstPtr assigned, RegistryPtr reg); 00088 private: 00095 void getVerifiedAuxiliaries(NodePtr current, InterpretationPtr output, InterpretationConstPtr partialInterpretation, InterpretationConstPtr assigned, RegistryPtr reg); 00096 }; 00097 00098 DLVHEX_NAMESPACE_END 00099 #endif // GUESSANDCHECK_MODEL_GENERATOR_HPP_INCLUDED__09112010 00100 00101 // vim:expandtab:ts=4:sw=4: 00102 // mode: C++ 00103 // End: