File: itkObjectStoreTest.cxx

package info (click to toggle)
insighttoolkit5 5.4.3-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 704,384 kB
  • sloc: cpp: 783,592; ansic: 628,724; xml: 44,704; fortran: 34,250; python: 22,874; sh: 4,078; pascal: 2,636; lisp: 2,158; makefile: 464; yacc: 328; asm: 205; perl: 203; lex: 146; tcl: 132; javascript: 98; csh: 81
file content (86 lines) | stat: -rw-r--r-- 2,471 bytes parent folder | download
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
81
82
83
84
85
86
/*=========================================================================
 *
 *  Copyright NumFOCUS
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *         https://www.apache.org/licenses/LICENSE-2.0.txt
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 *
 *=========================================================================*/

#include "itkObjectStore.h"
#include <iostream>
#include <set>

struct TestObject
{
  float vector[3];
  int   counter;
};

int
itkObjectStoreTest(int, char *[])
{
  unsigned int                          i, j;
  itk::ObjectStore<TestObject>::Pointer store = itk::ObjectStore<TestObject>::New();

  std::list<TestObject *> borrowed_list;
  store->SetGrowthStrategyToExponential();
  store->Reserve(40000);

  // for increased code coverage
  store->SetLinearGrowthSize(store->GetLinearGrowthSize());
  store->SetGrowthStrategy(store->GetGrowthStrategy());


  for (j = 0; j < 2; ++j)
  {
    std::cout << "_______________________" << std::endl;
    store->Print(std::cout);


    // Borrow some items
    for (i = 0; i < 30000; ++i)
    {
      borrowed_list.push_back(store->Borrow());
    }
    store->Print(std::cout);

    // Force allocation of a more memory
    for (i = 0; i < 1000000; ++i)
    {
      borrowed_list.push_back(store->Borrow());
    }
    store->Print(std::cout);

    // Return all items
    auto sz = static_cast<unsigned int>(borrowed_list.size());
    for (i = 0; i < sz; ++i)
    {
      store->Return(borrowed_list.back());
      borrowed_list.pop_back();
    }
    store->Print(std::cout);

    store->Clear();
    store->Squeeze();
  }

  // Test streaming enumeration for ObjectStoreEnums::GrowthStrategy elements
  const std::set<itk::ObjectStoreEnums::GrowthStrategy> allGrowthStrategy{
    itk::ObjectStoreEnums::GrowthStrategy::LINEAR_GROWTH, itk::ObjectStoreEnums::GrowthStrategy::EXPONENTIAL_GROWTH
  };
  for (const auto & ee : allGrowthStrategy)
  {
    std::cout << "STREAMED ENUM VALUE ObjectStoreEnums::GrowthStrategy: " << ee << std::endl;
  }
  return EXIT_SUCCESS;
}