- Timestamp:
- May 3, 2013, 9:46:45 AM (12 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:
- a86666
- Parents:
- 5281ff
- git-author:
- Frederik Heber <heber@…> (04/05/13 15:09:16)
- git-committer:
- Frederik Heber <heber@…> (05/03/13 09:46:45)
- Location:
- src/Jobs
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Jobs/InterfaceVMGJob.cpp
r5281ff re2925fd 71 71 vmg_float _box_end, 72 72 const int& near_field_cells, 73 const ImportParticles_t _ImportParticles, 73 74 const bool _DoPrintDebug, 74 75 int coarseningSteps, … … 80 81 returndata(_returndata), 81 82 level(levelMax), 83 ImportParticles(_ImportParticles), 82 84 DoPrintDebug(_DoPrintDebug) 83 85 { … … 134 136 VMG::MG::GetFactory().GetObjectStorageVal<int>("PARTICLE_NEAR_FIELD_CELLS"))); 135 137 136 // create smeared-out particle charges on particle_grid via splines 137 LOG(1, "INFO: Creating particle grid for " << particles.size() << " particles."); 138 for (std::list<Particle::Particle>::iterator iter = particles.begin(); 139 iter != particles.end(); ++iter) { 140 LOG(2, "DEBUG: Current particle is at " << (*iter).Pos() 141 << " with charge " << (*iter).Charge() << "."); 142 spl.SetSpline(particle_grid, *iter); 138 if (ImportParticles == DoImportParticles) { 139 // create smeared-out particle charges on particle_grid via splines 140 LOG(1, "INFO: Creating particle grid for " << particles.size() << " particles."); 141 for (std::list<Particle::Particle>::iterator iter = particles.begin(); 142 iter != particles.end(); ++iter) { 143 LOG(2, "DEBUG: Current particle is at " << (*iter).Pos() 144 << " with charge " << (*iter).Charge() << "."); 145 spl.SetSpline(particle_grid, *iter); 146 } 143 147 } 144 148 … … 155 159 grid, 156 160 sampled_input, 157 -1.);161 1.); 158 162 159 163 if (DoPrintDebug) { … … 360 364 comm.PrintStringOnce("E_total*: %e", e_long + e_short_peak + e_short_spline - e_self); 361 365 362 returndata.e_long = e; 366 returndata.nuclei_long = e_long; 367 returndata.electron_long = e_long; 363 368 } -
src/Jobs/InterfaceVMGJob.hpp
r5281ff re2925fd 36 36 { 37 37 public: 38 enum ImportParticles_t { 39 DontImportParticles=0, 40 DoImportParticles=1, 41 }; 42 38 43 InterfaceVMGJob(const SamplingGrid &_sampled_input, 39 44 VMGData &returndata, … … 46 51 vmg_float _box_end, 47 52 const int& near_field_cells, 53 const ImportParticles_t _ImportParticles=DoImportParticles, 48 54 const bool _DoPrintDebug=false, 49 55 int coarseningSteps=0, … … 74 80 double box_end[3]; 75 81 82 //!> whether we import particles (true) or evaluate only 83 const ImportParticles_t ImportParticles; 84 76 85 //!> whether we do print grid for debug visualization or not 77 86 const bool DoPrintDebug; -
src/Jobs/VMGJob.cpp
r5281ff re2925fd 83 83 const size_t _near_field_cells, 84 84 const size_t _interpolation_degree, 85 const bool _DoImportParticles, 85 86 const bool _DoPrintDebug) : 86 87 FragmentJob(_JobId), … … 90 91 near_field_cells(_near_field_cells), 91 92 interpolation_degree(_interpolation_degree), 93 DoImportParticles(_DoImportParticles), 94 DoPrintDebug(_DoPrintDebug), 92 95 returndata(static_cast<const SamplingGridProperties &>(_density_grid)), 93 particles(), 94 DoPrintDebug(_DoPrintDebug) 96 particles() 95 97 {} 96 98 … … 99 101 near_field_cells(3), 100 102 interpolation_degree(3), 101 particles(), 102 DoPrintDebug(false) 103 DoImportParticles(true), 104 DoPrintDebug(false), 105 particles() 103 106 {} 104 107 … … 220 223 density_grid.end[0]-density_grid.begin[0], 221 224 near_field_cells, 225 DoImportParticles ? 226 VMGInterfaces::InterfaceVMGJob::DoImportParticles 227 : VMGInterfaces::InterfaceVMGJob::DontImportParticles, 222 228 DoPrintDebug); 223 229 new LevelOperatorCS(Stencils::RestrictionFullWeight, Stencils::InterpolationTrilinear); -
src/Jobs/VMGJob.hpp
r5281ff re2925fd 42 42 * @param _interpolation_degree degree of interpolation polynomial for getting nuclei 43 43 * potential from grid 44 * @param _DoImportParticles whether we import particles (true) or evaluate only 44 45 * @param _DoPrintDebug whether we do print grid for debug visualization or not 45 46 */ … … 50 51 const size_t _near_field_cells, 51 52 const size_t _interpolation_degree, 53 const bool _DoImportParticles=true, 52 54 const bool _DoPrintDebug=false 53 55 ); … … 72 74 //!> interpolation degree used in sampling the potential of the nuclei 73 75 const size_t interpolation_degree; 76 //!> whether we import particles (true) or evaluate only 77 const bool DoImportParticles; 74 78 //!> whether we do print grid for debug visualization or not 75 79 const bool DoPrintDebug; … … 124 128 ar & const_cast< size_t &>(near_field_cells); 125 129 ar & const_cast< size_t &>(interpolation_degree); 130 ar & const_cast< bool &>(DoImportParticles); 126 131 ar & const_cast< bool &>(DoPrintDebug); 127 132 ar & returndata;
Note:
See TracChangeset
for help on using the changeset viewer.