Changeset 336da8 for src


Ignore:
Timestamp:
Sep 14, 2016, 6:42:53 PM (9 years ago)
Author:
Frederik Heber <heber@…>
Branches:
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
Children:
ca4b372
Parents:
c1948c
git-author:
Frederik Heber <heber@…> (06/01/16 08:51:01)
git-committer:
Frederik Heber <heber@…> (09/14/16 18:42:53)
Message:

WindowGrid_converter's refactored a bit with getDiscreteWindowOffsets().

  • Added SamplingGrid::getDiscreteWindowOffsets().
  • WindowGrid_converter now also use NDIM instead of 3 to clarify the use of the spatial degrees of freedom (and not some grid level or else).
Location:
src
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • src/Fragmentation/Summation/SetValues/SamplingGrid.cpp

    rc1948c r336da8  
    452452    ASSERT( (_wend[index] - _wbegin[index]) == _wlength[index],
    453453        "SamplingGrid::getDiscreteWindowCopyIndices() - end - begin is not equal to length for "
     454        +toString(index)+"th component.");
     455  }
     456}
     457
     458void SamplingGrid::getDiscreteWindowOffsets(
     459    size_t _pre_offset[NDIM],
     460    size_t _post_offset[NDIM],
     461    size_t _length[NDIM],
     462    size_t _total[NDIM]) const
     463{
     464  const double round_offset =
     465      (std::numeric_limits<size_t>::round_style == std::round_toward_zero) ?
     466          0.5 : 0.; // need offset to get to round_toward_nearest behavior
     467  for(size_t index=0;index<NDIM;++index) {
     468    if (fabs(end[index] - begin[index]) > std::numeric_limits<double>::epsilon()*1e4) {
     469      // we refrain from using floor/ceil as the window's starts and ends,
     470      // the grids have to be compatible (equal level), should always be on
     471      // discrete grid point locations.
     472      const double delta = getDeltaPerAxis(index);
     473      // delta is conversion factor from box length to discrete length, i.e. number of points
     474      _pre_offset[index] = (begin_window[index] - begin[index])/delta+round_offset;
     475      _post_offset[index] = (end[index] - end_window[index])/delta+round_offset;
     476      _length[index] = (end_window[index] - begin_window[index])/delta+round_offset;
     477      _total[index] = (end[index] - begin[index])/delta+round_offset;
     478    } else {
     479      _pre_offset[index] = 0;
     480      _post_offset[index] = 0;
     481      _length[index] = 0;
     482      _total[index] = 0;
     483    }
     484    // total is used as safe-guard against loss due to discrete conversion
     485    ASSERT( (_pre_offset[index] + _post_offset[index]) + _length[index] == _total[index],
     486        "SamplingGrid::getDiscreteWindowCopyIndices() - pre, length, post are not equal to total for "
    454487        +toString(index)+"th component.");
    455488  }
  • src/Fragmentation/Summation/SetValues/SamplingGrid.hpp

    rc1948c r336da8  
    253253      size_t _wend[NDIM]) const;
    254254
     255  /** Returns number of grid points before the window, during the window, and
     256   * after the window including the total length of the domain for check.
     257   *
     258   * \param _pre_offset grid points before start of window
     259   * \param _post_offset grid points after end of window
     260   * \param _length grid points in window
     261   * \param _total grid points in domain
     262   */
     263  void getDiscreteWindowOffsets(
     264      size_t _pre_offset[NDIM],
     265      size_t _post_offset[NDIM],
     266      size_t _length[NDIM],
     267      size_t _total[NDIM]) const;
     268
    255269  /** Equality operator.
    256270   *
  • src/Jobs/WindowGrid_converter.cpp

    rc1948c r336da8  
    5959{
    6060#ifndef NDEBUG
    61   for(size_t index=0;index<3;++index) {
     61  for(size_t index=0;index<NDIM;++index) {
    6262    ASSERT( window.begin[index] >= window.begin_window[index],
    6363        "InterfaceVMGJob::addGridOntoWindow() - given grid starts earlier than window in component "
     
    6969#endif
    7070  // the only issue are indices
    71   const size_t gridpoints_axis = window.getGridPointsPerAxis();
    72   size_t pre_offset[3];
    73   size_t post_offset[3];
    74   size_t length[3];
    75   size_t total[3];
    76   const double round_offset =
    77       (std::numeric_limits<size_t>::round_style == std::round_toward_zero) ?
    78           0.5 : 0.; // need offset to get to round_toward_nearest behavior
    79   for(size_t index=0;index<3;++index) {
    80     const double delta = (double)gridpoints_axis/(window.end[index] - window.begin[index]);
    81     // delta is conversion factor from box length to discrete length, i.e. number of points
    82     pre_offset[index] = delta*(window.begin[index] - window.begin_window[index])+round_offset;
    83     length[index] = delta*(window.end[index] - window.begin[index])+round_offset;
    84     post_offset[index] = delta*(window.end_window[index] - window.end[index])+round_offset;
    85     total[index] = delta*(window.end_window[index] - window.begin_window[index])+round_offset;
    86     // total is used as safe-guard against loss due to discrete conversion
    87     ASSERT( pre_offset[index]+post_offset[index]+length[index] == total[index],
    88         "InterfaceVMGJob::addGridOntoWindow() - pre, post, and length don't sum up to total for "
    89         +toString(index)+"th component.");
    90   }
     71  size_t pre_offset[NDIM];
     72  size_t post_offset[NDIM];
     73  size_t length[NDIM];
     74  size_t total[NDIM];
     75  window.getDiscreteWindowOffsets(pre_offset, post_offset, length, total);
    9176#ifndef NDEBUG
    9277  const size_t calculated_size = length[0]*length[1]*length[2];
    93 //  const size_t given_size = std::distance(grid_begin, grid_end);
    94 //  ASSERT( calculated_size == given_size,
    95 //      "InterfaceVMGJob::addGridOntoWindow() - not enough sampled values given: "
    96 //      +toString(calculated_size)+" != "+toString(given_size)+".");
    9778  ASSERT( calculated_size <=  window.sampled_grid.size(),
    9879      "InterfaceVMGJob::addGridOntoWindow() - not enough sampled values available: "
     
    10384      +toString(total_size)+" != "+toString(window.sampled_grid.size())+".");
    10485#endif
    105   size_t N[3];
     86  size_t N[NDIM];
    10687  SamplingGrid::sampledvalues_t::iterator griditer = window.sampled_grid.begin();
    10788  std::advance(griditer, pre_offset[0]*total[1]*total[2]);
     
    183164{
    184165#ifndef NDEBUG
    185   for(size_t index=0;index<3;++index) {
     166  for(size_t index=0;index<NDIM;++index) {
    186167    ASSERT( grid.begin_window[index] >= grid.begin[index],
    187168        "InterfaceVMGJob::addWindowOntoGrid() - given window starts earlier than grid in component "
     
    193174#endif
    194175  // the only issue are indices
    195   const size_t gridpoints_axis = grid.getGridPointsPerAxis();
    196   size_t pre_offset[3];
    197   size_t post_offset[3];
    198   size_t length[3];
    199   size_t total[3];
    200   const double round_offset =
    201       (std::numeric_limits<size_t>::round_style == std::round_toward_zero) ?
    202           0.5 : 0.; // need offset to get to round_toward_nearest behavior
    203   for(size_t index=0;index<3;++index) {
    204     const double delta = (double)gridpoints_axis/(grid.end[index] - grid.begin[index]);
    205     // delta is conversion factor from box length to discrete length, i.e. number of points
    206     pre_offset[index] = delta*(grid.begin_window[index] - grid.begin[index])+round_offset;
    207     length[index] = delta*(grid.end_window[index] - grid.begin_window[index])+round_offset;
    208     post_offset[index] = delta*(grid.end[index] - grid.end_window[index])+round_offset;
    209     total[index] = delta*(grid.end[index] - grid.begin[index])+round_offset;
    210     // total is used as safe-guard against loss due to discrete conversion
    211     ASSERT( pre_offset[index]+post_offset[index]+length[index] == total[index],
    212         "InterfaceVMGJob::addWindowOntoGrid() - pre, post, and length don't sum up to total for "
    213         +toString(index)+"th component.");
    214   }
     176  size_t pre_offset[NDIM];
     177  size_t post_offset[NDIM];
     178  size_t length[NDIM];
     179  size_t total[NDIM];
     180  grid.getDiscreteWindowOffsets(pre_offset, post_offset, length, total);
    215181#ifndef NDEBUG
    216182  const size_t calculated_size = length[0]*length[1]*length[2];
     
    218184      "InterfaceVMGJob::addWindowOntoGrid() - not enough sampled values given: "
    219185      +toString(calculated_size)+" != "+toString(grid.sampled_grid.size())+".");
    220 //  ASSERT( calculated_size <=  given_size,
    221 //      "InterfaceVMGJob::addWindowOntoGrid() - not enough sampled values available: "
    222 //      +toString(calculated_size)+" <= "+toString(given_size)+".");
    223 //  const size_t total_size = total[0]*total[1]*total[2];
    224 //  ASSERT( total_size == given_size,
    225 //      "InterfaceVMGJob::addWindowOntoGrid() - total size is not equal to number of present points: "
    226 //      +toString(total_size)+" != "+toString(given_size)+".");
    227 #endif
    228   size_t N[3];
     186#endif
     187  size_t N[NDIM];
    229188  // in open boundary case grid.Local() contains more than just the inner area. The grid
    230189  // is actually twice as large to allow for the FV discretization to work. Hence, we first
     
    238197    // this mimicks VMG::GridIndexTranslations::EndOffset()
    239198    const size_t off = OpenBoundaryConditions ? 1 : 0;
    240     for (size_t i=0;i<3;++i)
     199    for (size_t i=0;i<NDIM;++i)
    241200      pre_offset[i] += ((size_t)size[i] - off) / 4;
    242     for (size_t i=0;i<3;++i)
     201    for (size_t i=0;i<NDIM;++i)
    243202      total[i] = ((size_t)size[i]);
    244     for (size_t i=0;i<3;++i)
     203    for (size_t i=0;i<NDIM;++i)
    245204      post_offset[i] = ((size_t)size[i]) - pre_offset[i] - length[i];
    246205  }
Note: See TracChangeset for help on using the changeset viewer.