source: src/analysis_correlation.hpp@ e4decc

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 e4decc was 146cff2, checked in by Frederik Heber <heber@…>, 15 years ago

FIX: include <cmath> missing in some files.

  • Property mode set to 100644
File size: 5.3 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>
[c4d4df]21#include <fstream>
22
23// STL headers
24#include <map>
[e65de8]25#include <vector>
[c4d4df]26
27#include "defs.hpp"
28
29#include "atom.hpp"
[952f38]30#include "Helpers/Verbose.hpp"
[c4d4df]31
32/****************************************** forward declarations *****************************/
33
34class BoundaryTriangleSet;
35class element;
36class LinkedCell;
37class Tesselation;
38class Vector;
39
40/********************************************** definitions *********************************/
41
42typedef multimap<double, pair<atom *, atom *> > PairCorrelationMap;
[776b64]43typedef multimap<double, pair<atom *, const Vector *> > CorrelationToPointMap;
[c4d4df]44typedef multimap<double, pair<atom *, BoundaryTriangleSet *> > CorrelationToSurfaceMap;
45typedef map<double, int> BinPairMap;
46
47/********************************************** declarations *******************************/
48
[e5c0a1]49PairCorrelationMap *PairCorrelation(std::vector<molecule *> &molecules, const std::vector<const element *> &elements);
50CorrelationToPointMap *CorrelationToPoint(std::vector<molecule *> &molecules, const std::vector<const element *> &elements, const Vector *point );
51CorrelationToSurfaceMap *CorrelationToSurface(std::vector<molecule *> &molecules, const std::vector<const element *> &elements, const Tesselation * const Surface, const LinkedCell *LC );
52PairCorrelationMap *PeriodicPairCorrelation(std::vector<molecule *> &molecules, const std::vector<const element *> &elements, const int ranges[NDIM] );
53CorrelationToPointMap *PeriodicCorrelationToPoint(std::vector<molecule *> &molecules, const std::vector<const element *> &elements, const Vector *point, const int ranges[NDIM] );
54CorrelationToSurfaceMap *PeriodicCorrelationToSurface(std::vector<molecule *> &molecules, const std::vector<const element *> &elements, const Tesselation * const Surface, const LinkedCell *LC, const int ranges[NDIM] );
[bd61b41]55int GetBin ( const double value, const double BinWidth, const double BinStart );
[a5551b]56void OutputCorrelation( ofstream * const file, const BinPairMap * const map );
[244a84]57void OutputPairCorrelation( ofstream * const file, const PairCorrelationMap * const map );
58void OutputCorrelationToPoint( ofstream * const file, const CorrelationToPointMap * const map );
59void OutputCorrelationToSurface( ofstream * const file, const CorrelationToSurfaceMap * const map );
[c4d4df]60
61
62/** Searches for lowest and highest value in a given map of doubles.
63 * \param *map map of doubles to scan
64 * \param &min minimum on return
65 * \param &max maximum on return
66 */
67template <typename T> void GetMinMax ( T *map, double &min, double &max)
68{
69 min = 0.;
70 max = 0.;
71 bool FirstMinFound = false;
72 bool FirstMaxFound = false;
73
[f74d08]74 if (map == NULL) {
[58ed4a]75 DoeLog(0) && (eLog()<< Verbose(0) << "Nothing to min/max, map is NULL!" << endl);
[e359a8]76 performCriticalExit();
[f74d08]77 return;
78 }
79
[c4d4df]80 for (typename T::iterator runner = map->begin(); runner != map->end(); ++runner) {
81 if ((min > runner->first) || (!FirstMinFound)) {
82 min = runner->first;
83 FirstMinFound = true;
84 }
85 if ((max < runner->first) || (!FirstMaxFound)) {
86 max = runner->first;
87 FirstMaxFound = true;
88 }
89 }
90};
91
92/** Puts given correlation data into bins of given size (histogramming).
93 * Note that BinStart and BinEnd are desired to fill the complete range, even where Bins are zero. If this is
[790807]94 * not desired, give equal BinStart and BinEnd and the map will contain only Bins where the count is one or greater. If a
95 * certain start value is desired, give BinStart and a BinEnd that is smaller than BinStart, then only BinEnd will be
96 * calculated automatically, i.e. BinStart = 0. and BinEnd = -1. .
[c4d4df]97 * Also note that the range is given inclusive, i.e. [ BinStart, BinEnd ].
98 * \param *map map of doubles to count
99 * \param BinWidth desired width of the binds
100 * \param BinStart first bin
101 * \param BinEnd last bin
102 * \return Map of doubles (the bins) with counts as values
103 */
[e138de]104template <typename T> BinPairMap *BinData ( T *map, const double BinWidth, const double BinStart, const double BinEnd )
[c4d4df]105{
106 BinPairMap *outmap = new BinPairMap;
[bd61b41]107 int bin = 0;
[c4d4df]108 double start = 0.;
109 double end = 0.;
110 pair <BinPairMap::iterator, bool > BinPairMapInserter;
111
[f74d08]112 if (map == NULL) {
[58ed4a]113 DoeLog(0) && (eLog()<< Verbose(0) << "Nothing to bin, is NULL!" << endl);
[e359a8]114 performCriticalExit();
[f74d08]115 return outmap;
116 }
117
[c4d4df]118 if (BinStart == BinEnd) { // if same, find range ourselves
119 GetMinMax( map, start, end);
[790807]120 } else if (BinEnd < BinStart) { // if BinEnd smaller, just look for new max
121 GetMinMax( map, start, end);
122 start = BinStart;
123 } else { // else take both values
[c4d4df]124 start = BinStart;
125 end = BinEnd;
126 }
[85da4e]127 for (int runner = 0; runner <= ceil((end-start)/BinWidth); runner++)
128 outmap->insert( pair<double, int> ((double)runner*BinWidth+start, 0) );
[c4d4df]129
130 for (typename T::iterator runner = map->begin(); runner != map->end(); ++runner) {
131 bin = GetBin (runner->first, BinWidth, start);
[bd61b41]132 BinPairMapInserter = outmap->insert ( pair<double, int> ((double)bin*BinWidth+start, 1) );
[c4d4df]133 if (!BinPairMapInserter.second) { // bin already present, increase
134 BinPairMapInserter.first->second += 1;
135 }
136 }
137
138 return outmap;
139};
140
141#endif /* ANALYSIS_HPP_ */
Note: See TracBrowser for help on using the repository browser.