Ignore:
Timestamp:
Apr 10, 2018, 6:43:12 AM (7 years ago)
Author:
Frederik Heber <frederik.heber@…>
Branches:
AutomationFragmentation_failures, Candidate_v1.6.1, ChemicalSpaceEvaluator, Enhanced_StructuralOptimization_continued, Exclude_Hydrogens_annealWithBondGraph, ForceAnnealing_with_BondGraph, ForceAnnealing_with_BondGraph_contraction-expansion, Gui_displays_atomic_force_velocity, PythonUI_with_named_parameters, StoppableMakroAction, TremoloParser_IncreasedPrecision
Children:
6145577
Parents:
efd020
git-author:
Frederik Heber <frederik.heber@…> (08/03/17 10:46:48)
git-committer:
Frederik Heber <frederik.heber@…> (04/10/18 06:43:12)
Message:

atom::removeStep() extended to removing interval of steps.

  • AtomInfo::removeTrajectorySteps() and BondedParticle::removeTrajectorySteps() changed and all calls adapted.
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/Atom/atom_atominfo.hpp

    refd020 r8c6b68  
    5858  virtual void UpdateStep(const unsigned int _step)=0;
    5959
    60   /** Pops the last step in all trajectory vectors.
     60  /** Pops all steps in the interval [\a _firststep, \a _laststep] in all trajectory vectors.
    6161   *
    6262   * This allows to decrease all trajectories contained in different classes
    6363   * by one consistently. This is implemented by the topmost class which calls
    64    * the real functions, \sa removeTrajectoryStep(), by all necessary subclasses.
    65    */
    66   virtual void removeStep(const unsigned int _step)=0;
     64   * the real functions, \sa removeTrajectorySteps(), by all necessary subclasses.
     65   *
     66   * \param _firststep first step in interval to be removed
     67   * \param _laststep last step in interval to be removed
     68   */
     69  virtual void removeSteps(const unsigned int _firststep, const unsigned int _laststep)=0;
    6770
    6871  /** DEPRECATED: Getter for element indicated by AtomicElement.
     
    314317  /** Function used by this and inheriting classes to decrease the trajectory
    315318   * vectors by one.
    316    */
    317   void removeTrajectoryStep(const unsigned int _step);
     319   *
     320   * \param _firststep first step in interval to be removed
     321   * \param _laststep last step in interval to be removed
     322   */
     323  void removeTrajectorySteps(const unsigned int _firststep, const unsigned int _laststep);
    318324
    319325  // make these protected only such that deriving atom class still has full
     
    325331  VectorTrajectory_t AtomicVelocity;       //!< velocity vector of atom, giving last velocity within cell
    326332  VectorTrajectory_t AtomicForce;       //!< Force vector of atom, giving last force within cell
     333
     334  /** Helper function to avoid an interval of steps in VectorTrajectory_t.
     335   *
     336   * \param  _trajectory trajectory to remove in
     337   * \param _firststep first step in interval to be removed
     338   * \param _laststep last step in interval to be removed
     339   */
     340  static void eraseInTrajctory(
     341      VectorTrajectory_t &_trajectory,
     342      const unsigned int _firststep, const unsigned int _laststep);
    327343
    328344private:
Note: See TracChangeset for help on using the changeset viewer.