Changeset cbdcb1 for src/LinkedCell


Ignore:
Timestamp:
Jan 2, 2012, 1:34:58 PM (13 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:
b1c5ddb
Parents:
4a8169
git-author:
Frederik Heber <heber@…> (12/22/11 08:59:40)
git-committer:
Frederik Heber <heber@…> (01/02/12 13:34:58)
Message:

Added LinkedCell_View_ModelWrapper to safely keep LinkedCell_Model out of _Views' grasp.

  • This is the only way to keep _View away from its own pointer without declaring it "const" which prevents _Controller from re-instantiating the model after the Box has changed.
  • Added logging to LinkedCell_Controller::updateModelsForNewBoxMatrix().
  • Switched order of delete/create in updateModelsForNewBoxMatrix(). This is necessary such that newref is not created on top of oldref and hence unit test may fail.
Location:
src/LinkedCell
Files:
1 added
5 edited

Legend:

Unmodified
Added
Removed
  • src/LinkedCell/LinkedCell_Controller.cpp

    r4a8169 rcbdcb1  
    3030#include "LinkedCell_Model.hpp"
    3131#include "LinkedCell_View.hpp"
     32#include "LinkedCell_View_ModelWrapper.hpp"
    3233#include "IPointCloud.hpp"
    3334
     
    184185 *
    185186 * The main problem are the views currently in use.
     187 *
    186188 * We make use of LinkedCell:LinkedCell_View::RAIIMap as there all present are
    187189 * listed. We go through the list, create a map with old model ref as keys to
     
    192194void LinkedCell_Controller::updateModelsForNewBoxMatrix()
    193195{
     196  LOG(1, "INFO: Updating all models.");
     197
    194198  typedef std::map<const LinkedCell_Model *, LinkedCell_Model *>  ModelLookup;
    195199  ModelLookup models;
     
    201205    std::pair< ModelLookup::iterator, bool > inserter =
    202206#endif
    203         models.insert( std::pair<const LinkedCell_Model *, LinkedCell_Model *>( &((*iter)->LC), NULL) );
     207        models.insert( std::pair<const LinkedCell_Model *, LinkedCell_Model *>( (*iter)->LC->getModel(), NULL) );
     208    LOG(2, "INFO: Added " << (*iter)->LC->getModel() << " to list of models to replace.");
    204209    ASSERT( inserter.second,
    205210        "LinkedCell_Controller::updateModelsForNewBoxMatrix() - failed to insert old model "
    206         +toString( &((*iter)->LC))+","+toString(NULL)+" into models, is already present");
     211        +toString( (*iter)->LC->getModel() )+","+toString(NULL)+" into models, is already present");
    207212  }
    208213
    209214  // invert MapEdgelengthModel
     215  LOG(2, "INFO: ModelsMap is " << ModelsMap << ".");
    210216  typedef std::map<const LinkedCell_Model*, double > MapEdgelengthModel_inverted;
    211217  MapEdgelengthModel_inverted ModelsMap_inverted;
     
    214220#ifndef NDEBUG
    215221    MapEdgelengthModel_inverted::const_iterator assertiter = ModelsMap_inverted.find(iter->second);
    216     ASSERT( assertiter != ModelsMap_inverted.end(),
     222    ASSERT( assertiter == ModelsMap_inverted.end(),
    217223        "LinkedCell_Controller::updateModelsForNewBoxMatrix() - ModelsMap is not invertible, value "
    218224        +toString(iter->second)+" is already present.");
     
    220226    ModelsMap_inverted.insert( std::make_pair(iter->second, iter->first) );
    221227  }
     228  LOG(2, "INFO: Inverted ModelsMap is " << ModelsMap_inverted << ".");
    222229
    223230  // go through map and re-create models
     
    232239#endif
    233240    const double distance = ModelsMap_inverted[oldref];
     241    // create new one
     242    LinkedCell_Model * const newref = new LinkedCell_Model(distance, domain);
     243    // delete old one (this way to make sure, unit test notices different pointer addresses)
    234244    delete oldref;
    235245    ModelsMap.erase(distance);
    236     // create new one
    237     LinkedCell_Model * const newref = new LinkedCell_Model(distance, domain);
     246    LOG(2, "INFO: oldref is " << oldref << ", newref is " << newref << ".");
    238247    iter->second = newref;
    239248    // replace in ModelsMap
     
    253262  for (LinkedCell_View::ModelInstanceMap::const_iterator iter = LinkedCell_View::RAIIMap.begin();
    254263      iter != LinkedCell_View::RAIIMap.end(); ++iter) {
    255     ModelLookup::const_iterator modeliter = models.find(&((*iter)->LC));
     264    ModelLookup::const_iterator modeliter = models.find((*iter)->LC->getModel());
    256265    ASSERT( modeliter != models.end(),
    257266        "LinkedCell_Controller::updateModelsForNewBoxMatrix() - we miss a model "
    258         +toString(&((*iter)->LC))+" in ModelLookup.");
     267        +toString((*iter)->LC->getModel())+" in ModelLookup.");
    259268    // this is ugly but the only place where we have to set ourselves over the constness of the member variable
    260     //if (modeliter != models.end())
    261       //const_cast<LinkedCell_Model &>((*iter)->LC) = *modeliter->second;
     269    if (modeliter != models.end()) {
     270      LOG(2, "INFO: Setting model to " << modeliter->second << " in view " << *iter << ".");
     271      (*iter)->LC->setModel(modeliter->second);
     272    }
    262273  }
    263274}
  • src/LinkedCell/LinkedCell_View.cpp

    r4a8169 rcbdcb1  
    3131#include "LinkedCell.hpp"
    3232#include "LinkedCell_Model.hpp"
     33#include "LinkedCell_View_ModelWrapper.hpp"
    3334#include "tripleIndex.hpp"
    3435
     
    4344 */
    4445LinkedCell_View::LinkedCell_View(const LinkedCell_Model &_LC) :
    45     LC(_LC)
     46    LC( new LinkedCell_View_ModelWrapper(&_LC) )
    4647{
    4748  // add us to RAII counting map
     
    6061 */
    6162LinkedCell_View::LinkedCell_View(const LinkedCell_View &_view) :
    62     LC(_view.LC)
     63    LC( new LinkedCell_View_ModelWrapper(_view.LC->getModel()) )
    6364{
    6465  if (this != &_view) {
     
    9091    ELOG(1, "Failed to remove instance "+toString(this)+" from RAIIMap.");
    9192  }
     93  delete LC;
    9294}
    9395
     
    104106  LinkedList TesselList;  // we do not need a set, as nodes are uniquely associated to a cell.
    105107
     108  const LinkedCell_Model * const LCmodel = LC->getModel();  // get quick ref to model
    106109  // get relative bounds
    107   const tripleIndex step = LC.getStep(radius);
    108   const tripleIndex index = LC.getIndexToVector(center);
     110  const tripleIndex step = LCmodel->getStep(radius);
     111  const tripleIndex index = LCmodel->getIndexToVector(center);
    109112  LinkedCell_Model::LinkedCellNeighborhoodBounds neighbors =
    110       LC.getNeighborhoodBounds(index, step);
     113      LCmodel->getNeighborhoodBounds(index, step);
    111114
    112115  tripleIndex n;
     
    115118      for (n[2] = 0; n[2] < neighbors.second[2]; n[2]++) {
    116119        tripleIndex absolute_n = neighbors.first + n;
    117         if (!LC.checkArrayBounds(absolute_n))
    118           LC.applyBoundaryConditions(absolute_n);
    119         const LinkedCell &List = LC.getCell(absolute_n);
     120        if (!LCmodel->checkArrayBounds(absolute_n))
     121          LCmodel->applyBoundaryConditions(absolute_n);
     122        const LinkedCell &List = LCmodel->getCell(absolute_n);
    120123        LOG(1, "Current cell is " << neighbors.first << " plus " << n << ", yielding " << absolute_n << ".");
    121124        for (LinkedCell::const_iterator Runner = List.begin(); Runner != List.end(); Runner++)
  • src/LinkedCell/LinkedCell_View.hpp

    r4a8169 rcbdcb1  
    2424namespace LinkedCell {
    2525
     26  class LinkedCell_Controller;
    2627  class LinkedCell_Model;
     28  class LinkedCell_View_ModelWrapper;
    2729
    2830  /** This is the view of the MVC ansatz for the LinkedCell structure.
     
    5860    static ModelInstanceMap RAIIMap;
    5961    //!> internal reference to the underlying model
    60     const LinkedCell_Model &LC;
     62    LinkedCell_View_ModelWrapper * const LC;
    6163  };
    6264
  • src/LinkedCell/Makefile.am

    r4a8169 rcbdcb1  
    2323  LinkedCell/LinkedCell_Model_Update.hpp \
    2424  LinkedCell/LinkedCell_View.hpp \
     25  LinkedCell/LinkedCell_View_ModelWrapper.hpp \
    2526  LinkedCell/PointCloudAdaptor.hpp \
    2627  LinkedCell/tripleIndex.hpp
  • src/LinkedCell/unittests/stubs/LinkedCell_ViewStub.cpp

    r4a8169 rcbdcb1  
    2121
    2222#include "LinkedCell/LinkedCell_View.hpp"
     23#include "LinkedCell/LinkedCell_View_ModelWrapper.hpp"
    2324
    2425using namespace LinkedCell;
    2526
    2627LinkedCell_View::LinkedCell_View(const LinkedCell_Model &_LC) :
    27     LC(_LC)
     28    LC( new LinkedCell_View_ModelWrapper(&_LC) )
    2829{}
    2930
    3031LinkedCell_View::LinkedCell_View(const LinkedCell_View &_view) :
    31     LC(_view.LC)
     32    LC( new LinkedCell_View_ModelWrapper(_view.LC->getModel()) )
    3233{}
    3334
Note: See TracChangeset for help on using the changeset viewer.