Ignore:
Timestamp:
Dec 10, 2012, 10:10:58 AM (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, 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:
d4f31f
Parents:
4f056e
git-author:
Frederik Heber <heber@…> (09/04/12 08:26:23)
git-committer:
Frederik Heber <heber@…> (12/10/12 10:10:58)
Message:

IndexSetContainer now treats super set specially.

  • The super set must not gather its subsets via the gatherSubsets() as by construction all other sets are its subsets! As the super set is very large the power set way is no good idea.
  • added default cstor for SortedVector
  • removed SubsetMap::getMaximumSubsetLevel() as is replaced by ::getMaximumSetLevel() which is the level to sum up to.
  • changed all uses of getMaximumSubsetLevel() to getMaximumSetLevel().
  • TESTFIX: Changed unit test function on getMaximumSubsetLevel() to check on getMaximumSetLevel()
  • removed OrthogonalFullSummator as is fully replacable by OrthogonalSummator.
  • changed IndexSetContainer::createSuperSet a bit.
  • IndexSetContainer::AllIndices is now no more static convenience entity but truely contains the super set (non-statically). ::createSuperSet() is for convenience to be called in cstor for AllIndices.
Location:
src/Fragmentation/Summation
Files:
1 deleted
12 edited

Legend:

Unmodified
Added
Removed
  • src/Fragmentation/Summation/AllLevelOrthogonalSummator.hpp

    r4f056e r19c50e  
    5252    results(_results)
    5353  {
    54     ASSERT( results.size() >= subsetmap->getMaximumSubsetLevel(),
     54    ASSERT( results.size() >= subsetmap->getMaximumSetLevel(),
    5555        "AllLevelOrthogonalSummator() - result vector is not large enough.");
    5656  }
     
    6969        subsetmap, data, container, MatrixNrLookup
    7070        );
    71     const size_t MaxLevel = subsetmap->getMaximumSubsetLevel();
     71    const size_t MaxLevel = subsetmap->getMaximumSetLevel();
    7272    for (size_t level=1; level <= MaxLevel; ++level) {
    7373      MapType &LevelResults = results[level-1];
  • src/Fragmentation/Summation/AllLevelSummator.hpp

    r4f056e r19c50e  
    5252    results(_results)
    5353  {
    54     ASSERT( results.size() >= subsetmap->getMaximumSubsetLevel(),
     54    ASSERT( results.size() >= subsetmap->getMaximumSetLevel(),
    5555        "AllLevelSummator() - result vector is not large enough.");
    5656  }
     
    6969        subsetmap, data, container, MatrixNrLookup
    7070        );
    71     const size_t MaxLevel = subsetmap->getMaximumSubsetLevel();
     71    const size_t MaxLevel = subsetmap->getMaximumSetLevel();
    7272    for (size_t level=1; level <= MaxLevel; ++level) {
    7373      MapType &LevelResults = results[level-1];
  • src/Fragmentation/Summation/IndexSetContainer.cpp

    r4f056e r19c50e  
    4545#include "Fragmentation/KeySetsContainer.hpp"
    4646
    47 IndexSet::ptr IndexSetContainer::AllIndices(new IndexSet);
    48 
    49 IndexSet::ptr& IndexSetContainer::createSuperSet(const KeySetsContainer &_keysets) const
     47IndexSet::ptr IndexSetContainer::createSuperSet(const KeySetsContainer &_keysets) const
    5048{
    5149  // create superset
    52   //IndexSet::ptr AllIndices(new IndexSet);
     50  IndexSet::ptr _AllIndices(new IndexSet);
    5351  for (KeySetsContainer::ArrayOfIntVectors::const_iterator iter = _keysets.KeySets.begin();
    5452      iter != _keysets.KeySets.end(); ++iter)
     
    5654        keyiter != (*iter).end(); ++keyiter) {
    5755      if (*keyiter != -1)
    58         AllIndices->insert((Index_t)*keyiter);
     56        _AllIndices->insert((Index_t)*keyiter);
    5957    }
    60   LOG(1, "INFO: AllIndices is " << *AllIndices << ".");
     58  LOG(1, "INFO: AllIndices is " << *_AllIndices << ".");
    6159
    62   return AllIndices;
     60  return _AllIndices;
    6361}
    6462
    6563IndexSetContainer::IndexSetContainer(const KeySetsContainer &_keysets) :
    66   SortedVector<IndexSet>(createSuperSet(_keysets))
     64     AllIndices(createSuperSet(_keysets))
    6765{
    68   const size_t SupersetSize = getContainer()[0]->size();
     66  const size_t SupersetSize = AllIndices->size();
    6967  // create container with all keysets
    7068  for (KeySetsContainer::ArrayOfIntVectors::const_iterator iter = _keysets.KeySets.begin();
    7169      iter != _keysets.KeySets.end(); ++iter) {
     70    // create the IndexSets ...
    7271    IndexSet tempset;
    7372    for(KeySetsContainer::IntVector::const_iterator keyiter = (*iter).begin();
     
    7574      if (*keyiter != -1)
    7675        tempset.insert((Index_t)*keyiter);
    77     if (tempset.size() < SupersetSize)  // only insert if not super set
     76    // ... and insert, making sure that super set is AllIndices when present
     77    if (tempset.size() < SupersetSize)
    7878      insert(tempset);
     79    else
     80      insert(AllIndices);
    7981  }
    8082}
  • src/Fragmentation/Summation/IndexSetContainer.hpp

    r4f056e r19c50e  
    8383  size_t countSetsTillLevel(const size_t level) const;
    8484
     85  /** Getter to the super set.
     86   *
     87   * @return AllIndices
     88   */
     89  const IndexSet::ptr getSuperSet() const
     90  {
     91    return AllIndices;
     92  }
     93
    8594private:
    86   /** Helper function to get the super set out of a KeySetsContainer.
     95  /** Helper function to create the super set out of a KeySetsContainer.
    8796   *
    8897   * @param _keysets keysets to construct super set for
    89    * @return IndexSet that contains each index once that appears in the sets of \a _keysets
     98   * @return super set created from all keysets in \a _keysets
    9099   */
    91   IndexSet::ptr& createSuperSet(const KeySetsContainer &_keysets) const;
     100  IndexSet::ptr createSuperSet(const KeySetsContainer &_keysets) const;
    92101
    93   //!> static instance for AllIndices such that createSuperSet may return a reference.
    94   static IndexSet::ptr AllIndices;
     102  //!> super set that contains all present index sets
     103  IndexSet::ptr AllIndices;
    95104};
    96105
  • src/Fragmentation/Summation/Makefile.am

    r4f056e r19c50e  
    1313        Fragmentation/Summation/IndexSet.hpp \
    1414        Fragmentation/Summation/IndexSetContainer.hpp \
    15         Fragmentation/Summation/OrthogonalFullSummator.hpp \
    1615        Fragmentation/Summation/OrthogonalSummation.hpp \
    1716        Fragmentation/Summation/OrthogonalSummation_impl.hpp \
  • src/Fragmentation/Summation/OrthogonalSumUpPerLevel.hpp

    r4f056e r19c50e  
    3939  convertDataTo<TypeData, TypeMap>(fragmentData, Data_fused);
    4040  // instantiate summator
    41   std::vector<TypeMap> Result_fused(subsetmap->getMaximumSubsetLevel());
     41  std::vector<TypeMap> Result_fused(subsetmap->getMaximumSetLevel());
    4242  AllLevelOrthogonalSummator<TypeMap> Summer(
    4343              subsetmap,
  • src/Fragmentation/Summation/SortedVector.hpp

    r4f056e r19c50e  
    8484  }
    8585
     86  /** Default constructor.
     87   *
     88   * An empty vector is automatically sorted.
     89   *
     90   * @return
     91   */
     92  SortedVector() :
     93    ContainerSorted(true)
     94  {}
     95
    8696  /** Getter to sorted container.
    8797   *
  • src/Fragmentation/Summation/SubsetMap.cpp

    r4f056e r19c50e  
    4040#include <boost/bind.hpp>
    4141#include <boost/foreach.hpp>
     42#include <boost/lambda/lambda.hpp>
    4243#include <algorithm>
    4344#include <bitset>
    4445#include <set>
    4546
     47#include "CodePatterns/Assert.hpp"
    4648#include "CodePatterns/Log.hpp"
    4749
     
    4951  tempset(new IndexSet())
    5052{
     53  /// go through all IndexSets
    5154  const IndexSetContainer::Container_t &container = _container.getContainer();
    52 
    53 // we don't need this level-wise sorting as this is automatically achieved by specific sorting
    54 //  /// place in level-wise multimap
    55 //  typedef size_t level_t;
    56 //  // note: We use an IndexSetContainer as it is not accessed while filling it
    57 //  // also, as insert uses push_back, the IndexSetContainer is actually created
    58 //  // as sorted. Hence, the call to sort() just needs linear time (and does
    59 //  // nothing)
    60 //  typedef std::map<level_t, IndexSetContainer > IndexSetPerLevel_t;
    61 //  IndexSetPerLevel_t IndexSetPerLevel;
    62 //  for(IndexSetContainer::Container_t::const_iterator iter = container.begin();
    63 //      iter != container.end(); ++iter) {
    64 //    // key present in map?
    65 //    const size_t level = (*iter)->size();
    66 //    LOG(1, "INFO: Current set is " << **iter << " with size " << level << ".");
    67 //    IndexSetPerLevel_t::iterator leveliter = IndexSetPerLevel.find(level);
    68 //    // we have to explicitly copy the shared_ptr for insertion due to const container
    69 //    IndexSet_ptr ptr(*iter);
    70 //    if (leveliter == IndexSetPerLevel.end()) {
    71 //      LOG(2, "DEBUG: Level not present in Lookup, creating new container");
    72 //      IndexSetPerLevel.insert( std::make_pair( level, IndexSetContainer(ptr)) );
    73 //    } else {
    74 //      LOG(2, "DEBUG: Level present in Lookup, appending to container");
    75 //      leveliter->second.insert(ptr);
    76 //    }
    77 //  }
    78 
    79   /// go through all IndexSets
    80   std::for_each( container.begin(), container.end(),
    81       boost::bind(&SubsetMap::gatherSubsets, this, _1));
     55  for (IndexSetContainer::Container_t::const_iterator iter = container.begin();
     56      iter != container.end(); ++iter) {
     57    // check whether its the super set
     58    if (*iter == _container.getSuperSet()) {
     59      // place all other sets as its subsets
     60      std::vector<IndexSet> returnsets;
     61      returnsets.reserve(container.size());
     62      for (IndexSetContainer::Container_t::const_iterator insertiter = container.begin();
     63            insertiter != container.end(); ++insertiter)
     64        if (iter != insertiter) {
     65          LOG(2, "INFO: Current subset is " << **insertiter << " for super set.");
     66          ASSERT( _container.getSuperSet()->contains(**insertiter),
     67              "SubsetMap::SubsetMap() - "+toString(**insertiter)+" is not contained in super set "
     68              +toString(*_container.getSuperSet())+".");
     69          returnsets.push_back(**insertiter);
     70        }
     71      Lookup.insert( std::make_pair(*iter, IndexSetContainer::ptr(new IndexSetContainer(returnsets))) );
     72    } else {
     73      gatherSubsets(*iter);
     74    }
     75  }
    8276}
    8377
     
    184178}
    185179
    186 size_t SubsetMap::getMaximumSubsetLevel() const
    187 {
    188   // last one is super set, hence, the one before has largest subset size
    189   Lookup_t::const_iterator iter = --Lookup.end();
    190   --iter;
    191   return iter->first->size();
    192 }
    193 
    194180size_t SubsetMap::getMaximumSetLevel() const
    195181{
  • src/Fragmentation/Summation/SubsetMap.hpp

    r4f056e r19c50e  
    5858    return lookupiter->second;
    5959  }
    60 
    61   /** Returns the size of the largest \b sub set.
    62    *
    63    * This would be \f${\cal O}(n)\f$ if we had to look at each set. However, due
    64    * to the specific sorting we just have to check the last sets.
    65    *
    66    * @return number of indices in largest subset, -1 if SubsetMap contains no IndexSet's
    67    */
    68   size_t getMaximumSubsetLevel() const;
    6960
    7061  /** Returns the size of the largest set.
  • src/Fragmentation/Summation/SumUpPerLevel.hpp

    r4f056e r19c50e  
    3838  convertDataTo<TypeData, TypeMap>(fragmentData, Data_fused);
    3939  // instantiate summator
    40   std::vector<TypeMap> Result_fused(subsetmap->getMaximumSubsetLevel());
     40  std::vector<TypeMap> Result_fused(subsetmap->getMaximumSetLevel());
    4141  AllLevelSummator<TypeMap> Summer(
    4242              subsetmap,
  • src/Fragmentation/Summation/unittests/SubsetMapUnitTest.cpp

    r4f056e r19c50e  
    301301}
    302302
    303 /** UnitTest for getMaximumSubsetLevel()
    304  */
    305 void SubsetMapTest::getMaximumSubsetLevelTest()
     303/** UnitTest for getMaximumSetLevel()
     304 */
     305void SubsetMapTest::getMaximumSetLevelTest()
    306306{
    307307  // create small container
     
    323323    CPPUNIT_ASSERT( SM != NULL );
    324324
    325     CPPUNIT_ASSERT_EQUAL( (size_t)1, SM->getMaximumSubsetLevel() );
    326     // we are strictly less than super set (last one)
    327     CPPUNIT_ASSERT( SM->getMaximumSubsetLevel() < (--SM->Lookup.end())->first->size() );
     325    CPPUNIT_ASSERT_EQUAL( (size_t)2, SM->getMaximumSetLevel() );
     326    // we are strictly the last set
     327    CPPUNIT_ASSERT( SM->getMaximumSetLevel() == (--SM->Lookup.end())->first->size() );
    328328  }
    329329
     
    335335    CPPUNIT_ASSERT( SM != NULL );
    336336
    337     CPPUNIT_ASSERT_EQUAL( (size_t)3, SM->getMaximumSubsetLevel() );
    338     CPPUNIT_ASSERT( SM->getMaximumSubsetLevel() < (--SM->Lookup.end())->first->size() );
     337    CPPUNIT_ASSERT_EQUAL( (size_t)4, SM->getMaximumSetLevel() );
     338    CPPUNIT_ASSERT( SM->getMaximumSetLevel() == (--SM->Lookup.end())->first->size() );
    339339  }
    340340}
  • src/Fragmentation/Summation/unittests/SubsetMapUnitTest.hpp

    r4f056e r19c50e  
    3131    CPPUNIT_TEST ( getSubsetTest );
    3232    CPPUNIT_TEST ( gatherSubsetTest );
    33     CPPUNIT_TEST ( getMaximumSubsetLevelTest );
     33    CPPUNIT_TEST ( getMaximumSetLevelTest );
    3434    CPPUNIT_TEST_SUITE_END();
    3535
     
    4141      void getSubsetTest();
    4242      void gatherSubsetTest();
    43       void getMaximumSubsetLevelTest();
     43      void getMaximumSetLevelTest();
    4444
    4545private:
Note: See TracChangeset for help on using the changeset viewer.