Changeset c2e567
- Timestamp:
- Oct 12, 2011, 2:10:57 PM (13 years ago)
- 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, 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:
- c074cc
- Parents:
- 29cbe9
- git-author:
- Frederik Heber <heber@…> (09/12/11 08:46:41)
- git-committer:
- Frederik Heber <heber@…> (10/12/11 14:10:57)
- Location:
- LinearAlgebra
- Files:
-
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
LinearAlgebra/configure.ac
r29cbe9 rc2e567 104 104 AC_CHECK_LIB(m, sqrt, , AC_MSG_ERROR([compatible libc math library not found])) 105 105 106 # CodePatterns library ( needs operator<<(.., range<>))107 AM_PATH_CODEPATTERNS([1. 0.13], $have_debug,,[AC_MSG_ERROR([Missing CodePatterns library, please specify PKG_CONFIG_PATH or use --with-codepatterns...])])106 # CodePatterns library (serialization header before MemDebug.hpp ) 107 AM_PATH_CODEPATTERNS([1.1.5], $have_debug,,[AC_MSG_ERROR([Missing CodePatterns library, please specify PKG_CONFIG_PATH or use --with-codepatterns...])]) 108 108 109 109 # boost -
LinearAlgebra/src/LinearAlgebra/RealSpaceMatrix.hpp
r29cbe9 rc2e567 14 14 #endif 15 15 16 #include "boost/serialization/access.hpp" 17 #include <boost/serialization/split_member.hpp> 18 //#include "boost/serialization/export.hpp" 16 19 17 20 #include <iosfwd> … … 156 159 bool operator==(const RealSpaceMatrix&) const; 157 160 161 bool operator!=(const RealSpaceMatrix &other) const { 162 return !(*this == other); 163 } 164 165 private: 166 friend class boost::serialization::access; 167 // serialization 168 template<class Archive> 169 void save(Archive & ar, const unsigned int version) const 170 { 171 ar & content; 172 } 173 template<class Archive> 174 void load(Archive & ar, const unsigned int version) 175 { 176 ar & content; 177 createViews(); 178 } 179 BOOST_SERIALIZATION_SPLIT_MEMBER() 180 158 181 private: 159 182 RealSpaceMatrix(MatrixContent*); 160 183 void createViews(); 184 161 185 MatrixContent *content; 162 186 // we keep around some Vector views of the matrix, to return references … … 165 189 Vector* diagonal_ptr; 166 190 }; 191 //BOOST_CLASS_EXPORT_GUID(RealSpaceMatrix, "RealSpaceMatrix") 167 192 168 193 const RealSpaceMatrix operator*(const double,const RealSpaceMatrix&); -
LinearAlgebra/src/unittests/Makefile.am
r29cbe9 rc2e567 74 74 RealSpaceMatrixUnitTest.cpp \ 75 75 RealSpaceMatrixUnitTest.hpp 76 RealSpaceMatrixUnitTest_LDADD = ${GSLLIBS} 76 RealSpaceMatrixUnitTest_LDADD = ${GSLLIBS} \ 77 $(BOOST_SERIALIZATION_LDFLAGS) $(BOOST_SERIALIZATION_LIBS) 77 78 78 79 VectorContentUnitTest_SOURCES = UnitTestMain.cpp \ -
LinearAlgebra/src/unittests/RealSpaceMatrixUnitTest.cpp
r29cbe9 rc2e567 27 27 #include "RealSpaceMatrixUnitTest.hpp" 28 28 29 // include headers that implement a archive in simple text format 30 #include <boost/archive/text_oarchive.hpp> 31 #include <boost/archive/text_iarchive.hpp> 32 29 33 #include "defs.hpp" 30 34 #include "Exceptions.hpp" 35 #include "MatrixContent.hpp" 31 36 #include "RealSpaceMatrix.hpp" 32 37 #include "Vector.hpp" … … 366 371 CPPUNIT_ASSERT_EQUAL((*perm5)*t,Vector(2,3,1)); 367 372 } 373 374 void RealSpaceMatrixTest::SerializationTest() 375 { 376 // write element to stream 377 std::stringstream stream; 378 boost::archive::text_oarchive oa(stream); 379 oa << diagonal; 380 381 //std::cout << "Contents of archive is " << stream.str() << std::endl; 382 383 // create and open an archive for input 384 boost::archive::text_iarchive ia(stream); 385 // read class state from archive 386 RealSpaceMatrix *newm; 387 388 ia >> newm; 389 390 CPPUNIT_ASSERT (*diagonal == *newm); 391 } -
LinearAlgebra/src/unittests/RealSpaceMatrixUnitTest.hpp
r29cbe9 rc2e567 30 30 CPPUNIT_TEST ( DeterminantTest ); 31 31 CPPUNIT_TEST ( VecMultTest ); 32 CPPUNIT_TEST ( SerializationTest ); 32 33 CPPUNIT_TEST_SUITE_END(); 33 34 … … 44 45 void DeterminantTest(); 45 46 void VecMultTest(); 47 void SerializationTest(); 46 48 47 49 RealSpaceMatrix *zero;
Note:
See TracChangeset
for help on using the changeset viewer.