Changeset 6625c3 for src/molecule_dynamics.cpp
- Timestamp:
- Feb 24, 2011, 5:46:46 PM (14 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:
- 056e70
- Parents:
- 54b42e
- git-author:
- Frederik Heber <heber@…> (02/24/11 11:18:59)
- git-committer:
- Frederik Heber <heber@…> (02/24/11 17:46:46)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/molecule_dynamics.cpp
r54b42e r6625c3 60 60 // determine normalized trajectories direction vector (n1, n2) 61 61 Sprinter = Params.PermutationMap[Walker->nr]; // find first target point 62 trajectory1 = Sprinter-> Trajectory.R.at(Params.endstep) - Walker->Trajectory.R.at(Params.startstep);62 trajectory1 = Sprinter->getPosition(Params.endstep) - Walker->getPosition(Params.startstep); 63 63 trajectory1.Normalize(); 64 64 Norm1 = trajectory1.Norm(); 65 65 Sprinter = Params.PermutationMap[(*iter)->nr]; // find second target point 66 trajectory2 = Sprinter-> Trajectory.R.at(Params.endstep) - (*iter)->Trajectory.R.at(Params.startstep);66 trajectory2 = Sprinter->getPosition(Params.endstep) - (*iter)->getPosition(Params.startstep); 67 67 trajectory2.Normalize(); 68 68 Norm2 = trajectory1.Norm(); 69 69 // check whether either is zero() 70 70 if ((Norm1 < MYEPSILON) && (Norm2 < MYEPSILON)) { 71 tmp = Walker-> Trajectory.R.at(Params.startstep).distance((*iter)->Trajectory.R.at(Params.startstep));71 tmp = Walker->getPosition(Params.startstep).distance((*iter)->getPosition(Params.startstep)); 72 72 } else if (Norm1 < MYEPSILON) { 73 73 Sprinter = Params.PermutationMap[Walker->nr]; // find first target point 74 trajectory1 = Sprinter-> Trajectory.R.at(Params.endstep) - (*iter)->Trajectory.R.at(Params.startstep);74 trajectory1 = Sprinter->getPosition(Params.endstep) - (*iter)->getPosition(Params.startstep); 75 75 trajectory2 *= trajectory1.ScalarProduct(trajectory2); // trajectory2 is scaled to unity, hence we don't need to divide by anything 76 76 trajectory1 -= trajectory2; // project the part in norm direction away … … 78 78 } else if (Norm2 < MYEPSILON) { 79 79 Sprinter = Params.PermutationMap[(*iter)->nr]; // find second target point 80 trajectory2 = Sprinter-> Trajectory.R.at(Params.endstep) - Walker->Trajectory.R.at(Params.startstep); // copy second offset80 trajectory2 = Sprinter->getPosition(Params.endstep) - Walker->getPosition(Params.startstep); // copy second offset 81 81 trajectory1 *= trajectory2.ScalarProduct(trajectory1); // trajectory1 is scaled to unity, hence we don't need to divide by anything 82 82 trajectory2 -= trajectory1; // project the part in norm direction away … … 87 87 // Log() << Verbose(0) << " and "; 88 88 // Log() << Verbose(0) << trajectory2; 89 tmp = Walker-> Trajectory.R.at(Params.startstep).distance((*iter)->Trajectory.R.at(Params.startstep));89 tmp = Walker->getPosition(Params.startstep).distance((*iter)->getPosition(Params.startstep)); 90 90 // Log() << Verbose(0) << " with distance " << tmp << "." << endl; 91 91 } else { // determine distance by finding minimum distance … … 106 106 gsl_matrix_set(A, 1, i, trajectory2[i]); 107 107 gsl_matrix_set(A, 2, i, normal[i]); 108 gsl_vector_set(x,i, (Walker-> Trajectory.R.at(Params.startstep)[i] - (*iter)->Trajectory.R.at(Params.startstep)[i]));108 gsl_vector_set(x,i, (Walker->getPosition(Params.startstep)[i] - (*iter)->getPosition(Params.startstep)[i])); 109 109 } 110 110 // solve the linear system by Householder transformations … … 117 117 trajectory2.Scale(gsl_vector_get(x,1)); 118 118 normal.Scale(gsl_vector_get(x,2)); 119 TestVector = (*iter)-> Trajectory.R.at(Params.startstep) + trajectory2 + normal120 - (Walker-> Trajectory.R.at(Params.startstep) + trajectory1);119 TestVector = (*iter)->getPosition(Params.startstep) + trajectory2 + normal 120 - (Walker->getPosition(Params.startstep) + trajectory1); 121 121 if (TestVector.Norm() < MYEPSILON) { 122 122 // Log() << Verbose(2) << "Test: ok.\tDistance of " << tmp << " is correct." << endl; … … 150 150 // atom *Sprinter = PermutationMap[Walker->nr]; 151 151 // Log() << Verbose(0) << *Walker << " and " << *(*iter) << " are heading to the same target at "; 152 // Log() << Verbose(0) << Sprinter-> Trajectory.R.at(endstep);152 // Log() << Verbose(0) << Sprinter->getPosition(endstep); 153 153 // Log() << Verbose(0) << ", penalting." << endl; 154 154 result += Params.PenaltyConstants[2]; … … 183 183 // first term: distance to target 184 184 Runner = Params.PermutationMap[(*iter)->nr]; // find target point 185 tmp = ((*iter)-> Trajectory.R.at(Params.startstep).distance(Runner->Trajectory.R.at(Params.endstep)));185 tmp = ((*iter)->getPosition(Params.startstep).distance(Runner->getPosition(Params.endstep))); 186 186 tmp *= Params.IsAngstroem ? 1. : 1./AtomicLengthToAngstroem; 187 187 result += Params.PenaltyConstants[0] * tmp; … … 239 239 for (molecule::const_iterator iter = mol->begin(); iter != mol->end(); ++iter) { 240 240 for (molecule::const_iterator runner = mol->begin(); runner != mol->end(); ++runner) { 241 Params.DistanceList[(*iter)->nr]->insert( DistancePair((*iter)-> Trajectory.R.at(Params.startstep).distance((*runner)->Trajectory.R.at(Params.endstep)), (*runner)) );241 Params.DistanceList[(*iter)->nr]->insert( DistancePair((*iter)->getPosition(Params.startstep).distance((*runner)->getPosition(Params.endstep)), (*runner)) ); 242 242 } 243 243 } … … 489 489 // set forces 490 490 for (int i=NDIM;i++;) 491 Force->Matrix[0][_atom->nr][5+i] += 2.*constant*sqrt(_atom-> Trajectory.R.at(startstep).distance(Sprinter->Trajectory.R.at(endstep)));491 Force->Matrix[0][_atom->nr][5+i] += 2.*constant*sqrt(_atom->getPosition(startstep).distance(Sprinter->getPosition(endstep))); 492 492 } 493 493 DoLog(1) && (Log() << Verbose(1) << "done." << endl); … … 525 525 526 526 // check whether we have sufficient space in Trajectories for each atom 527 for_each(atoms.begin(),atoms.end(),bind2nd(mem_fun(&atom::ResizeTrajectory),MaxSteps)); 527 LOG(1, "STATUS: Extending each trajectory size to " << MaxSteps+1 << "."); 528 for_each(atoms.begin(),atoms.end(),bind2nd(mem_fun(&atom::ResizeTrajectory),MaxSteps+1)); 528 529 // push endstep to last one 529 530 for_each(atoms.begin(),atoms.end(),boost::bind(&atom::CopyStepOnStep,_1,MaxSteps,endstep)); … … 538 539 // add to molecule list 539 540 Sprinter = mol->AddCopyAtom((*iter)); 540 for (int n=NDIM;n--;) { 541 Sprinter->set(n, (*iter)->Trajectory.R.at(startstep)[n] + (PermutationMap[(*iter)->nr]->Trajectory.R.at(endstep)[n] - (*iter)->Trajectory.R.at(startstep)[n])*((double)step/(double)MaxSteps)); 542 // add to Trajectories 543 //Log() << Verbose(3) << step << ">=" << MDSteps-1 << endl; 544 if (step < MaxSteps) { 545 (*iter)->Trajectory.R.at(step)[n] = (*iter)->Trajectory.R.at(startstep)[n] + (PermutationMap[(*iter)->nr]->Trajectory.R.at(endstep)[n] - (*iter)->Trajectory.R.at(startstep)[n])*((double)step/(double)MaxSteps); 546 (*iter)->Trajectory.U.at(step)[n] = 0.; 547 (*iter)->Trajectory.F.at(step)[n] = 0.; 548 } 549 } 541 // add to Trajectories 542 Vector temp = (*iter)->getPosition(startstep) + (PermutationMap[(*iter)->nr]->getPosition(endstep) - (*iter)->getPosition(startstep))*((double)step/(double)MaxSteps); 543 Sprinter->setPosition(temp); 544 (*iter)->setAtomicVelocity(step, zeroVec); 545 (*iter)->setAtomicForce(step, zeroVec); 546 //Log() << Verbose(3) << step << ">=" << MDSteps-1 << endl; 550 547 } 551 548 } … … 620 617 // and perform Verlet integration for each atom with position, velocity and force vector 621 618 // check size of vectors 622 for_each(atoms.begin(),623 atoms.end(),624 boost::bind(&atom::VelocityVerletUpdate,_1,MDSteps+1, &configuration, &Force, (const size_t) 0));619 BOOST_FOREACH(atom *_atom, atoms) { 620 _atom->VelocityVerletUpdate(_atom->nr, MDSteps+1, &configuration, &Force, (const size_t) 0); 621 } 625 622 626 623 // correct velocities (rather momenta) so that center of mass remains motionless
Note:
See TracChangeset
for help on using the changeset viewer.