source: src/Actions/FragmentationAction/StructuralOptimizationAction.cpp@ 13e5be

stable v1.7.0
Last change on this file since 13e5be was efd020, checked in by Frederik Heber <frederik.heber@…>, 8 years ago

Readded step-world-time to StructuralOptimization.

  • adapted ForceAnnealing and its Action accordingly, i.e. they receive the old time step as the current step.
  • TESTFIX: needed to add "--step-world-time 1" to ForceAnnealing regression test, results then remained exactly the same.
  • Property mode set to 100644
File size: 5.1 KB
Line 
1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2014 Frederik Heber. All rights reserved.
5 *
6 *
7 * This file is part of MoleCuilder.
8 *
9 * MoleCuilder is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation, either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * MoleCuilder is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with MoleCuilder. If not, see <http://www.gnu.org/licenses/>.
21 */
22
23/*
24 * StructuralOptimizationAction.cpp
25 *
26 * Created on: Aug 02, 2014
27 * Author: heber
28 */
29
30// include config.h
31#ifdef HAVE_CONFIG_H
32#include <config.h>
33#endif
34
35//#include "CodePatterns/MemDebug.hpp"
36
37#include "CodePatterns/Chronos.hpp"
38
39#include "Actions/FragmentationAction/AnalyseFragmentationResultsAction.hpp"
40#include "Actions/FragmentationAction/FragmentationAutomationAction.hpp"
41#include "Actions/FragmentationAction/StructuralOptimizationAction.hpp"
42#include "Actions/MoleculeAction/ForceAnnealingAction.hpp"
43#include "Actions/ActionQueue.hpp"
44#include "Actions/ActionSequence.hpp"
45
46#include "Descriptors/AtomDescriptor.hpp"
47
48using namespace MoleCuilder;
49
50// and construct the stuff
51#include "StructuralOptimizationAction.def"
52#include "MakroAction_impl_pre.hpp"
53/** =========== define the function ====================== */
54
55// static instances
56ActionSequence FragmentationStructuralOptimizationAction::prototype_actions;
57bool FragmentationStructuralOptimizationAction::isPrepared = false;
58
59void FragmentationStructuralOptimizationAction::prepare(ActionRegistry &AR)
60{
61 // perform a verlet-integration first, if there are already forces or velocities
62 // present. If not, we still copy the position cleanly into a new step where then
63 // forces are set according to summed fragmentary contributions. This is much cleaner.
64 prototype_actions.addAction(AR.getActionByName(std::string("destroy-adjacency")).clone());
65 prototype_actions.addAction(AR.getActionByName(std::string("create-adjacency")).clone());
66 prototype_actions.addAction(AR.getActionByName(std::string("correct-bonddegree")).clone());
67 prototype_actions.addAction(AR.getActionByName(std::string("update-molecules")).clone());
68 prototype_actions.addAction(AR.getActionByName(std::string("fragment-molecule")).clone());
69 prototype_actions.addAction(AR.getActionByName(std::string("fragment-automation")).clone());
70 prototype_actions.addAction(AR.getActionByName(std::string("analyse-fragment-results")).clone());
71 prototype_actions.addAction(AR.getActionByName(std::string("step-world-time")).clone());
72 prototype_actions.addAction(AR.getActionByName(std::string("force-annealing")).clone());
73 prototype_actions.addAction(AR.getActionByName(std::string("output")).clone());
74 prototype_actions.addAction(AR.getActionByName(std::string("clear-fragment-results")).clone());
75 isPrepared = true;
76}
77
78void FragmentationStructuralOptimizationAction::unprepare(ActionRegistry &AR)
79{
80 // empty sequence
81 Action *actionremove = NULL;
82 while ((actionremove = prototype_actions.removeLastAction()) != NULL)
83 delete actionremove;
84 isPrepared = false;
85}
86
87ActionState::ptr FragmentationStructuralOptimizationAction::performCall(){
88
89 // set number of steps
90 setLoop(params.steps.get());
91 // remove output from sequence if not desired.
92 if (!params.DoOutput.get()) {
93#ifndef NDEBUG
94 bool status =
95#endif
96 removeAction(std::string("output"));
97 ASSERT( status,
98 "FragmentationStructuralOptimizationAction::performCall() - output not found in ActionSequence.");
99 }
100 // don't recreate bond graph if not desired
101 if (params.DontCreateGraphEachStep.get()) {
102#ifndef NDEBUG
103 bool status = true;
104 status &=
105#endif
106 removeAction(std::string("destroy-adjacency"));
107
108#ifndef NDEBUG
109 status &=
110#endif
111 removeAction(std::string("create-adjacency"));
112
113#ifndef NDEBUG
114 status &=
115#endif
116 removeAction(std::string("correct-bonddegree"));
117
118#ifndef NDEBUG
119 status &=
120#endif
121 removeAction(std::string("update-molecules"));
122 ASSERT( status,
123 "FragmentationStructuralOptimizationAction::performCall() - at least one graph action not found in ActionSequence.");
124 }
125 // and call
126 ActionState::ptr state(MakroAction::performCall());
127
128 return state;
129}
130
131ActionState::ptr FragmentationStructuralOptimizationAction::performUndo(ActionState::ptr _state) {
132 ActionState::ptr state(MakroAction::performUndo(_state));
133
134 return state;
135}
136
137ActionState::ptr FragmentationStructuralOptimizationAction::performRedo(ActionState::ptr _state){
138 ActionState::ptr state(MakroAction::performRedo(_state));
139
140 return state;
141}
142
143bool FragmentationStructuralOptimizationAction::canUndo(){
144 return true;
145}
146
147bool FragmentationStructuralOptimizationAction::shouldUndo(){
148 return true;
149}
Note: See TracBrowser for help on using the repository browser.