source: src/Fragmentation/fragmentation_helpers.hpp@ 6ef48c

Last change on this file since 6ef48c was d760bb, checked in by Frederik Heber <heber@…>, 12 years ago

REFACTOR: PowerSetGenerator now creates all orders in one go, not limited to one by one increments.

  • atom_bondedparticle's MaxOrder is not a bool but an int containing the desired final order set by CheckOrderAtSite and compared to AdaptiveOrder to obtain its old meaning.
  • UniqueFragments now contains a vector of n Graphs to place n-body fragments in that are later combined. Also, cleaned up a lot of old functions and merged stuff into cstor. FreeAllOrdersList() and CombineAllOrderListIntoOne() have been adapted accordingly.
  • Fragmentation::FragmentBOSSANOVA now uses fully again FragmentLowerOrdersList which now has the above n slots to place n-body fragments in and which is passed by ref to UniqueFragments.
  • SPFragmentGenerator now always stores the current fragment, only in a specific slot in UniqueFragment's Graphs, and it recurses if there are enough SP levels and plces left.
  • FIX: BondsPerShortestPath properly prints and informs about resetting the path list.
  • We checked extra that BondFragments come out exactly as before (same order because of the Graph being a map naturally). The only difference is the OrderAtSite file which now has more than 0/1 values in the second entry.
  • Property mode set to 100644
File size: 871 bytes
RevLine 
[ba1823]1/*
2 * fragmentation_helpers.hpp
3 *
4 * Created on: Oct 18, 2011
5 * Author: heber
6 */
7
[bf42a0]8#ifndef FRAGMENTATION_FRAGMENTATION_HELPERS_HPP_
9#define FRAGMENTATION_FRAGMENTATION_HELPERS_HPP_
[ba1823]10
11
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
[ba94c5]16#include <deque>
[ba1823]17#include <vector>
18
[b78dfd]19#include "types.hpp"
20
[ba94c5]21typedef std::deque<int> KeyStack;
[ba1823]22
[f96874]23class AtomMask_t;
[dadc74]24class Graph;
25class KeySet;
[ba1823]26class molecule;
27
[f96874]28void PrintAtomMask(const AtomMask_t &AtomMask, int AtomCount);
[a03d25]29
[d760bb]30int CombineAllOrderListIntoOne(Graph &FragmentList, std::vector<Graph*> *&FragmentLowerOrdersList, KeyStack &RootStack, molecule *mol);
31void FreeAllOrdersList(std::vector<Graph*> *&FragmentLowerOrdersList, KeyStack &RootStack, molecule *mol);
[ba1823]32
[b78dfd]33const std::vector<atomId_t> getGlobalIdsFromLocalIds(const molecule &mol, const std::vector<atomId_t> &atomids);
34
[bf42a0]35#endif /* FRAGMENTATION_FRAGMENTATION_HELPERS_HPP_ */
Note: See TracBrowser for help on using the repository browser.