Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/boundary.cpp

    r6e5084 rd74077  
    66#include "Helpers/MemDebug.hpp"
    77
    8 #include "Actions/MoleculeAction/RotateToPrincipalAxisSystemAction.hpp"
     8#include "BoundaryPointSet.hpp"
     9#include "BoundaryLineSet.hpp"
     10#include "BoundaryTriangleSet.hpp"
     11#include "CandidateForTesselation.hpp"
     12#include "BoundaryPolygonSet.hpp"
     13#include "TesselPoint.hpp"
    914#include "World.hpp"
    1015#include "atom.hpp"
     
    1318#include "config.hpp"
    1419#include "element.hpp"
    15 #include "Helpers/helpers.hpp"
    16 #include "Helpers/Info.hpp"
     20#include "helpers.hpp"
     21#include "info.hpp"
    1722#include "linkedcell.hpp"
    18 #include "Helpers/Verbose.hpp"
    19 #include "Helpers/Log.hpp"
     23#include "verbose.hpp"
     24#include "log.hpp"
    2025#include "molecule.hpp"
    2126#include "tesselation.hpp"
    2227#include "tesselationhelpers.hpp"
    2328#include "World.hpp"
    24 #include "LinearAlgebra/Plane.hpp"
    25 #include "LinearAlgebra/Matrix.hpp"
     29#include "Plane.hpp"
     30#include "Matrix.hpp"
    2631#include "Box.hpp"
    2732
     
    8792              if (Neighbour == BoundaryPoints[axis].end()) // make it wrap around
    8893                Neighbour = BoundaryPoints[axis].begin();
    89               DistanceVector = runner->second.second->x - Neighbour->second.second->x;
     94              DistanceVector = (runner->second.second->getPosition()) - (Neighbour->second.second->getPosition());
    9095              do { // seek for neighbour pair where it flips
    9196                  OldComponent = DistanceVector[Othercomponent];
     
    9398                  if (Neighbour == BoundaryPoints[axis].end()) // make it wrap around
    9499                    Neighbour = BoundaryPoints[axis].begin();
    95                   DistanceVector = runner->second.second->x - Neighbour->second.second->x;
     100                  DistanceVector = (runner->second.second->getPosition()) - (Neighbour->second.second->getPosition());
    96101                  //Log() << Verbose(2) << "OldComponent is " << OldComponent << ", new one is " << DistanceVector.x[Othercomponent] << "." << endl;
    97102                } while ((runner != Neighbour) && (fabs(OldComponent / fabs(
     
    105110                  //Log() << Verbose(1) << "The pair, where the sign of OtherComponent flips, is: " << *(Neighbour->second.second) << " and " << *(OtherNeighbour->second.second) << "." << endl;
    106111                  // now we have found the pair: Neighbour and OtherNeighbour
    107                   OtherVector = runner->second.second->x - OtherNeighbour->second.second->x;
     112                  OtherVector = (runner->second.second->getPosition()) - (OtherNeighbour->second.second->getPosition());
    108113                  //Log() << Verbose(1) << "Distances to Neighbour and OtherNeighbour are " << DistanceVector.x[component] << " and " << OtherVector.x[component] << "." << endl;
    109114                  //Log() << Verbose(1) << "OtherComponents to Neighbour and OtherNeighbour are " << DistanceVector.x[Othercomponent] << " and " << OtherVector.x[Othercomponent] << "." << endl;
     
    173178    // 3b. construct set of all points, transformed into cylindrical system and with left and right neighbours
    174179    for (molecule::const_iterator iter = mol->begin(); iter != mol->end(); ++iter) {
    175       ProjectedVector = (*iter)->x - (*MolCenter);
     180      ProjectedVector = (*iter)->getPosition() - (*MolCenter);
    176181      ProjectedVector.ProjectOntoPlane(AxisVector);
    177182
     
    199204          DoLog(2) && (Log() << Verbose(2) << "Keeping new vector due to larger projected distance " << ProjectedVectorNorm << "." << endl);
    200205        } else if (fabs(ProjectedVectorNorm - BoundaryTestPair.first->second.first) < MYEPSILON) {
    201           helper = (*iter)->x;
    202           helper -= *MolCenter;
     206          helper = (*iter)->getPosition() - (*MolCenter);
    203207          const double oldhelperNorm = helper.NormSquared();
    204           helper = BoundaryTestPair.first->second.second->x - (*MolCenter);
     208          helper = BoundaryTestPair.first->second.second->getPosition() - (*MolCenter);
    205209          if (helper.NormSquared() < oldhelperNorm) {
    206210            BoundaryTestPair.first->second.second = (*iter);
     
    255259        {
    256260          Vector SideA, SideB, SideC, SideH;
    257           SideA = left->second.second->x - (*MolCenter);
     261          SideA = left->second.second->getPosition() - (*MolCenter);
    258262          SideA.ProjectOntoPlane(AxisVector);
    259263          //          Log() << Verbose(1) << "SideA: " << SideA << endl;
    260264
    261           SideB = right->second.second->x -(*MolCenter);
     265          SideB = right->second.second->getPosition() -(*MolCenter);
    262266          SideB.ProjectOntoPlane(AxisVector);
    263267          //          Log() << Verbose(1) << "SideB: " << SideB << endl;
    264268
    265           SideC = left->second.second->x - right->second.second->x;
     269          SideC = left->second.second->getPosition() - right->second.second->getPosition();
    266270          SideC.ProjectOntoPlane(AxisVector);
    267271          //          Log() << Verbose(1) << "SideC: " << SideC << endl;
    268272
    269           SideH = runner->second.second->x -(*MolCenter);
     273          SideH = runner->second.second->getPosition() -(*MolCenter);
    270274          SideH.ProjectOntoPlane(AxisVector);
    271275          //          Log() << Verbose(1) << "SideH: " << SideH << endl;
     
    675679  double cellvolume = 0.;
    676680
    677   // transform to PAS by Action
    678   Vector MainAxis(0.,0.,1.);
    679   MoleculeRotateToPrincipalAxisSystem(MainAxis);
     681  // transform to PAS
     682  mol->PrincipalAxisSystem(true);
    680683
    681684  IsAngstroem = configuration->GetIsAngstroem();
     
    701704  // sum up the atomic masses
    702705  for (molecule::const_iterator iter = mol->begin(); iter != mol->end(); ++iter) {
    703       totalmass += (*iter)->type->mass;
     706      totalmass += (*iter)->getType()->mass;
    704707  }
    705708  DoLog(0) && (Log() << Verbose(0) << "RESULT: The summed mass is " << setprecision(10) << totalmass << " atomicmassunit." << endl);
     
    857860
    858861          // ... and put at new position
    859           Inserter = (*iter)->x;
     862          Inserter = (*iter)->getPosition();
    860863          if (DoRandomRotation)
    861864            Inserter *= Rotations;
     
    882885            // copy atom ...
    883886            CopyAtoms[(*iter)->nr] = (*iter)->clone();
    884             CopyAtoms[(*iter)->nr]->x = Inserter;
     887            (*CopyAtoms[(*iter)->nr]).setPosition(Inserter);
    885888            Filling->AddAtom(CopyAtoms[(*iter)->nr]);
    886             DoLog(4) && (Log() << Verbose(4) << "Filling atom " << **iter << ", translated to " << AtomTranslations << ", at final position is " << (CopyAtoms[(*iter)->nr]->x) << "." << endl);
     889            DoLog(1) && (Log() << Verbose(1) << "Filling atom " << **iter << ", translated to " << AtomTranslations << ", at final position is " << (CopyAtoms[(*iter)->nr]->getPosition()) << "." << endl);
    887890          } else {
    888891            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.