source: src/Fragmentation/Summation/SetValues/SamplingGrid.cpp@ 5b1e5e

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_StructOpt_integration_tests Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator 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_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion GeometryObjects Gui_displays_atomic_force_velocity IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks RotateToPrincipalAxisSystem_UndoRedo StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps Ubuntu_1604_changes stable
Last change on this file since 5b1e5e was 5b1e5e, checked in by Frederik Heber <heber@…>, 9 years ago

FIX: Replaced 3 by NDIM in SamplingGrid which avoids some confusion with numeric grid levels.

  • Property mode set to 100644
File size: 21.9 KB
RevLine 
[28c025]1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2012 University of Bonn. All rights reserved.
[5aaa43]5 * Copyright (C) 2013 Frederik Heber. All rights reserved.
[28c025]6 *
7 *
8 * This file is part of MoleCuilder.
9 *
10 * MoleCuilder is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * MoleCuilder is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with MoleCuilder. If not, see <http://www.gnu.org/licenses/>.
22 */
23
24/*
25 * SamplingGrid.cpp
26 *
27 * Created on: 25.07.2012
28 * Author: heber
29 */
30
31// include config.h
32#ifdef HAVE_CONFIG_H
33#include <config.h>
34#endif
35
36// include headers that implement a archive in simple text format
37// otherwise BOOST_CLASS_EXPORT_IMPLEMENT has no effect
38#include <boost/archive/text_oarchive.hpp>
39#include <boost/archive/text_iarchive.hpp>
40
41#include "CodePatterns/MemDebug.hpp"
42
[fbf143]43#include "Fragmentation/Summation/SetValues/SamplingGrid.hpp"
[28c025]44
[fb3485]45#include <boost/bind.hpp>
[8eafd6]46#include <algorithm>
[98f8fe]47#include <limits>
48
[c889b7]49#include "CodePatterns/Assert.hpp"
[cb3363]50#include "CodePatterns/Log.hpp"
[28c025]51
[1a00bb]52// static instances
[5b1e5e]53const double SamplingGrid::zeroOffset[NDIM] = { 0., 0., 0. };
[1a00bb]54
55SamplingGrid::SamplingGrid() :
56 SamplingGridProperties()
57{
58 setWindowSize(zeroOffset, zeroOffset);
59 ASSERT( getWindowGridPoints() == (size_t)0,
60 "SamplingGrid::SamplingGrid() - incorrect number of samples given for the window.");
61}
62
[5b1e5e]63SamplingGrid::SamplingGrid(const double _begin[NDIM],
64 const double _end[NDIM],
[c6355f]65 const int _level) :
66 SamplingGridProperties(_begin, _end, _level)
67{
68 setWindowSize(zeroOffset, zeroOffset);
69 ASSERT( getWindowGridPoints() == (size_t)0,
70 "SamplingGrid::SamplingGrid() - incorrect number of samples given for the window.");
71}
72
[5b1e5e]73SamplingGrid::SamplingGrid(const double _begin[NDIM],
74 const double _end[NDIM],
[28c025]75 const int _level,
[c889b7]76 const sampledvalues_t &_sampled_grid) :
[3d9a8d]77 SamplingGridProperties(_begin, _end, _level),
[28c025]78 sampled_grid(_sampled_grid)
[1a00bb]79{
80 setWindowSize(_begin, _end);
81 ASSERT( getWindowGridPoints() == (size_t)_sampled_grid.size(),
82 "SamplingGrid::SamplingGrid() - incorrect number of samples given for the window.");
83}
[28c025]84
85SamplingGrid::SamplingGrid(const SamplingGrid &_grid) :
86 SamplingGridProperties(_grid),
87 sampled_grid(_grid.sampled_grid)
[1a00bb]88{
[c6355f]89 setWindowSize(_grid.begin_window, _grid.end_window);
90 ASSERT( getWindowGridPoints() == _grid.getWindowGridPoints(),
91 "SamplingGrid::SamplingGrid() - incorrect number of samples given for the window.");
[1a00bb]92}
[28c025]93
94SamplingGrid::SamplingGrid(const SamplingGridProperties &_props) :
95 SamplingGridProperties(_props)
[1a00bb]96{
[c6355f]97 setWindowSize(zeroOffset, zeroOffset);
98 ASSERT( getWindowGridPoints() == (size_t)0,
99 "SamplingGrid::SamplingGrid() - incorrect number of samples given for the window.");
[1a00bb]100}
[28c025]101
[c889b7]102SamplingGrid::SamplingGrid(
103 const SamplingGridProperties &_props,
104 const sampledvalues_t &_sampled_grid) :
105 SamplingGridProperties(_props),
106 sampled_grid(_sampled_grid)
[1a00bb]107{
108 setWindowSize(_props.begin, _props.end);
109 ASSERT( getWindowGridPoints() == (size_t)_sampled_grid.size(),
110 "SamplingGrid::SamplingGrid() - incorrect number of samples given for the window.");
111}
[c889b7]112
[28c025]113SamplingGrid::~SamplingGrid()
114{}
115
[c0e8fb]116bool SamplingGrid::isCongruent(const SamplingGrid &_props) const
117{
118 bool status = true;
119 status &= (static_cast<const SamplingGridProperties &>(*this) ==
120 static_cast<const SamplingGridProperties &>(_props));
[5b1e5e]121 for(size_t i = 0; i<NDIM; ++i) {
[c0e8fb]122 status &= begin_window[i] == _props.begin_window[i];
123 status &= end_window[i] == _props.end_window[i];
124 }
125 return status;
126}
127
[c889b7]128SamplingGrid& SamplingGrid::operator=(const SamplingGrid& other)
129{
130 // check for self-assignment
131 if (this != &other) {
132 static_cast<SamplingGridProperties &>(*this) = other;
[e2404f]133 setWindowSize(other.begin_window, other.end_window);
[c889b7]134 sampled_grid = other.sampled_grid;
135 }
136 return *this;
137}
138
[313f83]139static void multiplyElements(
140 double &dest,
141 const double &source,
142 const double prefactor)
143{
144 dest *= prefactor*(source);
145}
146
[8eafd6]147SamplingGrid& SamplingGrid::operator*=(const double _value)
148{
149 std::transform(
150 sampled_grid.begin(), sampled_grid.end(),
151 sampled_grid.begin(),
152 boost::bind(std::multiplies<double>(), _1, _value));
153
154 return *this;
155}
[313f83]156
[a1fcc6]157SamplingGrid& SamplingGrid::operator*=(const SamplingGrid& other)
158{
159 // check that grids are compatible
[313f83]160 if (isCompatible(other)) {
161 /// get minimum of window
[5b1e5e]162 double min_begin_window[NDIM];
163 double min_end_window[NDIM];
[313f83]164 bool doShrink = false;
[5b1e5e]165 for (size_t index=0; index<NDIM;++index) {
[313f83]166 if (begin_window[index] <= other.begin_window[index]) {
167 min_begin_window[index] = other.begin_window[index];
168 doShrink = true;
169 } else {
170 min_begin_window[index] = begin_window[index];
171 }
172 if (end_window[index] <= other.end_window[index]) {
173 min_end_window[index] = end_window[index];
174 } else {
175 min_end_window[index] = other.end_window[index];
176 doShrink = true;
177 }
178 }
[10f0cb]179 LOG(4, "DEBUG: min begin is " << min_begin_window[0] << "," << min_begin_window[1] << "," << min_begin_window[2] << ".");
180 LOG(4, "DEBUG: min end is " << min_end_window[0] << "," << min_end_window[1] << "," << min_end_window[2] << ".");
[313f83]181 if (doShrink)
182 shrinkWindow(min_begin_window, min_end_window);
183 addWindowOntoWindow(
184 other.begin_window,
185 other.end_window,
186 begin_window,
187 end_window,
188 sampled_grid,
189 other.sampled_grid,
190 boost::bind(multiplyElements, _1, _2, 1.),
191 sourcewindow);
[a1fcc6]192 } else {
[c0e8fb]193 ASSERT(0, "SamplingGrid::operator*=() - multiplying incongruent grids is so far not in the cards.");
[a1fcc6]194 }
195 return *this;
196}
197
[c889b7]198void SamplingGrid::superposeOtherGrids(const SamplingGrid &other, const double prefactor)
199{
[1a00bb]200 /// check that grids are compatible
[c889b7]201 if (isCompatible(other)) {
[1a00bb]202 /// get maximum of window
[5b1e5e]203 double max_begin_window[NDIM];
204 double max_end_window[NDIM];
[1a00bb]205 bool doExtend = false;
[5b1e5e]206 for (size_t index=0; index<NDIM;++index) {
[1a00bb]207 if (begin_window[index] >= other.begin_window[index]) {
208 max_begin_window[index] = other.begin_window[index];
209 doExtend = true;
210 } else {
211 max_begin_window[index] = begin_window[index];
212 }
213 if (end_window[index] >= other.end_window[index]) {
214 max_end_window[index] = end_window[index];
215 } else {
216 max_end_window[index] = other.end_window[index];
217 doExtend = true;
218 }
219 }
[10f0cb]220 LOG(4, "DEBUG: max begin is " << max_begin_window[0] << "," << max_begin_window[1] << "," << max_begin_window[2] << ".");
221 LOG(4, "DEBUG: max end is " << max_end_window[0] << "," << max_end_window[1] << "," << max_end_window[2] << ".");
[1a00bb]222 if (doExtend)
223 extendWindow(max_begin_window, max_end_window);
224 /// and copy other into larger window, too
[de6dfb]225 addOntoWindow(other.begin_window, other.end_window, other.sampled_grid, prefactor);
[c889b7]226 } else {
227 ASSERT(0, "SamplingGrid::superposeOtherGrids() - superposing incompatible grids is so far not in the cards.");
228 }
229}
230
[620517]231const size_t SamplingGrid::getWindowGridPointsPerAxis(const size_t axis) const
[3d9a8d]232{
[620517]233 static const double round_offset(
234 (std::numeric_limits<size_t>::round_style == std::round_toward_zero) ?
235 0.5 : 0.); // need offset to get to round_toward_nearest behavior
236// const double total = getTotalLengthPerAxis(axis);
237 const double delta = getDeltaPerAxis(axis);
238 if (delta == 0)
239 return 0;
240 const double length = getWindowLengthPerAxis(axis);
241 if (length == 0)
[1a00bb]242 return 0;
[620517]243 return (size_t)(length/delta+round_offset);
[1a00bb]244}
245
[cb3363]246double SamplingGrid::integral() const
247{
[98f8fe]248 const double volume_element = getVolume()/(double)getTotalGridPoints();
[cb3363]249 double int_value = 0.;
250 for (sampledvalues_t::const_iterator iter = sampled_grid.begin();
251 iter != sampled_grid.end();
252 ++iter)
253 int_value += *iter;
254 int_value *= volume_element;
255 LOG(2, "DEBUG: SamplingGrid::integral() is " << scientific << setprecision(13) << int_value << ".");
256 return int_value;
257}
258
[e72c61]259double SamplingGrid::integral(const SamplingGrid &weight) const
260{
261 if (isCompatible(weight)) {
[98f8fe]262 const double volume_element = getVolume()/(double)getTotalGridPoints();
[e72c61]263 double int_value = 0.;
264 sampledvalues_t::const_iterator iter = sampled_grid.begin();
265 sampledvalues_t::const_iterator weightiter = weight.sampled_grid.begin();
266 for (;iter != sampled_grid.end();++iter,++weightiter)
267 int_value += (*weightiter) * (*iter);
268 int_value *= volume_element;
269 //LOG(2, "DEBUG: SamplingGrid::integral() is " << scientific << setprecision(13) << int_value << ".");
270 return int_value;
271 } else
272 return 0.;
273}
[1a00bb]274void SamplingGrid::setWindowSize(
[5b1e5e]275 const double _begin_window[NDIM],
276 const double _end_window[NDIM])
[1a00bb]277{
[5b1e5e]278 for (size_t index=0;index<NDIM;++index) {
[64bafe0]279 begin_window[index] = getNearestLowerGridPoint(_begin_window[index], index);
280 ASSERT( begin_window[index] >= begin[index],
[e2404f]281 "SamplingGrid::setWindowSize() - window starts earlier than domain on "
282 +toString(index)+"th component.");
[64bafe0]283 end_window[index] = getNearestHigherGridPoint(_end_window[index], index);
284 ASSERT( end_window[index] <= end[index],
[e2404f]285 "SamplingGrid::setWindowSize() - window ends later than domain on "
286 +toString(index)+"th component.");
[1a00bb]287 }
288}
289
290void SamplingGrid::setWindow(
[5b1e5e]291 const double _begin_window[NDIM],
292 const double _end_window[NDIM])
[1a00bb]293{
294 setWindowSize(_begin_window, _end_window);
295 const size_t gridpoints_window = getWindowGridPoints();
[c6355f]296 sampled_grid.clear();
[1a00bb]297 sampled_grid.resize(gridpoints_window, 0.);
298}
299
[e2404f]300void SamplingGrid::setDomain(
[5b1e5e]301 const double _begin[NDIM],
302 const double _end[NDIM])
[e2404f]303{
304 setDomainSize(_begin, _end);
305 setWindowSize(_begin, _end);
306 const size_t gridpoints = getTotalGridPoints();
307 sampled_grid.resize(gridpoints, 0.);
308}
309
[1a00bb]310void SamplingGrid::extendWindow(
[5b1e5e]311 const double _begin_window[NDIM],
312 const double _end_window[NDIM])
[1a00bb]313{
314#ifndef NDEBUG
[5b1e5e]315 for(size_t index=0;index < NDIM; ++index) {
[c6355f]316 // check that we truly have to extend the window
[1a00bb]317 ASSERT ( begin_window[index] >= _begin_window[index],
318 "SamplingGrid::extendWindow() - component "+toString(index)+
319 " of window start is greater than old value.");
320 ASSERT ( end_window[index] <= _end_window[index],
321 "SamplingGrid::extendWindow() - component "+toString(index)+
322 " of window end is less than old value.");
[c6355f]323
324 // check that we are still less than domain
325 ASSERT ( _begin_window[index] >= begin[index],
326 "SamplingGrid::extendWindow() - component "+toString(index)+
327 " of window start is less than domain start.");
328 ASSERT ( _end_window[index] <= end[index],
329 "SamplingGrid::extendWindow() - component "+toString(index)+
330 " of window end is greater than domain end.");
[1a00bb]331 }
332#endif
333 // copy old window size and values
[5b1e5e]334 double old_begin_window[NDIM];
335 double old_end_window[NDIM];
336 for(size_t index=0;index<NDIM;++index) {
[1a00bb]337 old_begin_window[index] = begin_window[index];
338 old_end_window[index] = end_window[index];
339 }
340 sampledvalues_t old_values(sampled_grid);
[de6dfb]341 // set new window
342 setWindow(_begin_window,_end_window);
[1a00bb]343 // now extend it ...
[de6dfb]344 addOntoWindow(old_begin_window, old_end_window, old_values, +1.);
[10f0cb]345 LOG(6, "DEBUG: Grid after extension is " << sampled_grid << ".");
[1a00bb]346}
347
[313f83]348void SamplingGrid::shrinkWindow(
[5b1e5e]349 const double _begin_window[NDIM],
350 const double _end_window[NDIM])
[313f83]351{
352#ifndef NDEBUG
[5b1e5e]353 for(size_t index=0;index < NDIM; ++index) {
[313f83]354 // check that we truly have to shrink the window
355 ASSERT ( begin_window[index] <= _begin_window[index],
356 "SamplingGrid::shrinkWindow() - component "+toString(index)+
357 " of window start is less than old value.");
358 ASSERT ( end_window[index] >= _end_window[index],
359 "SamplingGrid::shrinkWindow() - component "+toString(index)+
360 " of window end is greater than old value.");
361
362 // check that we are still less than domain
363 ASSERT ( _begin_window[index] >= begin[index],
364 "SamplingGrid::shrinkWindow() - component "+toString(index)+
365 " of window start is less than domain start.");
366 ASSERT ( _end_window[index] <= end[index],
367 "SamplingGrid::shrinkWindow() - component "+toString(index)+
368 " of window end is greater than domain end.");
369 }
370#endif
371 // copy old window size and values
[5b1e5e]372 double old_begin_window[NDIM];
373 double old_end_window[NDIM];
374 for(size_t index=0;index<NDIM;++index) {
[313f83]375 old_begin_window[index] = begin_window[index];
376 old_end_window[index] = end_window[index];
377 }
378 sampledvalues_t old_values(sampled_grid);
379 // set new window
380 setWindow(_begin_window,_end_window);
381 // now extend it ...
382 addIntoWindow(old_begin_window, old_end_window, old_values, +1.);
[10f0cb]383 LOG(6, "DEBUG: Grid after extension is " << sampled_grid << ".");
[313f83]384}
385
[fb3485]386static void addElements(
387 double &dest,
388 const double &source,
389 const double prefactor)
390{
391 dest += prefactor*(source);
392}
393
[1a00bb]394void SamplingGrid::addOntoWindow(
[5b1e5e]395 const double _begin_window[NDIM],
396 const double _end_window[NDIM],
[de6dfb]397 const sampledvalues_t &_sampled_grid,
398 const double prefactor)
[fb3485]399{
400 addWindowOntoWindow(
401 begin_window,
402 end_window,
403 _begin_window,
404 _end_window,
405 sampled_grid,
406 _sampled_grid,
407 boost::bind(addElements, _1, _2, boost::cref(prefactor)),
[313f83]408 destwindow);
409}
410
411void SamplingGrid::addIntoWindow(
[5b1e5e]412 const double _begin_window[NDIM],
413 const double _end_window[NDIM],
[313f83]414 const sampledvalues_t &_sampled_grid,
415 const double prefactor)
416{
417 addWindowOntoWindow(
418 _begin_window,
419 _end_window,
420 begin_window,
421 end_window,
422 sampled_grid,
423 _sampled_grid,
424 boost::bind(addElements, _1, _2, boost::cref(prefactor)),
425 sourcewindow);
[fb3485]426}
427
[3f64ee]428void SamplingGrid::getDiscreteWindowIndices(
429 const double *larger_wbegin,
430 const double *larger_wend,
431 const double *smaller_wbegin,
432 const double *smaller_wend,
433 size_t *pre_offset,
434 size_t *post_offset,
435 size_t *length,
436 size_t *total) const
437{
438 const size_t gridpoints_axis = getGridPointsPerAxis();
439 const double round_offset =
440 (std::numeric_limits<size_t>::round_style == std::round_toward_zero) ?
441 0.5 : 0.; // need offset to get to round_toward_nearest behavior
[5b1e5e]442 for(size_t index=0;index<NDIM;++index) {
[3f64ee]443 if (fabs(end[index] - begin[index]) > std::numeric_limits<double>::epsilon()*1e4) {
444 // we refrain from using floor/ceil as the window's starts and ends,
445 // the grids have to be compatible (equal level), should always be on
446 // discrete grid point locations.
447 const double delta = (double)gridpoints_axis/(end[index] - begin[index]);
448 // delta is conversion factor from box length to discrete length, i.e. number of points
449 pre_offset[index] = delta*(smaller_wbegin[index] - larger_wbegin[index])+round_offset;
450 length[index] = delta*(smaller_wend[index] - smaller_wbegin[index])+round_offset;
451 post_offset[index] = delta*(larger_wend[index] - smaller_wend[index])+round_offset;
452 total[index] = delta*(larger_wend[index] - larger_wbegin[index])+round_offset;
453 } else {
454 pre_offset[index] = 0;
455 length[index] = 0;
456 post_offset[index] = 0;
457 total[index] = 0;
458 }
459 // total is used as safe-guard against loss due to discrete conversion
460 ASSERT( pre_offset[index]+post_offset[index]+length[index] == total[index],
461 "SamplingGrid::getDiscreteWindowIndices() - pre, post, and length don't sum up to total for "
462 +toString(index)+"th component.");
463 }
464}
465
[fb3485]466void SamplingGrid::addWindowOntoWindow(
[5b1e5e]467 const double larger_wbegin[NDIM],
468 const double larger_wend[NDIM],
469 const double smaller_wbegin[NDIM],
470 const double smaller_wend[NDIM],
[313f83]471 sampledvalues_t &dest_sampled_grid,
472 const sampledvalues_t &source_sampled_grid,
[fb3485]473 boost::function<void (double &, const double &)> op,
[313f83]474 enum eLargerWindow larger_window)
[1a00bb]475{
476#ifndef NDEBUG
[5b1e5e]477 for(size_t index=0;index<NDIM;++index) {
[313f83]478 ASSERT( smaller_wbegin[index] >= larger_wbegin[index],
[fb3485]479 "SamplingGrid::addWindowOntoWindow() - given smaller window starts earlier than larger window in component "
[1a00bb]480 +toString(index)+".");
[313f83]481 ASSERT( smaller_wend[index] <= larger_wend[index],
[fb3485]482 "SamplingGrid::addWindowOntoWindow() - given smaller window ends later than larger window in component "
[1a00bb]483 +toString(index)+".");
484 }
485#endif
486 // the only issue are indices
[5b1e5e]487 size_t pre_offset[NDIM];
488 size_t post_offset[NDIM];
489 size_t length[NDIM];
490 size_t total[NDIM];
[3f64ee]491 getDiscreteWindowIndices(
492 larger_wbegin, larger_wend,
493 smaller_wbegin, smaller_wend,
494 pre_offset,
495 post_offset,
496 length,
497 total
498 );
[64bafe0]499 // assert that calculated lengths match with given vector sizes
[c6355f]500#ifndef NDEBUG
501 const size_t calculated_size = length[0]*length[1]*length[2];
[313f83]502 if (larger_window == destwindow) {
503 ASSERT( calculated_size == source_sampled_grid.size(),
504 "SamplingGrid::addWindowOntoWindow() - not enough source sampled values given: "
505 +toString(calculated_size)+" != "+toString(source_sampled_grid.size())+".");
506 ASSERT( calculated_size <= dest_sampled_grid.size(),
507 "SamplingGrid::addWindowOntoWindow() - not enough sampled values available: "
508 +toString(calculated_size)+" <= "+toString(dest_sampled_grid.size())+".");
509 } else {
510 ASSERT( calculated_size == dest_sampled_grid.size(),
511 "SamplingGrid::addWindowOntoWindow() - not enough dest sampled values given: "
512 +toString(calculated_size)+" != "+toString(dest_sampled_grid.size())+".");
513 ASSERT( calculated_size <= source_sampled_grid.size(),
514 "SamplingGrid::addWindowOntoWindow() - not enough source sampled values available: "
515 +toString(calculated_size)+" <= "+toString(source_sampled_grid.size())+".");
516 }
[c6355f]517 const size_t total_size = total[0]*total[1]*total[2];
[313f83]518 if (larger_window == destwindow) {
519 ASSERT( total_size == dest_sampled_grid.size(),
520 "SamplingGrid::addWindowOntoWindow() - total size is not equal to number of present dest points: "
521 +toString(total_size)+" != "+toString(dest_sampled_grid.size())+".");
522 } else {
523 ASSERT( total_size == source_sampled_grid.size(),
524 "SamplingGrid::addWindowOntoWindow() - total size is not equal to number of present source points: "
525 +toString(total_size)+" != "+toString(source_sampled_grid.size())+".");
526 }
[c6355f]527#endif
[5b1e5e]528 size_t N[NDIM];
[64bafe0]529// size_t counter = 0;
[313f83]530 sampledvalues_t::iterator destiter = dest_sampled_grid.begin();
531 sampledvalues_t::const_iterator sourceiter = source_sampled_grid.begin();
532 if (larger_window == destwindow)
533 std::advance(destiter, pre_offset[0]*total[1]*total[2]);
[fb3485]534 else
[313f83]535 std::advance(sourceiter, pre_offset[0]*total[1]*total[2]);
[de6dfb]536 for(N[0]=0; N[0] < length[0]; ++N[0]) {
[313f83]537 if (larger_window == destwindow)
538 std::advance(destiter, pre_offset[1]*total[2]);
[fb3485]539 else
[313f83]540 std::advance(sourceiter, pre_offset[1]*total[2]);
[de6dfb]541 for(N[1]=0; N[1] < length[1]; ++N[1]) {
[313f83]542 if (larger_window == destwindow)
543 std::advance(destiter, pre_offset[2]);
[fb3485]544 else
[313f83]545 std::advance(sourceiter, pre_offset[2]);
[de6dfb]546 for(N[2]=0; N[2] < length[2]; ++N[2]) {
[313f83]547 ASSERT( destiter != dest_sampled_grid.end(),
548 "SamplingGrid::addWindowOntoWindow() - destiter is already at end of window.");
549 ASSERT( sourceiter != source_sampled_grid.end(),
550 "SamplingGrid::addWindowOntoWindow() - destiter is already at end of window.");
551 op(*destiter, *sourceiter);
552 ++destiter;
553 ++sourceiter;
[1a00bb]554 }
[313f83]555 if (larger_window == destwindow)
556 std::advance(destiter, post_offset[2]);
[fb3485]557 else
[313f83]558 std::advance(sourceiter, post_offset[2]);
[1a00bb]559 }
[313f83]560 if (larger_window == destwindow)
561 std::advance(destiter, post_offset[1]*total[2]);
[fb3485]562 else
[313f83]563 std::advance(sourceiter, post_offset[1]*total[2]);
[1a00bb]564 }
[c6355f]565#ifndef NDEBUG
[313f83]566 if (larger_window == destwindow)
567 std::advance(destiter, post_offset[0]*total[1]*total[2]);
[fb3485]568 else
[313f83]569 std::advance(sourceiter, post_offset[0]*total[1]*total[2]);
570 ASSERT( destiter == dest_sampled_grid.end(),
571 "SamplingGrid::addWindowOntoWindow() - destiter is not at end of window.");
572 ASSERT( sourceiter == source_sampled_grid.end(),
573 "SamplingGrid::addWindowOntoWindow() - sourceiter is not at end of window.");
[c6355f]574#endif
[10f0cb]575 LOG(8, "DEBUG: Grid after adding other is " << dest_sampled_grid << ".");
[1a00bb]576}
577
[955051]578
579bool SamplingGrid::operator==(const SamplingGrid &other) const
580{
581 bool status =
582 static_cast<const SamplingGridProperties &>(*this)
583 == static_cast<const SamplingGridProperties &>(other);
584 // compare general properties
585 if (status) {
586 // compare windows
[5b1e5e]587 for (size_t i=0; i<NDIM; ++i) {
[955051]588 status &= begin_window[i] == other.begin_window[i];
589 status &= end_window[i] == other.end_window[i];
590 }
591 // compare grids
592 if (status)
593 status &= sampled_grid == other.sampled_grid;
594 }
595 return status;
596}
597
[c889b7]598std::ostream & operator<<(std::ostream &ost, const SamplingGrid& other)
599{
[1a00bb]600 ost << "SamplingGrid";
601 ost << " starting at " << other.begin[0] << "," << other.begin[1] << "," << other.begin[2];
602 ost << " ending at " << other.end[0] << "," << other.end[1] << "," << other.end[2];
603 ost << ", window starting at " << other.begin_window[0] << "," << other.begin_window[1] << "," << other.begin_window[2];
604 ost << ", window ending at " << other.end_window[0] << "," << other.end_window[1] << "," << other.end_window[2];
[80959a1]605 ost << ", level of " << other.level;
606 ost << " and integrated value of " << other.integral();
[c889b7]607 return ost;
608}
609
[beb16e]610template<> SamplingGrid ZeroInstance<SamplingGrid>()
611{
612 SamplingGrid returnvalue;
613 return returnvalue;
614}
615
[28c025]616// we need to explicitly instantiate the serialization functions as
617// its is only serialized through its base class FragmentJob
618BOOST_CLASS_EXPORT_IMPLEMENT(SamplingGrid)
Note: See TracBrowser for help on using the repository browser.