/* * KeySetsContainer.hpp * * Created on: Sep 15, 2011 * Author: heber */ #ifndef KEYSETSCONTAINER_HPP_ #define KEYSETSCONTAINER_HPP_ // include config.h #ifdef HAVE_CONFIG_H #include #endif #include "boost/serialization/vector.hpp" #include /** Contains the index set for each fragment. * */ class KeySetsContainer { public: typedef std::vector IntVector; typedef std::vector ArrayOfIntVectors; ArrayOfIntVectors KeySets; IntVector AtomCounter; int FragmentCounter; int Order; IntVector FragmentsPerOrder; ArrayOfIntVectors OrderSet; KeySetsContainer(); ~KeySetsContainer(); bool ParseKeySets(const std::string path, const std::string name, const int FCounter); bool ParseManyBodyTerms(); bool Contains(const int GreaterSet, const int SmallerSet); bool operator==(const KeySetsContainer &other) const; bool operator!=(const KeySetsContainer &other) const { return !(*this == other); } private: friend class boost::serialization::access; // serialization template void serialize(Archive & ar, const unsigned int version) { ar & KeySets; ar & AtomCounter; ar & FragmentCounter; ar & Order; ar & FragmentsPerOrder; ar & OrderSet; } }; #endif /* KEYSETSCONTAINER_HPP_ */