source: src/Fragmentation/Fragmentation.hpp@ 0542e2

AutomationFragmentation_failures Candidate_v1.6.1 Candidate_v1.7.0 ChemicalSpaceEvaluator Enhanced_StructuralOptimization_continued Exclude_Hydrogens_annealWithBondGraph ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_contraction-expansion Gui_displays_atomic_force_velocity JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool PythonUI_with_named_parameters StoppableMakroAction TremoloParser_IncreasedPrecision stable
Last change on this file since 0542e2 was 0f5956, checked in by Frederik Heber <heber@…>, 9 years ago

Added "parse-state-files" option to fragment-molecule which is off by default.

  • this prevents accidental parsing of stale keysets, adjacency, or orderatsite files. These hard to find errors ever and again cause failing fragmentation because e.g. some hydrogen is suddenly in the keysets although hydrogens are excluded.
  • Property mode set to 100644
File size: 2.3 KB
RevLine 
[246e13]1/*
2 * Fragmentation.hpp
3 *
4 * Created on: Oct 18, 2011
5 * Author: heber
6 */
7
8#ifndef FRAGMENTATION_HPP_
9#define FRAGMENTATION_HPP_
10
11
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
[ba94c5]16#include "Fragmentation/fragmentation_helpers.hpp"
[ca8bea]17#include "Fragmentation/Graph.hpp"
18#include "Fragmentation/HydrogenSaturation_enum.hpp"
[fe0cb8]19#include "Graph/ListOfLocalAtoms.hpp"
[d4d7a1]20#include "types.hpp"
[dadc74]21
[d4d7a1]22#include <map>
[99b0dc]23#include <string>
24#include <vector>
25
[321470]26#include <boost/bimap.hpp>
27
[246e13]28class atom;
[f96874]29class AtomMask_t;
[0fad93]30class AdjacencyList;
[f0674a]31class KeySet;
[246e13]32class molecule;
33
34class Fragmentation
35{
[321470]36 // some typedefs for intermediat global id <-> local id bimap
37 typedef atomId_t global_t;
38 typedef atomId_t local_t;
39 typedef boost::bimap< global_t, local_t > Global_local_bimap_t;
40 typedef Global_local_bimap_t::value_type idpair_t;
[246e13]41public:
[9291d04]42 Fragmentation(
43 molecule *_mol,
44 AdjacencyList &_FileChecker,
45 const enum HydrogenTreatment _treatment);
[246e13]46 ~Fragmentation();
47
[0f5956]48 int FragmentMolecule(const std::vector<atomId_t> &atomids, int Order, const std::string &prefix, const Graph &ParsedFragmentList, const bool _ParseStateFile);
[99b0dc]49
[ca8bea]50 const Graph& getGraph() const {
51 return TotalGraph;
52 }
[246e13]53
54private:
55
[339910]56 void FragmentBOSSANOVA(molecule *mol, Graph &FragmentList, KeyStack &RootStack);
[246e13]57 int GuesstimateFragmentCount(int order);
58
59 // order at site
[e71325]60 bool CheckOrderAtSite(AtomMask_t &AtomMask, const Graph &GlobalKeySetList, int Order, const std::string &path, bool LoopDoneAlready);
61 bool StoreOrderAtSiteFile(const std::string &path);
[321470]62 bool ParseOrderAtSiteFromFile(const std::vector<atomId_t> &atomids, const std::string &path, const Global_local_bimap_t &global_local_bimap);
[246e13]63
64 // storing fragments
[339910]65 void FillRootStackForSubgraphs(KeyStack &RootStack, const AtomMask_t &AtomMask);
[bfbd4a]66 bool AssignKeySetsToFragment(const Graph &KeySetList, ListOfLocalAtoms_t &ListOfLocalAtoms, Graph &FragmentList, bool FreeList = false);
[339910]67 void TranslateIndicesToGlobalIDs(Graph &FragmentList, int &TotalNumberOfKeySets, Graph &TotalGraph);
[246e13]68
69private:
[99b0dc]70 //!> pointer to molecule that is fragmented
[246e13]71 molecule *mol;
[9291d04]72 //!> whether to treat hydrogen special
73 const enum HydrogenTreatment treatment;
[9511c7]74 //!> reference to an external adjacency for comparison
[0fad93]75 AdjacencyList &FileChecker;
[ca8bea]76 //!> Resulting Graph with all keysets
77 Graph TotalGraph;
[246e13]78};
79
80
81#endif /* FRAGMENTATION_HPP_ */
Note: See TracBrowser for help on using the repository browser.