Changeset 67db80 for src/Fragmentation


Ignore:
Timestamp:
Dec 13, 2012, 9:32:50 AM (13 years ago)
Author:
Frederik Heber <heber@…>
Branches:
Action_Thermostats, Add_AtomRandomPerturbation, Add_FitFragmentPartialChargesAction, Add_RotateAroundBondAction, Add_SelectAtomByNameAction, Added_ParseSaveFragmentResults, AddingActions_SaveParseParticleParameters, Adding_Graph_to_ChangeBondActions, Adding_MD_integration_tests, Adding_ParticleName_to_Atom, Adding_StructOpt_integration_tests, AtomFragments, Automaking_mpqc_open, AutomationFragmentation_failures, Candidate_v1.5.4, Candidate_v1.6.0, Candidate_v1.6.1, Candidate_v1.7.0, ChangeBugEmailaddress, ChangingTestPorts, ChemicalSpaceEvaluator, CombiningParticlePotentialParsing, Combining_Subpackages, Debian_Package_split, Debian_package_split_molecuildergui_only, Disabling_MemDebug, Docu_Python_wait, EmpiricalPotential_contain_HomologyGraph, EmpiricalPotential_contain_HomologyGraph_documentation, Enable_parallel_make_install, Enhance_userguide, Enhanced_StructuralOptimization, Enhanced_StructuralOptimization_continued, Example_ManyWaysToTranslateAtom, Exclude_Hydrogens_annealWithBondGraph, FitPartialCharges_GlobalError, Fix_BoundInBox_CenterInBox_MoleculeActions, Fix_ChargeSampling_PBC, Fix_ChronosMutex, Fix_FitPartialCharges, Fix_FitPotential_needs_atomicnumbers, Fix_ForceAnnealing, Fix_IndependentFragmentGrids, Fix_ParseParticles, Fix_ParseParticles_split_forward_backward_Actions, Fix_PopActions, Fix_QtFragmentList_sorted_selection, Fix_Restrictedkeyset_FragmentMolecule, Fix_StatusMsg, Fix_StepWorldTime_single_argument, Fix_Verbose_Codepatterns, Fix_fitting_potentials, Fixes, ForceAnnealing_goodresults, ForceAnnealing_oldresults, ForceAnnealing_tocheck, ForceAnnealing_with_BondGraph, ForceAnnealing_with_BondGraph_continued, ForceAnnealing_with_BondGraph_continued_betteresults, ForceAnnealing_with_BondGraph_contraction-expansion, FragmentAction_writes_AtomFragments, FragmentMolecule_checks_bonddegrees, GeometryObjects, Gui_Fixes, Gui_displays_atomic_force_velocity, ImplicitCharges, IndependentFragmentGrids, IndependentFragmentGrids_IndividualZeroInstances, IndependentFragmentGrids_IntegrationTest, IndependentFragmentGrids_Sole_NN_Calculation, JobMarket_RobustOnKillsSegFaults, JobMarket_StableWorkerPool, JobMarket_unresolvable_hostname_fix, MoreRobust_FragmentAutomation, ODR_violation_mpqc_open, PartialCharges_OrthogonalSummation, PdbParser_setsAtomName, PythonUI_with_named_parameters, QtGui_reactivate_TimeChanged_changes, Recreated_GuiChecks, Rewrite_FitPartialCharges, RotateToPrincipalAxisSystem_UndoRedo, SaturateAtoms_findBestMatching, SaturateAtoms_singleDegree, StoppableMakroAction, Subpackage_CodePatterns, Subpackage_JobMarket, Subpackage_LinearAlgebra, Subpackage_levmar, Subpackage_mpqc_open, Subpackage_vmg, Switchable_LogView, ThirdParty_MPQC_rebuilt_buildsystem, TrajectoryDependenant_MaxOrder, TremoloParser_IncreasedPrecision, TremoloParser_MultipleTimesteps, TremoloParser_setsAtomName, Ubuntu_1604_changes, stable
Children:
12a24c
Parents:
e15ffe
git-author:
Frederik Heber <heber@…> (09/27/12 13:23:40)
git-committer:
Frederik Heber <heber@…> (12/13/12 09:32:50)
Message:

Added serialization capabilities to FragmentEdge, FragmentNode, and HomologyGraph.

  • also added unit test function for each.
Location:
src/Fragmentation/Homology
Files:
14 edited

Legend:

Unmodified
Added
Removed
  • src/Fragmentation/Homology/FragmentEdge.cpp

    re15ffe r67db80  
    3434#include <config.h>
    3535#endif
     36
     37// include headers that implement a archive in simple text format
     38// otherwise BOOST_CLASS_EXPORT_IMPLEMENT has no effect
     39#include <boost/archive/text_oarchive.hpp>
     40#include <boost/archive/text_iarchive.hpp>
    3641
    3742#include "CodePatterns/MemDebug.hpp"
     
    118123  return out;
    119124}
     125
     126
     127// we need to explicitly instantiate the serialization functions
     128BOOST_CLASS_EXPORT_IMPLEMENT(FragmentEdge)
  • src/Fragmentation/Homology/FragmentEdge.hpp

    re15ffe r67db80  
    1313#include <config.h>
    1414#endif
     15
     16#include <boost/serialization/export.hpp>
     17#include <boost/serialization/utility.hpp>
    1518
    1619#include <iosfwd>
     
    4245  //!> stores the atomic number of either FragmentNode making up the edge
    4346  const AtomicNumberPair_t AtomicNumberPair;
     47
     48private:
     49  friend class boost::serialization::access;
     50  // serialization
     51  template <typename Archive>
     52  void serialize(Archive& ar, const unsigned int version)
     53  {
     54    ar & const_cast<AtomicNumberPair_t &>(AtomicNumberPair);
     55  }
    4456};
     57
     58// we need to give this class a unique key for serialization
     59BOOST_CLASS_EXPORT_KEY(FragmentEdge)
    4560
    4661std::ostream& operator<<(std::ostream &out, const FragmentEdge &node);
  • src/Fragmentation/Homology/FragmentNode.cpp

    re15ffe r67db80  
    3434#include <config.h>
    3535#endif
     36
     37// include headers that implement a archive in simple text format
     38// otherwise BOOST_CLASS_EXPORT_IMPLEMENT has no effect
     39#include <boost/archive/text_oarchive.hpp>
     40#include <boost/archive/text_iarchive.hpp>
    3641
    3742#include "CodePatterns/MemDebug.hpp"
     
    102107  return out;
    103108}
     109
     110
     111// we need to explicitly instantiate the serialization functions
     112BOOST_CLASS_EXPORT_IMPLEMENT(FragmentNode)
  • src/Fragmentation/Homology/FragmentNode.hpp

    re15ffe r67db80  
    1313#include <config.h>
    1414#endif
     15
     16#include <boost/serialization/export.hpp>
    1517
    1618#include <iosfwd>
     
    7173  //!> number of connecting edges
    7274  const size_t ConnectedEdges;
     75
     76private:
     77  friend class boost::serialization::access;
     78  // serialization
     79  template <typename Archive>
     80  void serialize(Archive& ar, const unsigned int version)
     81  {
     82    ar & const_cast<size_t &>(AtomicNumber);
     83    ar & const_cast<size_t &>(ConnectedEdges);
     84  }
    7385};
     86
     87// we need to give this class a unique key for serialization
     88BOOST_CLASS_EXPORT_KEY(FragmentNode)
    7489
    7590std::ostream& operator<<(std::ostream &out, const FragmentNode &node);
  • src/Fragmentation/Homology/HomologyGraph.cpp

    re15ffe r67db80  
    3434#include <config.h>
    3535#endif
     36
     37// include headers that implement a archive in simple text format
     38// otherwise BOOST_CLASS_EXPORT_IMPLEMENT has no effect
     39#include <boost/archive/text_oarchive.hpp>
     40#include <boost/archive/text_iarchive.hpp>
    3641
    3742#include "CodePatterns/MemDebug.hpp"
     
    106111}
    107112
     113// we need to explicitly instantiate the serialization functions
     114BOOST_CLASS_EXPORT_IMPLEMENT(HomologyGraph)
     115
  • src/Fragmentation/Homology/HomologyGraph.hpp

    re15ffe r67db80  
    1414#include <config.h>
    1515#endif
     16
     17#include <boost/serialization/export.hpp>
     18#include <boost/serialization/set.hpp>
    1619
    1720#include <set>
     
    9598  //!> information on the edges of the graph
    9699  const edges_t edges;
     100
     101private:
     102  friend class boost::serialization::access;
     103  // serialization
     104  template <typename Archive>
     105  void serialize(Archive& ar, const unsigned int version)
     106  {
     107    ar & const_cast<nodes_t &>(nodes);
     108    ar & const_cast<edges_t &>(edges);
     109  }
    97110};
    98111
    99112std::ostream& operator<<(std::ostream& ost, const HomologyGraph &graph);
     113
     114// we need to give this class a unique key for serialization
     115BOOST_CLASS_EXPORT_KEY(HomologyGraph)
    100116
    101117// define some helpers outside to allow for light-weight unit testing
  • src/Fragmentation/Homology/HomologyGraph_getFromKeyset.cpp

    re15ffe r67db80  
    4747#include "World.hpp"
    4848
     49// we have placed these functions into an extra module to allow compiling the
     50// unit tests which do no require them against dummy units which do not pull
     51// in all the cludder of World, atom, molecule, and so on ...
     52
    4953namespace detail {
    5054  const HomologyGraph::nodes_t getNodesFromKeySet(const KeySet &keyset)
  • src/Fragmentation/Homology/unittests/FragmentEdgeUnitTest.cpp

    re15ffe r67db80  
    4848
    4949#include "CodePatterns/Assert.hpp"
     50
     51#include <sstream>
    5052
    5153#ifdef HAVE_TESTRUNNER
     
    134136  CPPUNIT_ASSERT( edge == edge);
    135137}
     138
     139
     140/** UnitTest for serialization
     141 */
     142void FragmentEdgeTest::serializeTest()
     143{
     144  FragmentEdge edge(1,1);
     145  // serialize
     146  std::stringstream outputstream;
     147  boost::archive::text_oarchive oa(outputstream);
     148  oa << edge;
     149
     150  // deserialize
     151  FragmentEdge sameedge;
     152  std::stringstream returnstream(outputstream.str());
     153  boost::archive::text_iarchive ia(returnstream);
     154  ia >> sameedge;
     155
     156  CPPUNIT_ASSERT( edge == sameedge );
     157}
  • src/Fragmentation/Homology/unittests/FragmentEdgeUnitTest.hpp

    re15ffe r67db80  
    2626    CPPUNIT_TEST ( comparatorTest );
    2727    CPPUNIT_TEST ( assignmentTest );
     28    CPPUNIT_TEST ( serializeTest );
    2829    CPPUNIT_TEST_SUITE_END();
    2930
     
    3334      void comparatorTest();
    3435      void assignmentTest();
     36      void serializeTest();
    3537
    3638};
  • src/Fragmentation/Homology/unittests/FragmentNodeUnitTest.cpp

    re15ffe r67db80  
    4949
    5050#include "CodePatterns/Assert.hpp"
     51#include <sstream>
    5152
    5253#ifdef HAVE_TESTRUNNER
     
    135136  CPPUNIT_ASSERT( node == node);
    136137}
     138
     139
     140/** UnitTest for serialization
     141 */
     142void FragmentNodeTest::serializeTest()
     143{
     144  FragmentNode node(1,1);
     145  // serialize
     146  std::stringstream outputstream;
     147  boost::archive::text_oarchive oa(outputstream);
     148  oa << node;
     149
     150  // deserialize
     151  FragmentNode samenode;
     152  std::stringstream returnstream(outputstream.str());
     153  boost::archive::text_iarchive ia(returnstream);
     154  ia >> samenode;
     155
     156  CPPUNIT_ASSERT( node == samenode );
     157}
  • src/Fragmentation/Homology/unittests/FragmentNodeUnitTest.hpp

    re15ffe r67db80  
    2626    CPPUNIT_TEST ( comparatorTest );
    2727    CPPUNIT_TEST ( assignmentTest );
     28    CPPUNIT_TEST ( serializeTest );
    2829    CPPUNIT_TEST_SUITE_END();
    2930
     
    3334      void comparatorTest();
    3435      void assignmentTest();
     36      void serializeTest();
    3537};
    3638
  • src/Fragmentation/Homology/unittests/HomologyGraphUnitTest.cpp

    re15ffe r67db80  
    5151
    5252#include <boost/assign.hpp>
     53#include <sstream>
    5354
    5455using namespace boost::assign;
     
    147148  CPPUNIT_ASSERT( *graph == *graph);
    148149}
     150
     151
     152/** UnitTest for serialization
     153 */
     154void HomologyGraphTest::serializeTest()
     155{
     156  // serialize
     157  std::stringstream outputstream;
     158  boost::archive::text_oarchive oa(outputstream);
     159  oa << graph;
     160
     161  // deserialize
     162  HomologyGraph *samegraph;
     163  std::stringstream returnstream(outputstream.str());
     164  boost::archive::text_iarchive ia(returnstream);
     165  ia >> samegraph;
     166
     167  CPPUNIT_ASSERT( *graph == *samegraph );
     168
     169  delete samegraph;
     170}
  • src/Fragmentation/Homology/unittests/HomologyGraphUnitTest.hpp

    re15ffe r67db80  
    2929    CPPUNIT_TEST ( comparatorTest );
    3030    CPPUNIT_TEST ( assigmentTest );
     31    CPPUNIT_TEST ( serializeTest );
    3132    CPPUNIT_TEST_SUITE_END();
    3233
     
    3637      void comparatorTest();
    3738      void assigmentTest();
     39      void serializeTest();
    3840
    3941private:
  • src/Fragmentation/Homology/unittests/Makefile.am

    re15ffe r67db80  
    2828        ../libMolecuilderHelpers.la \
    2929        ${CodePatterns_LIBS} \
     30  $(BOOST_SERIALIZATION_LDFLAGS) $(BOOST_SERIALIZATION_LIBS) \
    3031        $(BOOST_LIB)
    3132
     
    3940        ../Fragmentation/Homology/unittests/FragmentNodeUnitTest.hpp
    4041FragmentNodeUnitTest_LDADD = ${FRAGMENTATIONHOMOLOGYLIBS}
    41 
     42       
    4243HomologyContainerUnitTest_SOURCES = $(top_srcdir)/src/unittests/UnitTestMain.cpp \
    4344        ../Fragmentation/Homology/unittests/HomologyContainerUnitTest.cpp \
Note: See TracChangeset for help on using the changeset viewer.