source: trunk/source/global/management/test/AllocVectorTest.cc @ 1315

Last change on this file since 1315 was 1315, checked in by garnier, 14 years ago

update geant4-09-04-beta-cand-01 interfaces-V09-03-09 vis-V09-03-08

File size: 3.5 KB
Line 
1//
2// ********************************************************************
3// * License and Disclaimer                                           *
4// *                                                                  *
5// * The  Geant4 software  is  copyright of the Copyright Holders  of *
6// * the Geant4 Collaboration.  It is provided  under  the terms  and *
7// * conditions of the Geant4 Software License,  included in the file *
8// * LICENSE and available at  http://cern.ch/geant4/license .  These *
9// * include a list of copyright holders.                             *
10// *                                                                  *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work  make  any representation or  warranty, express or implied, *
14// * regarding  this  software system or assume any liability for its *
15// * use.  Please see the license in the file  LICENSE  and URL above *
16// * for the full disclaimer and the limitation of liability.         *
17// *                                                                  *
18// * This  code  implementation is the result of  the  scientific and *
19// * technical work of the GEANT4 collaboration.                      *
20// * By using,  copying,  modifying or  distributing the software (or *
21// * any work based  on the software)  you  agree  to acknowledge its *
22// * use  in  resulting  scientific  publications,  and indicate your *
23// * acceptance of all terms of the Geant4 Software license.          *
24// ********************************************************************
25//
26//
27// $Id: AllocVectorTest.cc,v 1.2 2006/06/29 19:04:45 gunter Exp $
28// GEANT4 tag $Name: geant4-09-04-beta-cand-01 $
29//
30//
31// ----------------------------------------------------------------------
32#include "G4Timer.hh"
33#include "G4Allocator.hh"
34#include "globals.hh"
35#include "G4ios.hh"
36#include <vector>
37
38int main()
39{
40  G4Timer timer;
41  G4double d = 1.;
42  const size_t maxiter = 10000000;
43  const size_t modulo  = 2000000;
44
45  G4cout << "+++++  G4Allocator test ..........." << G4endl;
46  timer.Start();
47
48  std::vector< double, G4Allocator<double> > tvec1;
49  std::vector< double, G4Allocator<double> > tvec2(maxiter);
50  for (size_t i=0; i<maxiter; i++)
51  {
52    tvec1.push_back(d);
53    tvec2.push_back(d);
54    if (i%modulo == 0)
55    {
56      G4cout << "Dynamic vector - size: " << tvec1.size() << G4endl
57             << "      ...and capacity: " << tvec1.capacity() << G4endl;
58      G4cout << "Fixed vector   - size: " << tvec2.size() << G4endl
59             << "      ...and capacity: " << tvec2.capacity() << G4endl;
60    }
61  }
62
63  timer.Stop(); 
64
65  G4cout << "System time: " << timer.GetSystemElapsed() << G4endl
66         << "User time  : " << timer.GetUserElapsed() << G4endl;
67
68  G4cout << "+++++  std::allocator test ..........." << G4endl;
69  timer.Start();
70
71  std::vector< double > tvec3;
72  std::vector< double > tvec4(maxiter);
73  for (size_t j=0; j<maxiter; j++)
74  {
75    tvec3.push_back(d);
76    tvec4.push_back(d);
77    if (j%modulo == 0)
78    {
79      G4cout << "Dynamic vector - size: " << tvec3.size() << G4endl
80             << "      ...and capacity: " << tvec3.capacity() << G4endl;
81      G4cout << "Fixed vector   - size: " << tvec4.size() << G4endl
82             << "      ...and capacity: " << tvec4.capacity() << G4endl;
83    }
84  }
85
86  timer.Stop(); 
87
88  G4cout << "System time: " << timer.GetSystemElapsed() << G4endl
89         << "User time  : " << timer.GetUserElapsed() << G4endl;
90
91  return 0;
92}
Note: See TracBrowser for help on using the repository browser.