source: src/Analysis/analysis_correlation.hpp@ 325687

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 Candidate_v1.7.0 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
Last change on this file since 325687 was 325687, checked in by Frederik Heber <heber@…>, 14 years ago

DipoleAngularCorrelation() - External zero orientation vector may be given.

  • Property mode set to 100644
File size: 7.8 KB
RevLine 
[c4d4df]1/*
2 * analysis.hpp
3 *
4 * Created on: Oct 13, 2009
5 * Author: heber
6 */
7
8#ifndef ANALYSIS_HPP_
9#define ANALYSIS_HPP_
10
11using namespace std;
12
13/*********************************************** includes ***********************************/
14
15// include config.h
16#ifdef HAVE_CONFIG_H
17#include <config.h>
18#endif
19
[146cff2]20#include <cmath>
[92e5cb]21#include <iomanip>
[c4d4df]22#include <fstream>
23
24// STL headers
25#include <map>
[e65de8]26#include <vector>
[c4d4df]27
[e4fe8d]28#include "Helpers/defs.hpp"
[c4d4df]29
30#include "atom.hpp"
[92e5cb]31#include "CodePatterns/Info.hpp"
32#include "CodePatterns/Log.hpp"
[1cc661]33#include "CodePatterns/Range.hpp"
[ad011c]34#include "CodePatterns/Verbose.hpp"
[255829]35#include "Helpers/helpers.hpp"
[c4d4df]36
37/****************************************** forward declarations *****************************/
38
39class BoundaryTriangleSet;
[ea430a]40class Formula;
[c4d4df]41class element;
42class LinkedCell;
43class Tesselation;
44class Vector;
45
46/********************************************** definitions *********************************/
47
48typedef multimap<double, pair<atom *, atom *> > PairCorrelationMap;
[4b8630]49typedef multimap<double, atom * > DipoleAngularCorrelationMap;
[208237b]50typedef multimap<double, pair<molecule *, molecule *> > DipoleCorrelationMap;
[776b64]51typedef multimap<double, pair<atom *, const Vector *> > CorrelationToPointMap;
[c4d4df]52typedef multimap<double, pair<atom *, BoundaryTriangleSet *> > CorrelationToSurfaceMap;
53typedef map<double, int> BinPairMap;
54
55/********************************************** declarations *******************************/
56
[1cc661]57range<size_t> getMaximumTrajectoryBounds(std::vector<atom *> &atoms);
[0a7fad]58std::map<atomId_t, Vector> CalculateZeroAngularDipole(std::vector<atom *> &atoms);
[1cc661]59
[325687]60DipoleAngularCorrelationMap *DipoleAngularCorrelation(std::vector<atom *> &atoms, std::map<atomId_t, Vector> &ZeroVector);
[208237b]61DipoleCorrelationMap *DipoleCorrelation(std::vector<molecule *> &molecules);
[e5c0a1]62PairCorrelationMap *PairCorrelation(std::vector<molecule *> &molecules, const std::vector<const element *> &elements);
63CorrelationToPointMap *CorrelationToPoint(std::vector<molecule *> &molecules, const std::vector<const element *> &elements, const Vector *point );
64CorrelationToSurfaceMap *CorrelationToSurface(std::vector<molecule *> &molecules, const std::vector<const element *> &elements, const Tesselation * const Surface, const LinkedCell *LC );
65PairCorrelationMap *PeriodicPairCorrelation(std::vector<molecule *> &molecules, const std::vector<const element *> &elements, const int ranges[NDIM] );
66CorrelationToPointMap *PeriodicCorrelationToPoint(std::vector<molecule *> &molecules, const std::vector<const element *> &elements, const Vector *point, const int ranges[NDIM] );
67CorrelationToSurfaceMap *PeriodicCorrelationToSurface(std::vector<molecule *> &molecules, const std::vector<const element *> &elements, const Tesselation * const Surface, const LinkedCell *LC, const int ranges[NDIM] );
[bd61b41]68int GetBin ( const double value, const double BinWidth, const double BinStart );
[92e5cb]69void OutputCorrelation_Header( ofstream * const file );
70void OutputCorrelation_Value( ofstream * const file, BinPairMap::const_iterator &runner );
71void OutputDipoleAngularCorrelation_Header( ofstream * const file );
72void OutputDipoleAngularCorrelation_Value( ofstream * const file, DipoleAngularCorrelationMap::const_iterator &runner );
[208237b]73void OutputDipoleCorrelation_Header( ofstream * const file );
74void OutputDipoleCorrelation_Value( ofstream * const file, DipoleCorrelationMap::const_iterator &runner );
[92e5cb]75void OutputPairCorrelation_Header( ofstream * const file );
76void OutputPairCorrelation_Value( ofstream * const file, PairCorrelationMap::const_iterator &runner );
77void OutputCorrelationToPoint_Header( ofstream * const file );
78void OutputCorrelationToPoint_Value( ofstream * const file, CorrelationToPointMap::const_iterator &runner );
79void OutputCorrelationToSurface_Header( ofstream * const file );
80void OutputCorrelationToSurface_Value( ofstream * const file, CorrelationToSurfaceMap::const_iterator &runner );
[c4d4df]81
82/** Searches for lowest and highest value in a given map of doubles.
83 * \param *map map of doubles to scan
84 * \param &min minimum on return
85 * \param &max maximum on return
86 */
87template <typename T> void GetMinMax ( T *map, double &min, double &max)
88{
89 min = 0.;
90 max = 0.;
91 bool FirstMinFound = false;
92 bool FirstMaxFound = false;
93
[f74d08]94 if (map == NULL) {
[58ed4a]95 DoeLog(0) && (eLog()<< Verbose(0) << "Nothing to min/max, map is NULL!" << endl);
[e359a8]96 performCriticalExit();
[f74d08]97 return;
98 }
99
[c4d4df]100 for (typename T::iterator runner = map->begin(); runner != map->end(); ++runner) {
101 if ((min > runner->first) || (!FirstMinFound)) {
102 min = runner->first;
103 FirstMinFound = true;
104 }
105 if ((max < runner->first) || (!FirstMaxFound)) {
106 max = runner->first;
107 FirstMaxFound = true;
108 }
109 }
110};
111
112/** Puts given correlation data into bins of given size (histogramming).
113 * Note that BinStart and BinEnd are desired to fill the complete range, even where Bins are zero. If this is
[790807]114 * not desired, give equal BinStart and BinEnd and the map will contain only Bins where the count is one or greater. If a
115 * certain start value is desired, give BinStart and a BinEnd that is smaller than BinStart, then only BinEnd will be
116 * calculated automatically, i.e. BinStart = 0. and BinEnd = -1. .
[c4d4df]117 * Also note that the range is given inclusive, i.e. [ BinStart, BinEnd ].
118 * \param *map map of doubles to count
119 * \param BinWidth desired width of the binds
120 * \param BinStart first bin
121 * \param BinEnd last bin
122 * \return Map of doubles (the bins) with counts as values
123 */
[e138de]124template <typename T> BinPairMap *BinData ( T *map, const double BinWidth, const double BinStart, const double BinEnd )
[c4d4df]125{
126 BinPairMap *outmap = new BinPairMap;
[bd61b41]127 int bin = 0;
[c4d4df]128 double start = 0.;
129 double end = 0.;
130 pair <BinPairMap::iterator, bool > BinPairMapInserter;
131
[f74d08]132 if (map == NULL) {
[58ed4a]133 DoeLog(0) && (eLog()<< Verbose(0) << "Nothing to bin, is NULL!" << endl);
[e359a8]134 performCriticalExit();
[f74d08]135 return outmap;
136 }
137
[c4d4df]138 if (BinStart == BinEnd) { // if same, find range ourselves
139 GetMinMax( map, start, end);
[790807]140 } else if (BinEnd < BinStart) { // if BinEnd smaller, just look for new max
141 GetMinMax( map, start, end);
142 start = BinStart;
143 } else { // else take both values
[c4d4df]144 start = BinStart;
145 end = BinEnd;
146 }
[85da4e]147 for (int runner = 0; runner <= ceil((end-start)/BinWidth); runner++)
148 outmap->insert( pair<double, int> ((double)runner*BinWidth+start, 0) );
[c4d4df]149
150 for (typename T::iterator runner = map->begin(); runner != map->end(); ++runner) {
151 bin = GetBin (runner->first, BinWidth, start);
[bd61b41]152 BinPairMapInserter = outmap->insert ( pair<double, int> ((double)bin*BinWidth+start, 1) );
[c4d4df]153 if (!BinPairMapInserter.second) { // bin already present, increase
154 BinPairMapInserter.first->second += 1;
155 }
156 }
157
158 return outmap;
159};
160
[92e5cb]161/** Prints correlation map of template type to file.
162 * \param *file file to write to
163 * \param *map map to write
164 * \param (*header) pointer to function that adds specific part to header
165 * \param (*value) pointer to function that prints value from given iterator
166 */
167template <typename T>
168void OutputCorrelationMap(
169 ofstream * const file,
170 const T * const map,
171 void (*header)( ofstream * const file),
172 void (*value)( ofstream * const file, typename T::const_iterator &runner)
173 )
174{
175 Info FunctionInfo(__func__);
176 *file << "BinStart\tBinCenter\tBinEnd";
177 header(file);
178 *file << endl;
179 typename T::const_iterator advancer = map->begin();
180 typename T::const_iterator runner = map->begin();
181 if (advancer != map->end())
182 advancer++;
183 for ( ;(advancer != map->end()) && (runner != map->end()); ++advancer, ++runner) {
184 *file << setprecision(8)
185 << runner->first << "\t"
186 << (advancer->first + runner->first)/2. << "\t"
187 << advancer->first << "\t";
188 value(file, runner);
189 *file << endl;
190 }
191 if(runner != map->end()) {
192 *file << setprecision(8) << runner->first << "\t0\t0\t";
193 value(file, runner);
194 *file << endl;
195 }
196};
197
198
[c4d4df]199#endif /* ANALYSIS_HPP_ */
Note: See TracBrowser for help on using the repository browser.