Changeset 3aa8a5 for src/Actions


Ignore:
Timestamp:
Dec 3, 2012, 9:50:01 AM (12 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:
4694df
Parents:
5197e5
git-author:
Frederik Heber <heber@…> (09/21/12 16:22:50)
git-committer:
Frederik Heber <heber@…> (12/03/12 09:50:01)
Message:

REFACTOR: AdjacencyList now just contains a single internal map.

Location:
src/Actions
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • src/Actions/FragmentationAction/FragmentationAction.cpp

    r5197e5 r3aa8a5  
    4747#include "World.hpp"
    4848
     49#include <boost/filesystem.hpp>
    4950#include <iostream>
    5051#include <map>
     
    8081  // go through all atoms, note down their molecules and group them
    8182  typedef std::multimap<molecule *, atom *> clusters_t;
     83  typedef std::vector<atomId_t> atomids_t;
     84  atomids_t atomids;
    8285  clusters_t clusters;
    8386  for (World::AtomSelectionConstIterator iter = world.beginAtomSelection();
    8487      iter != world.endAtomSelection(); ++iter) {
    8588    clusters.insert( std::make_pair(iter->second->getMolecule(), iter->second) );
     89    atomids.push_back(iter->second->getId());
    8690  }
    8791  LOG(1, "INFO: There are " << clusters.size()  << " molecules to consider.");
     
    9195
    9296  // parse in Adjacency file
    93   std::ifstream File;
    94   std::string filename;
    95   filename = params.prefix.get() + ADJACENCYFILE;
    96   File.open(filename.c_str(), ios::out);
    97   AdjacencyList FileChecker(File);
     97  boost::shared_ptr<AdjacencyList> FileChecker;
     98  boost::filesystem::path filename(params.prefix.get() + std::string(ADJACENCYFILE));
     99  if (boost::filesystem::exists(filename) && boost::filesystem::is_regular_file(filename)) {
     100    std::ifstream File;
     101    File.open(filename.string().c_str(), ios::out);
     102    FileChecker.reset(new AdjacencyList(File));
     103    File.close();
     104  } else {
     105    LOG(1, "INFO: Could not open default adjacency file " << filename.string() << ".");
     106    FileChecker.reset(new AdjacencyList);
     107  }
    98108
    99109  DepthFirstSearchAnalysis DFS;
     
    119129        << " atoms, out of " << mol->getAtomCount() << ".");
    120130    const enum HydrogenSaturation saturation =  params.DoSaturation.get() ? DoSaturate : DontSaturate;
    121     Fragmentation Fragmenter(mol, FileChecker, saturation);
     131    Fragmentation Fragmenter(mol, *FileChecker, saturation);
    122132
    123133    // perform fragmentation
     
    134144  }
    135145  LOG(0, "STATUS: There are " << keysetcounter << " fragments.");
     146
    136147  // store molecule's fragment to file
    137   ExportGraph_ToFiles exporter(TotalGraph, saturation);
    138   exporter.setPrefix(params.prefix.get());
    139   exporter.setOutputTypes(params.types.get());
    140   exporter();
     148  {
     149    ExportGraph_ToFiles exporter(TotalGraph, saturation);
     150    exporter.setPrefix(params.prefix.get());
     151    exporter.setOutputTypes(params.types.get());
     152    exporter();
     153  }
     154
     155  // store Adjacency to file
     156  {
     157    std::string filename = params.prefix.get() + ADJACENCYFILE;
     158    std::ofstream AdjacencyFile;
     159    AdjacencyFile.open(filename.c_str(), ios::out);
     160    AdjacencyList adjacency(atomids);
     161    adjacency.StoreToFile(AdjacencyFile);
     162    AdjacencyFile.close();
     163  }
     164
    141165  World::getInstance().setExitFlag(ExitFlag);
    142166  end = clock();
    143167  LOG(0, "STATUS: Clocks for this operation: " << (end-start) << ", time: " << ((double)(end-start)/CLOCKS_PER_SEC) << "s.");
    144 
    145168
    146169  return Action::success;
  • src/Actions/MoleculeAction/SaveAdjacencyAction.cpp

    r5197e5 r3aa8a5  
    4040
    4141#include "CodePatterns/Log.hpp"
    42 #include "Graph/BondGraph.hpp"
     42#include "Graph/AdjacencyList.hpp"
    4343#include "molecule.hpp"
    4444#include "World.hpp"
     
    5555  molecule *mol = NULL;
    5656
     57  // gather all desired ids
     58  typedef std::vector<atomId_t> atomids_t;
     59  atomids_t atomids;
    5760  for (World::MoleculeSelectionIterator iter = World::getInstance().beginMoleculeSelection(); iter != World::getInstance().endMoleculeSelection(); ++iter) {
    5861    mol = iter->second;
    59     LOG(0, "Storing adjacency to path " << params.adjacencyfile.get() << ".");
    60     // TODO: sollte stream nicht filename benutzen, besser fuer unit test
    61     mol->StoreAdjacencyToFile(params.adjacencyfile.get().leaf().string(), params.adjacencyfile.get().branch_path().string());
     62    const molecule::atomIdSet &mol_atomids = mol->getAtomIds();
     63    atomids.insert(atomids.end(), mol_atomids.begin(), mol_atomids.end());
    6264  }
     65
     66  // store to file
     67  AdjacencyList adjacency(atomids);
     68  std::ofstream AdjacencyFile;
     69  const std::string filename = params.adjacencyfile.get().string();
     70  LOG(0, "STATUS: Storing adjacency of selected molecules to " << filename << ".");
     71  AdjacencyFile.open(filename.c_str(), ios::out);
     72  adjacency.StoreToFile(AdjacencyFile);
     73  AdjacencyFile.close();
     74
    6375  return Action::success;
    6476}
Note: See TracChangeset for help on using the changeset viewer.