Action_Thermostats
Adding_Graph_to_ChangeBondActions
Adding_MD_integration_tests
Adding_StructOpt_integration_tests
AutomationFragmentation_failures
Candidate_v1.6.1
Candidate_v1.7.0
ChemicalSpaceEvaluator
Enhanced_StructuralOptimization
Enhanced_StructuralOptimization_continued
Exclude_Hydrogens_annealWithBondGraph
Fix_Verbose_Codepatterns
ForceAnnealing_with_BondGraph
ForceAnnealing_with_BondGraph_continued
ForceAnnealing_with_BondGraph_continued_betteresults
ForceAnnealing_with_BondGraph_contraction-expansion
Gui_displays_atomic_force_velocity
JobMarket_RobustOnKillsSegFaults
JobMarket_StableWorkerPool
PythonUI_with_named_parameters
Recreated_GuiChecks
StoppableMakroAction
TremoloParser_IncreasedPrecision
stable
Last change
on this file since bccbe9 was 54f3d1, checked in by Frederik Heber <heber@…>, 14 years ago |
Removed short-wiring of updates as they are now passed through LinkedCellArrayCache.
- replaced ..._internal() calls by Changes->addUpdate(..) in LinkedCell_Model.
- added some verbosity to allow for following the chain of updates.
- new unit test function lazyUpdatesTest() in LinkedCell_ModelTest.
- TESTFIX: nodeTest() and insertPointCloudTest() needed a forced update at the
right places due to the cached nature now as they access internals bypassing
the automatic updates.
|
-
Property mode
set to
100644
|
File size:
1.4 KB
|
Line | |
---|
1 | /*
|
---|
2 | * LinkedCell_Model_changeModel.hpp
|
---|
3 | *
|
---|
4 | * Created on: Dec 20, 2011
|
---|
5 | * Author: heber
|
---|
6 | */
|
---|
7 |
|
---|
8 | #ifndef LINKEDCELL_MODEL_CHANGEMODEL_HPP_
|
---|
9 | #define LINKEDCELL_MODEL_CHANGEMODEL_HPP_
|
---|
10 |
|
---|
11 | // include config.h
|
---|
12 | #ifdef HAVE_CONFIG_H
|
---|
13 | #include <config.h>
|
---|
14 | #endif
|
---|
15 |
|
---|
16 | #include <boost/function.hpp>
|
---|
17 | #include <map>
|
---|
18 |
|
---|
19 | #include "CodePatterns/Observer/Observable.hpp"
|
---|
20 |
|
---|
21 | #include "LinkedCell_Model.hpp"
|
---|
22 | #include "LinkedCell_Model_Update.hpp"
|
---|
23 |
|
---|
24 | class TesselPoint;
|
---|
25 |
|
---|
26 | namespace LinkedCell {
|
---|
27 |
|
---|
28 | /** This structures encapsulates changes occuring to the model.
|
---|
29 | *
|
---|
30 | * We do this mostly to keep the Observer LinkedCell_Model away from the
|
---|
31 | * Observable which we need for the Cacheable LinkedCell_Model::N.
|
---|
32 | */
|
---|
33 | class LinkedCell_Model::changeModel : public Observable
|
---|
34 | {
|
---|
35 | //!> grant LinkedCell_ModelTest test access to queue
|
---|
36 | friend class ::LinkedCell_ModelTest;
|
---|
37 | public:
|
---|
38 |
|
---|
39 | explicit changeModel(const double distance);
|
---|
40 | ~changeModel();
|
---|
41 |
|
---|
42 | void addUpdate(
|
---|
43 | const TesselPoint *Walker,
|
---|
44 | const Update::PriorityLevel priority,
|
---|
45 | boost::function<void (const TesselPoint *)> _updateMethod
|
---|
46 | );
|
---|
47 | private:
|
---|
48 | //!> grant LinkedCell_Model access to bind LinkedCellArrayCache to update funcation
|
---|
49 | friend class LinkedCell_Model;
|
---|
50 | void performUpdates();
|
---|
51 | private:
|
---|
52 | typedef std::map<const TesselPoint *, Update*> UpdateQueueMap;
|
---|
53 | UpdateQueueMap queue;
|
---|
54 | };
|
---|
55 |
|
---|
56 | } // namespace LinkedCell
|
---|
57 |
|
---|
58 |
|
---|
59 | #endif /* LINKEDCELL_MODEL_CHANGEMODEL_HPP_ */
|
---|
Note:
See
TracBrowser
for help on using the repository browser.