Ignore:
Timestamp:
Jan 2, 2012, 1:34:58 PM (14 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, 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
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.
File:
1 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}
Note: See TracChangeset for help on using the changeset viewer.