Ignore:
Timestamp:
Feb 24, 2011, 5:46:46 PM (14 years ago)
Author:
Frederik Heber <heber@…>
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)
Message:

Removed atom_trajectoryparticle*, replaced by AtomInfo class now having std::vector<> for trajectories.

AtomInfo:

Other changes:

  • gsl_rng_gaussian() exchanged by boost::random specific type.
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/molecule_dynamics.cpp

    r54b42e r6625c3  
    6060    // determine normalized trajectories direction vector (n1, n2)
    6161    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);
    6363    trajectory1.Normalize();
    6464    Norm1 = trajectory1.Norm();
    6565    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);
    6767    trajectory2.Normalize();
    6868    Norm2 = trajectory1.Norm();
    6969    // check whether either is zero()
    7070    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));
    7272    } else if (Norm1 < MYEPSILON) {
    7373      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);
    7575      trajectory2 *= trajectory1.ScalarProduct(trajectory2); // trajectory2 is scaled to unity, hence we don't need to divide by anything
    7676      trajectory1 -= trajectory2;   // project the part in norm direction away
     
    7878    } else if (Norm2 < MYEPSILON) {
    7979      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 offset
     80      trajectory2 = Sprinter->getPosition(Params.endstep) - Walker->getPosition(Params.startstep);  // copy second offset
    8181      trajectory1 *= trajectory2.ScalarProduct(trajectory1); // trajectory1 is scaled to unity, hence we don't need to divide by anything
    8282      trajectory2 -= trajectory1;   // project the part in norm direction away
     
    8787  //        Log() << Verbose(0) << " and ";
    8888  //        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));
    9090  //        Log() << Verbose(0) << " with distance " << tmp << "." << endl;
    9191    } else { // determine distance by finding minimum distance
     
    106106        gsl_matrix_set(A, 1, i, trajectory2[i]);
    107107        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]));
    109109      }
    110110      // solve the linear system by Householder transformations
     
    117117      trajectory2.Scale(gsl_vector_get(x,1));
    118118      normal.Scale(gsl_vector_get(x,2));
    119       TestVector = (*iter)->Trajectory.R.at(Params.startstep) + trajectory2 + normal
    120                    - (Walker->Trajectory.R.at(Params.startstep) + trajectory1);
     119      TestVector = (*iter)->getPosition(Params.startstep) + trajectory2 + normal
     120                   - (Walker->getPosition(Params.startstep) + trajectory1);
    121121      if (TestVector.Norm() < MYEPSILON) {
    122122  //          Log() << Verbose(2) << "Test: ok.\tDistance of " << tmp << " is correct." << endl;
     
    150150  //    atom *Sprinter = PermutationMap[Walker->nr];
    151151  //        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);
    153153  //        Log() << Verbose(0) << ", penalting." << endl;
    154154      result += Params.PenaltyConstants[2];
     
    183183    // first term: distance to target
    184184    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)));
    186186    tmp *= Params.IsAngstroem ? 1. : 1./AtomicLengthToAngstroem;
    187187    result += Params.PenaltyConstants[0] * tmp;
     
    239239  for (molecule::const_iterator iter = mol->begin(); iter != mol->end(); ++iter) {
    240240    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)) );
    242242    }
    243243  }
     
    489489    // set forces
    490490    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)));
    492492  }
    493493  DoLog(1) && (Log() << Verbose(1) << "done." << endl);
     
    525525
    526526  // 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));
    528529  // push endstep to last one
    529530  for_each(atoms.begin(),atoms.end(),boost::bind(&atom::CopyStepOnStep,_1,MaxSteps,endstep));
     
    538539      // add to molecule list
    539540      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;
    550547    }
    551548  }
     
    620617  // and perform Verlet integration for each atom with position, velocity and force vector
    621618  // 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  }
    625622
    626623  // correct velocities (rather momenta) so that center of mass remains motionless
Note: See TracChangeset for help on using the changeset viewer.