source: src/LinkedCell/LinkedCell_View.cpp@ 770ec6

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 Candidate_v1.7.0 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
Last change on this file since 770ec6 was cbcda6, checked in by Frederik Heber <heber@…>, 14 years ago

BUGFIX: LinkedCell_View::getPointsInsideSphere() did not adhere to boundary conditions.

  • new function LinkedCell_Model::getDomain() such that view may use the same domain and use it when checking distances.
  • Property mode set to 100644
File size: 4.6 KB
RevLine 
[5344e4]1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
[0aa122]4 * Copyright (C) 2012 University of Bonn. All rights reserved.
[5344e4]5 * Please see the LICENSE file or "Copyright notice" in builder.cpp for details.
6 */
7
8/*
9 * LinkedCell_View.cpp
10 *
11 * Created on: Nov 15, 2011
12 * Author: heber
13 */
14
15// include config.h
16#ifdef HAVE_CONFIG_H
17#include <config.h>
18#endif
19
20#include "CodePatterns/MemDebug.hpp"
21
22#include "LinkedCell_View.hpp"
23
[9ed706]24#include <algorithm>
25
26#include "CodePatterns/Assert.hpp"
[53d894]27#include "CodePatterns/Log.hpp"
28
[5344e4]29#include "Atom/TesselPoint.hpp"
[cbcda6]30#include "Box.hpp"
[5344e4]31#include "LinearAlgebra/Vector.hpp"
32#include "LinkedCell.hpp"
33#include "LinkedCell_Model.hpp"
[cbdcb1]34#include "LinkedCell_View_ModelWrapper.hpp"
[4459fc]35#include "tripleIndex.hpp"
[5344e4]36
37using namespace LinkedCell;
38
[9ed706]39// static multimap instance
40LinkedCell_View::ModelInstanceMap LinkedCell_View::RAIIMap;
41
42/** Constructor of class LinkedCell_View.
43 *
44 * We add ourselves to RAIIMap here.
45 */
[5344e4]46LinkedCell_View::LinkedCell_View(const LinkedCell_Model &_LC) :
[cbdcb1]47 LC( new LinkedCell_View_ModelWrapper(&_LC) )
[9ed706]48{
49 // add us to RAII counting map
50#ifndef NDEBUG
51 std::pair< ModelInstanceMap::iterator, bool> inserter =
52#endif
53 RAIIMap.insert( this );
54 ASSERT( inserter.second,
55 "LinkedCell_View::LinkedCell_View() - we "+toString(this)+" are already present in RAIIMap.");
[b75386]56 LOG(3, "INFO: Placing instance "+toString(this)+" into RAIIMap.");
[9ed706]57}
[5344e4]58
[9ed706]59/** Copy Constructor of class LinkedCell_View.
60 *
61 * We add ourselves to RAIIMap here.
62 */
63LinkedCell_View::LinkedCell_View(const LinkedCell_View &_view) :
[cbdcb1]64 LC( new LinkedCell_View_ModelWrapper(_view.LC->getModel()) )
[5344e4]65{
[9ed706]66 if (this != &_view) {
67 // add us to RAII counting map
68 #ifndef NDEBUG
69 std::pair< ModelInstanceMap::iterator, bool> inserter =
70 #endif
71 RAIIMap.insert( this );
72 ASSERT( inserter.second,
73 "LinkedCell_View::LinkedCell_View(&view) - we "+toString(this)+" are already present in RAIIMap.");
[b75386]74 LOG(3, "INFO: Placing instance "+toString(this)+" copied from "+toString(&_view)+" into RAIIMap.");
[9ed706]75 }
[5344e4]76}
77
[9ed706]78/** Destructor of class LinkedCell_View.
79 *
80 * We remove ourselves from RAIIMap here.
81 */
82LinkedCell_View::~LinkedCell_View()
83{
84 ModelInstanceMap::iterator iter = RAIIMap.find(this);
85 ASSERT( iter != RAIIMap.end(),
86 "LinkedCell_View::~LinkedCell_View() - there is no instance "
87 +toString(this)+" in RAIIMap.");
88 if (iter != RAIIMap.end()) {
89 RAIIMap.erase(iter);
[b75386]90 LOG(3, "INFO: Removing instance "+toString(this)+" from RAIIMap.");
[9ed706]91 } else {
92 ELOG(1, "Failed to remove instance "+toString(this)+" from RAIIMap.");
93 }
[cbdcb1]94 delete LC;
[9ed706]95}
[53d894]96
[5344e4]97/** Return at least as many points as are inside a sphere of \a radius around \a center.
98 *
99 * \sa LinkedCell_View::getPointsInsideSphere()
100 *
101 * @param radius radius of sphere
102 * @param center center of sphere
103 * @return a list containing at least all points inside described sphere
104 */
105LinkedList LinkedCell_View::getAllNeighbors(const double radius, const Vector &center) const
106{
107 LinkedList TesselList; // we do not need a set, as nodes are uniquely associated to a cell.
108
[cbdcb1]109 const LinkedCell_Model * const LCmodel = LC->getModel(); // get quick ref to model
[5344e4]110 // get relative bounds
[cbdcb1]111 const tripleIndex step = LCmodel->getStep(radius);
112 const tripleIndex index = LCmodel->getIndexToVector(center);
[5344e4]113 LinkedCell_Model::LinkedCellNeighborhoodBounds neighbors =
[cbdcb1]114 LCmodel->getNeighborhoodBounds(index, step);
[5344e4]115
116 tripleIndex n;
[53d894]117 for (n[0] = 0; n[0] < neighbors.second[0]; n[0]++)
118 for (n[1] = 0; n[1] < neighbors.second[1]; n[1]++)
119 for (n[2] = 0; n[2] < neighbors.second[2]; n[2]++) {
120 tripleIndex absolute_n = neighbors.first + n;
[cbdcb1]121 if (!LCmodel->checkArrayBounds(absolute_n))
122 LCmodel->applyBoundaryConditions(absolute_n);
123 const LinkedCell &List = LCmodel->getCell(absolute_n);
[b75386]124 LOG(3, "INFO: Current cell is " << neighbors.first << " plus " << n << ", yielding " << absolute_n << ".");
[5344e4]125 for (LinkedCell::const_iterator Runner = List.begin(); Runner != List.end(); Runner++)
[fbbcde]126 TesselList.insert(*Runner);
[5344e4]127 }
128 return TesselList;
129}
130
131LinkedList LinkedCell_View::getPointsInsideSphere(const double radius, const Vector &center) const
132{
133 // get overly much points
134 const LinkedList TesselList = getAllNeighbors(radius, center);
135 LinkedList ReturnList;
136
137 // remove all unnecessary ones
[cbcda6]138 const Box& domain = LC->getModel()->getDomain();
[5344e4]139 for (LinkedList::const_iterator iter = TesselList.begin(); iter != TesselList.end(); ++iter) {
[cbcda6]140 if (domain.periodicDistanceSquared(center, (*iter)->getPosition()) <= radius*radius)
[fbbcde]141 ReturnList.insert(*iter);
[5344e4]142 }
143
144 return ReturnList;
145}
Note: See TracBrowser for help on using the repository browser.