Changeset 949953
- Timestamp:
- Nov 7, 2011, 12:23:52 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:
- c20b35
- Parents:
- 071243
- git-author:
- Frederik Heber <heber@…> (09/26/11 12:59:25)
- git-committer:
- Frederik Heber <heber@…> (11/07/11 12:23:52)
- Location:
- src
- Files:
-
- 4 added
- 5 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Actions/Makefile.am
r071243 r949953 407 407 libMolecuilderActionPrototypes_la_includedir = $(includedir)/MoleCuilder/Actions/ 408 408 409 BUILT_SOURCES += AllActionHeaders.hpp 409 BUILT_SOURCES += AllActionHeaders.hpp AllActionPython.hpp 410 410 411 411 # UIElements/libMolecuilderUI.la … … 459 459 echo "#endif /* ALLACTIONHEADERS_HPP_ */" >>$@; 460 460 461 AllActionPython.hpp: $(ACTIONPROTOTYPESHEADER) 462 echo "#ifndef ALLACTIONPYTHON_HPP_" >$@; \ 463 echo "#define ALLACTIONPYTHON_HPP_" >>$@; \ 464 for file in $(ACTIONPROTOTYPESHEADER); do \ 465 echo "#include \"`echo $$file | sed -e 's/hpp/def/'`\"" >>$@; \ 466 echo "#include \"Actions/Action_impl_python.hpp\"" >>$@; \ 467 echo "#include \"Actions/Action_impl_undef.hpp\"" >>$@; \ 468 done; \ 469 echo "#endif /* ALLACTIONPYTHON_HPP_ */" >>$@; 470 471 461 472 MOSTLYCLEANFILES += \ 462 AllActionHeaders.hpp 473 AllActionHeaders.hpp \ 474 AllActionPython.hpp -
src/Actions/pyMoleCuilder.cpp
r071243 r949953 18 18 #endif 19 19 20 #include <boost/python /def.hpp>20 #include <boost/python.hpp> 21 21 #include <boost/python/module.hpp> 22 22 #include <boost/python/args.hpp> … … 24 24 #include "CodePatterns/MemDebug.hpp" 25 25 26 #include "Actions/CommandAction/HelpAction.hpp" 26 //!> define all present actions 27 #include "GlobalListOfActions.hpp" 28 29 //!> python wrapping for all of these actions 30 #include "AllActionPython.hpp" 31 32 #include "cleanUp.hpp" 33 #include "Actions/ActionHistory.hpp" 34 27 35 28 36 BOOST_PYTHON_MODULE(pyMoleCuilder) 29 37 { 30 boost::python::def( 31 "CommandHelp", 32 MoleCuilder::CommandHelp, 33 boost::python::args("actionname"), 34 "this gives a list of all Actions." 35 ); 38 // need to init the history before any action is created 39 MoleCuilder::ActionHistory::init(); 40 41 // from this moment on, we need to be sure to deeinitialize in the correct order 42 // this is handled by the cleanup function 43 atexit(cleanUp); 44 45 // set the docstring of the current module scope 46 boost::python::scope().attr("__doc__") = "pyMolecuilder are the python bindings to all Actions of the program suite MoleCuilder.\n\nMoleCuilder is a program to build molecular (dynamics) worlds, allowing you indefinite manipulation, control and analysis over the atoms and molecules within a simulation domain."; 47 48 #define export_print(z,n,list) \ 49 BOOST_PP_CAT(export_, BOOST_PP_SEQ_ELEM(n, list))(); 50 #define BOOST_PP_LOCAL_MACRO(n) export_print(~, n, GLOBALLISTOFACTIONS) 51 #define BOOST_PP_LOCAL_LIMITS (0, BOOST_PP_DEC(BOOST_PP_SEQ_SIZE(GLOBALLISTOFACTIONS))) 52 #include BOOST_PP_LOCAL_ITERATE() 53 #undef instance_print 36 54 } -
src/Makefile.am
r071243 r949953 271 271 272 272 pyexec_LTLIBRARIES += pyMoleCuilder.la 273 pyMoleCuilder_la_SOURCES = Actions/pyMoleCuilder.cpp 273 pyMoleCuilder_la_SOURCES = \ 274 cleanUp.cpp \ 275 cleanUp.hpp \ 276 Actions/pyMoleCuilder.cpp 274 277 pyMoleCuilder_la_CPPFLAGS = ${BOOST_CPPFLAGS} ${CodePatterns_CFLAGS} -I$(PYTHON_INCLUDE_DIR) 275 278 pyMoleCuilder_la_LDFLAGS = -module -avoid-version -shared … … 284 287 #molecuilder_CXXFLAGS += -DNO_CACHING 285 288 molecuilder_LDFLAGS = $(AM_LDFLAGS) $(BOOST_FILESYSTEM_LDFLAGS) $(BOOST_PROGRAM_OPTIONS_LDFLAGS) $(BOOST_RANDOM_LDFLAGS) $(BOOST_SYSTEM_LDFLAGS) $(BOOST_THREAD_LDFLAGS) 286 molecuilder_SOURCES = builder.cpp builder_init.cpp builder_init.hpp 289 molecuilder_SOURCES = \ 290 builder.cpp \ 291 builder_init.cpp \ 292 builder_init.hpp \ 293 cleanUp.cpp \ 294 cleanUp.hpp 287 295 molecuilder_LDADD = \ 288 296 libMolecuilderUI.la \ … … 296 304 297 305 #Stuff for building the GUI using Qt 298 molecuildergui_SOURCES = builder.cpp builder_init.cpp builder_init.hpp 306 molecuildergui_SOURCES = \ 307 builder.cpp \ 308 builder_init.cpp \ 309 builder_init.hpp \ 310 cleanUp.cpp \ 311 cleanUp.hpp 299 312 molecuildergui_CXXFLAGS = $(AM_CPPFLAGS) -DUSE_GUI_QT 300 313 molecuildergui_LDFLAGS = $(AM_LDFLAGS) $(BOOST_FILESYSTEM_LDFLAGS) $(BOOST_PROGRAM_OPTIONS_LDFLAGS) $(BOOST_SYSTEM_LDFLAGS) $(BOOST_THREAD_LDFLAGS) -
src/builder_init.cpp
r071243 r949953 23 23 #include <iostream> 24 24 25 #include "config.hpp" 26 #include "molecule.hpp" 27 #include "World.hpp" 25 #include "Actions/ActionHistory.hpp" 26 #include "Actions/ActionExceptions.hpp" 28 27 29 #include "Actions/ActionExceptions.hpp" 30 #include "Actions/ActionHistory.hpp" 31 #include "Actions/ActionRegistry.hpp" 28 #include "builder_init.hpp" 29 #include "cleanUp.hpp" 32 30 33 #include "CodePatterns/Chronos.hpp"34 31 #include "CodePatterns/Log.hpp" 35 #include "Element/periodentafel.hpp" 32 36 33 #include "Graph/BondGraph.hpp" 34 37 35 #include "Parser/ChangeTracker.hpp" 38 36 #include "Parser/FormatParserStorage.hpp" 39 #include "RandomNumbers/RandomNumberDistributionFactory.hpp" 40 #include "RandomNumbers/RandomNumberEngineFactory.hpp" 41 #include "RandomNumbers/RandomNumberGeneratorFactory.hpp" 42 #include "Tesselation/tesselationhelpers.hpp" 37 38 #include "UIElements/UIFactory.hpp" 39 #include "UIElements/CommandLineUI/CommandLineParser.hpp" 43 40 #include "UIElements/CommandLineUI/CommandLineUIFactory.hpp" 44 #include "UIElements/CommandLineUI/CommandLineUIFactory.hpp"45 #include "UIElements/CommandLineUI/CommandLineParser.hpp"46 #include "UIElements/Dialog.hpp"47 #include "UIElements/MainWindow.hpp"48 #include "UIElements/Menu/MenuDescription.hpp"49 41 #ifdef USE_GUI_QT 50 42 #include "UIElements/Qt4/QtUIFactory.hpp" 51 43 #endif 52 44 #include "UIElements/TextUI/TextUIFactory.hpp" 53 #include "UIElements/ UIFactory.hpp"45 #include "UIElements/MainWindow.hpp" 54 46 55 47 #include "version.h" 56 48 57 #include "builder_init.hpp" 49 #include "World.hpp" 50 58 51 59 52 /** Print some initial information output the program. … … 148 141 } 149 142 150 151 /** In this function all dynamicly allocated member variables to static/global152 * variables are added to the ignore list of Memory/MemDebug.153 *154 * Use this to prevent their listing in the Memory::getState() at the end of the155 * program. Check with valgrind that truely no memory leak occurs!156 */157 void AddStaticEntitiestoIgnoreList()158 {159 // zeroVec and unitVec are global variables (on the stack) but vectorContent160 // within is situated on the heap and has to be ignored161 Memory::ignore(zeroVec.get());162 Memory::ignore(unitVec[0].get());163 Memory::ignore(unitVec[1].get());164 Memory::ignore(unitVec[2].get());165 }166 167 /** We give a list of all times per action and a total time.168 *169 */170 void printTimings()171 {172 const MoleCuilder::ActionRegistry &AR = MoleCuilder::ActionRegistry::getInstance();173 const Chronos &Chron = Chronos::getInstance();174 std::cout << "(Non-zero) Times used per Action [seconds]:" << std::endl;175 for (MoleCuilder::ActionRegistry::const_iterator iter = AR.getBeginIter(); iter != AR.getEndIter(); ++iter)176 if (Chron.getTime(iter->first) != 0.) { // dont give if action has not been used177 std::cout << " " << setiosflags(ios::left) << setw(24) << setfill('.') << iter->first;178 std::cout << setiosflags(ios::left) << setprecision(6) << fixed << Chron.getTime(iter->first) << std::endl;179 }180 std::cout << "Total Time: " << Chron.SumUpTotalTime() << " seconds" << std::endl;181 std::cout << "Total Actions called: " << Chron.SumUpTotalFunctions() << std::endl;182 }183 184 /** Cleans all singleton instances in an orderly fashion.185 * C++ does not guarantee any specific sequence of removal of single instances186 * which have static/global variables. Some singletons depend on others hence we187 * acertain a specific ordering here, which is is used via the atexit() hook.188 */189 void cleanUp()190 {191 printTimings();192 Chronos::purgeInstance();193 194 RandomNumberDistributionFactory::purgeInstance();195 RandomNumberEngineFactory::purgeInstance();196 RandomNumberGeneratorFactory::purgeInstance();197 FormatParserStorage::purgeInstance();198 ChangeTracker::purgeInstance();199 World::purgeInstance();200 MenuDescription::purgeInstance();201 UIFactory::purgeInstance();202 ValueStorage::purgeInstance();203 CommandLineParser::purgeInstance();204 MoleCuilder::ActionRegistry::purgeInstance();205 MoleCuilder::OptionRegistry::purgeInstance();206 MoleCuilder::ActionHistory::purgeInstance();207 // we have to remove these two static as otherwise their boost::shared_ptrs are still present208 MoleCuilder::Action::removeStaticStateEntities();209 // put some static variables' dynamic contents on the Memory::ignore map to avoid their210 // admonishing lateron211 AddStaticEntitiestoIgnoreList();212 logger::purgeInstance();213 errorLogger::purgeInstance();214 #ifdef LOG_OBSERVER215 cout << observerLog().getLog();216 #endif217 Memory::getState();218 }219 220 143 /** Dump current memory chunks. 221 144 * -
src/builder_init.hpp
r071243 r949953 20 20 void doUI(); 21 21 22 void AddStaticEntitiestoIgnoreList();23 void cleanUp();24 22 void dumpMemory(); 25 23
Note:
See TracChangeset
for help on using the changeset viewer.