File: indexsettest.cc

package info (click to toggle)
dune-common 2.11.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 6,048 kB
  • sloc: cpp: 54,403; python: 4,136; sh: 1,657; makefile: 17
file content (80 lines) | stat: -rw-r--r-- 2,015 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
// -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
// vi: set et ts=4 sw=2 sts=2:
// SPDX-FileCopyrightInfo: Copyright © DUNE Project contributors, see file LICENSE.md in module root
// SPDX-License-Identifier: LicenseRef-GPL-2.0-only-with-DUNE-exception
#include <cstdlib>
#include <iostream>
#include <ostream>

#include <dune/common/parallel/indexset.hh>
#include <dune/common/parallel/localindex.hh>

int testDeleteIndices()
{
  Dune::ParallelIndexSet<int,Dune::LocalIndex,15> indexSet;
  Dune::ParallelIndexSet<int,Dune::LocalIndex,25> indexSet1;

  indexSet.beginResize();
  indexSet1.beginResize();

  for(int i=0; i< 10; i++) {
    indexSet.add(i, Dune::LocalIndex (i));
    indexSet1.add(i, Dune::LocalIndex (i));
  }

  indexSet.endResize();
  indexSet1.endResize();

  typedef Dune::ParallelIndexSet<int,Dune::LocalIndex,15>::iterator
  Iterator;

  Iterator entry = indexSet.begin();
  indexSet.beginResize();

  for(int i=0; i < 5; i++)
    ++entry;

  indexSet.markAsDeleted(entry);

  indexSet.endResize();

  std::cout<<"Unchanged: "<<indexSet1<<std::endl;
  std::cout<<"Deleted:   "<<indexSet<<std::endl;

  Iterator end = indexSet.end();
  int i=0, ret=0;

  for(entry = indexSet.begin(); entry != end; ++entry,++i)
    if(entry->global()==5) {
      std::cerr<<"Entry was not deleted!"<<std::endl;
      ret++;
    }

  if(i>9) {
    std::cerr<<"Number of entries not correct!"<<std::endl;
    ret++;
  }

  Dune::ParallelIndexSet<int,Dune::LocalIndex,25>::iterator iter=indexSet1.begin();

  // Test whether the local indices changed
  for(entry = indexSet.begin(); entry != end; ++entry) {
    while(iter->global() < entry->global())
      iter++;
    if(iter->global() != entry->global()) {
      std::cerr <<" Global indices do not match!"<<std::endl;
      ++ret;
    }
    if(iter->local() != entry->local()) {
      std::cerr <<" Local indices do not match!"<<std::endl;
      ++ret;
    }
  }

  return ret;
}

int main(int, char **)
{
  std::exit(testDeleteIndices());
}