Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/boundary.cpp

    rd74077 r6e5084  
    66#include "Helpers/MemDebug.hpp"
    77
    8 #include "BoundaryPointSet.hpp"
    9 #include "BoundaryLineSet.hpp"
    10 #include "BoundaryTriangleSet.hpp"
    11 #include "CandidateForTesselation.hpp"
    12 #include "BoundaryPolygonSet.hpp"
    13 #include "TesselPoint.hpp"
     8#include "Actions/MoleculeAction/RotateToPrincipalAxisSystemAction.hpp"
    149#include "World.hpp"
    1510#include "atom.hpp"
     
    1813#include "config.hpp"
    1914#include "element.hpp"
    20 #include "helpers.hpp"
    21 #include "info.hpp"
     15#include "Helpers/helpers.hpp"
     16#include "Helpers/Info.hpp"
    2217#include "linkedcell.hpp"
    23 #include "verbose.hpp"
    24 #include "log.hpp"
     18#include "Helpers/Verbose.hpp"
     19#include "Helpers/Log.hpp"
    2520#include "molecule.hpp"
    2621#include "tesselation.hpp"
    2722#include "tesselationhelpers.hpp"
    2823#include "World.hpp"
    29 #include "Plane.hpp"
    30 #include "Matrix.hpp"
     24#include "LinearAlgebra/Plane.hpp"
     25#include "LinearAlgebra/Matrix.hpp"
    3126#include "Box.hpp"
    3227
     
    9287              if (Neighbour == BoundaryPoints[axis].end()) // make it wrap around
    9388                Neighbour = BoundaryPoints[axis].begin();
    94               DistanceVector = (runner->second.second->getPosition()) - (Neighbour->second.second->getPosition());
     89              DistanceVector = runner->second.second->x - Neighbour->second.second->x;
    9590              do { // seek for neighbour pair where it flips
    9691                  OldComponent = DistanceVector[Othercomponent];
     
    9893                  if (Neighbour == BoundaryPoints[axis].end()) // make it wrap around
    9994                    Neighbour = BoundaryPoints[axis].begin();
    100                   DistanceVector = (runner->second.second->getPosition()) - (Neighbour->second.second->getPosition());
     95                  DistanceVector = runner->second.second->x - Neighbour->second.second->x;
    10196                  //Log() << Verbose(2) << "OldComponent is " << OldComponent << ", new one is " << DistanceVector.x[Othercomponent] << "." << endl;
    10297                } while ((runner != Neighbour) && (fabs(OldComponent / fabs(
     
    110105                  //Log() << Verbose(1) << "The pair, where the sign of OtherComponent flips, is: " << *(Neighbour->second.second) << " and " << *(OtherNeighbour->second.second) << "." << endl;
    111106                  // now we have found the pair: Neighbour and OtherNeighbour
    112                   OtherVector = (runner->second.second->getPosition()) - (OtherNeighbour->second.second->getPosition());
     107                  OtherVector = runner->second.second->x - OtherNeighbour->second.second->x;
    113108                  //Log() << Verbose(1) << "Distances to Neighbour and OtherNeighbour are " << DistanceVector.x[component] << " and " << OtherVector.x[component] << "." << endl;
    114109                  //Log() << Verbose(1) << "OtherComponents to Neighbour and OtherNeighbour are " << DistanceVector.x[Othercomponent] << " and " << OtherVector.x[Othercomponent] << "." << endl;
     
    178173    // 3b. construct set of all points, transformed into cylindrical system and with left and right neighbours
    179174    for (molecule::const_iterator iter = mol->begin(); iter != mol->end(); ++iter) {
    180       ProjectedVector = (*iter)->getPosition() - (*MolCenter);
     175      ProjectedVector = (*iter)->x - (*MolCenter);
    181176      ProjectedVector.ProjectOntoPlane(AxisVector);
    182177
     
    204199          DoLog(2) && (Log() << Verbose(2) << "Keeping new vector due to larger projected distance " << ProjectedVectorNorm << "." << endl);
    205200        } else if (fabs(ProjectedVectorNorm - BoundaryTestPair.first->second.first) < MYEPSILON) {
    206           helper = (*iter)->getPosition() - (*MolCenter);
     201          helper = (*iter)->x;
     202          helper -= *MolCenter;
    207203          const double oldhelperNorm = helper.NormSquared();
    208           helper = BoundaryTestPair.first->second.second->getPosition() - (*MolCenter);
     204          helper = BoundaryTestPair.first->second.second->x - (*MolCenter);
    209205          if (helper.NormSquared() < oldhelperNorm) {
    210206            BoundaryTestPair.first->second.second = (*iter);
     
    259255        {
    260256          Vector SideA, SideB, SideC, SideH;
    261           SideA = left->second.second->getPosition() - (*MolCenter);
     257          SideA = left->second.second->x - (*MolCenter);
    262258          SideA.ProjectOntoPlane(AxisVector);
    263259          //          Log() << Verbose(1) << "SideA: " << SideA << endl;
    264260
    265           SideB = right->second.second->getPosition() -(*MolCenter);
     261          SideB = right->second.second->x -(*MolCenter);
    266262          SideB.ProjectOntoPlane(AxisVector);
    267263          //          Log() << Verbose(1) << "SideB: " << SideB << endl;
    268264
    269           SideC = left->second.second->getPosition() - right->second.second->getPosition();
     265          SideC = left->second.second->x - right->second.second->x;
    270266          SideC.ProjectOntoPlane(AxisVector);
    271267          //          Log() << Verbose(1) << "SideC: " << SideC << endl;
    272268
    273           SideH = runner->second.second->getPosition() -(*MolCenter);
     269          SideH = runner->second.second->x -(*MolCenter);
    274270          SideH.ProjectOntoPlane(AxisVector);
    275271          //          Log() << Verbose(1) << "SideH: " << SideH << endl;
     
    679675  double cellvolume = 0.;
    680676
    681   // transform to PAS
    682   mol->PrincipalAxisSystem(true);
     677  // transform to PAS by Action
     678  Vector MainAxis(0.,0.,1.);
     679  MoleculeRotateToPrincipalAxisSystem(MainAxis);
    683680
    684681  IsAngstroem = configuration->GetIsAngstroem();
     
    704701  // sum up the atomic masses
    705702  for (molecule::const_iterator iter = mol->begin(); iter != mol->end(); ++iter) {
    706       totalmass += (*iter)->getType()->mass;
     703      totalmass += (*iter)->type->mass;
    707704  }
    708705  DoLog(0) && (Log() << Verbose(0) << "RESULT: The summed mass is " << setprecision(10) << totalmass << " atomicmassunit." << endl);
     
    860857
    861858          // ... and put at new position
    862           Inserter = (*iter)->getPosition();
     859          Inserter = (*iter)->x;
    863860          if (DoRandomRotation)
    864861            Inserter *= Rotations;
     
    885882            // copy atom ...
    886883            CopyAtoms[(*iter)->nr] = (*iter)->clone();
    887             (*CopyAtoms[(*iter)->nr]).setPosition(Inserter);
     884            CopyAtoms[(*iter)->nr]->x = Inserter;
    888885            Filling->AddAtom(CopyAtoms[(*iter)->nr]);
    889             DoLog(1) && (Log() << Verbose(1) << "Filling atom " << **iter << ", translated to " << AtomTranslations << ", at final position is " << (CopyAtoms[(*iter)->nr]->getPosition()) << "." << endl);
     886            DoLog(4) && (Log() << Verbose(4) << "Filling atom " << **iter << ", translated to " << AtomTranslations << ", at final position is " << (CopyAtoms[(*iter)->nr]->x) << "." << endl);
    890887          } else {
    891888            DoLog(1) && (Log() << Verbose(1) << "INFO: Position at " << Inserter << " is inner point, within boundary or outside of MaxDistance." << endl);
Note: See TracChangeset for help on using the changeset viewer.