- Timestamp:
- Nov 7, 2011, 4:13:18 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:
- f894fe
- Parents:
- 55f299
- git-author:
- Frederik Heber <heber@…> (11/02/11 01:13:59)
- git-committer:
- Frederik Heber <heber@…> (11/07/11 16:13:18)
- Location:
- src/Actions
- Files:
-
- 3 added
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Actions/GlobalListOfActions.hpp
r55f299 rf89b45 48 48 (ParserSetParserParameters) \ 49 49 (ParserSetOutputFormats) \ 50 (AnalysisCalculateBoundingBox) \ 50 51 (AnalysisCalculateCellVolume) \ 51 52 (AnalysisCalculateMolarMass) \ -
src/Actions/Makefile.am
r55f299 rf89b45 87 87 88 88 ANALYSISACTIONSOURCE = \ 89 Actions/AnalysisAction/CalculateBoundingBoxAction.cpp \ 89 90 Actions/AnalysisAction/CalculateCellVolumeAction.cpp \ 90 91 Actions/AnalysisAction/CalculateMolarMassAction.cpp \ … … 97 98 Actions/AnalysisAction/SurfaceCorrelationAction.cpp 98 99 ANALYSISACTIONHEADER = \ 100 Actions/AnalysisAction/CalculateBoundingBoxAction.hpp \ 99 101 Actions/AnalysisAction/CalculateCellVolumeAction.hpp \ 100 102 Actions/AnalysisAction/CalculateMolarMassAction.hpp \ … … 107 109 Actions/AnalysisAction/SurfaceCorrelationAction.hpp 108 110 ANALYSISACTIONDEFS = \ 111 Actions/AnalysisAction/CalculateBoundingBoxAction.def \ 109 112 Actions/AnalysisAction/CalculateCellVolumeAction.def \ 110 113 Actions/AnalysisAction/CalculateMolarMassAction.def \ -
src/Actions/pyMoleCuilder.cpp
r55f299 rf89b45 61 61 } 62 62 63 } /* namespace detail */ 64 65 namespace PythonTypes { 66 67 inline void IndexError(){ 68 PyErr_SetString(PyExc_IndexError, "Index out of range"); 69 boost::python::throw_error_already_set(); 70 } 71 72 template<class T> 73 struct vec_item{ 74 typedef typename T::value_type V; 75 static V& get(T& x, int i){ 76 static V nothing; 77 if(i < 0) i += x.size(); 78 if(i >= 0 && i < int(x.size())) return x[i]; 79 IndexError(); 80 return nothing; 81 } 82 static void set(T& x, int i, V const& v){ 83 if(i < 0) i += x.size(); 84 if(i >= 0 && i < int(x.size())) x[i] = v; 85 else IndexError(); 86 } 87 static void del(T& x, int i){ 88 if(i < 0) i += x.size(); 89 if(i >= 0 && i < int(x.size())) x.erase(x.begin() + i); 90 else IndexError(); 91 } 92 static void add(T& x, V const& v){ 93 x.push_back(v); 94 } 95 }; 96 97 98 } /* namespace PythonTypes */ 63 99 } /* namespace MoleCuilder */ 64 } /* namespace detail */65 100 66 101 BOOST_PYTHON_MODULE(pyMoleCuilder) … … 77 112 78 113 boost::python::def("reinit", MoleCuilder::detail::module_reinit, "Reinitializes the internal state of the python module as if it had been freshly imported, saves all input files beforehand."); 114 115 // STL Vectors: 116 // doubleVec 117 boost::python::class_< std::vector< double > >("PythonType_doubleVec") 118 .def("__len__", &std::vector< double >::size) 119 .def("clear", &std::vector< double >::clear) 120 .def("append", &MoleCuilder::PythonTypes::vec_item< std::vector< double > >::add, 121 boost::python::with_custodian_and_ward<1, 2>()) // let container keep value 122 .def("__getitem__", &MoleCuilder::PythonTypes::vec_item< std::vector< double > >::get, 123 boost::python::return_value_policy<boost::python::copy_non_const_reference>()) 124 .def("__setitem__", &MoleCuilder::PythonTypes::vec_item< std::vector< double > >::set, 125 boost::python::with_custodian_and_ward<1,2>()) // to let container keep value 126 .def("__delitem__", &MoleCuilder::PythonTypes::vec_item< std::vector< double > >::del) 127 .def("__iter__", boost::python::iterator< std::vector< double > >()) 128 ; 129 130 79 131 #define export_print(z,n,list) \ 80 132 BOOST_PP_CAT(export_, BOOST_PP_SEQ_ELEM(n, list))();
Note:
See TracChangeset
for help on using the changeset viewer.