mirror of https://github.com/CGAL/cgal
make it generic
This commit is contained in:
parent
11a98dbc95
commit
c98ca70df2
|
|
@ -6,47 +6,57 @@
|
||||||
#include <CGAL/Timer.h>
|
#include <CGAL/Timer.h>
|
||||||
#include <boost/container/deque.hpp>
|
#include <boost/container/deque.hpp>
|
||||||
|
|
||||||
#if 1 //
|
const int N = 10000000;
|
||||||
// leaf
|
|
||||||
struct X {
|
struct Leaf {
|
||||||
bool b;
|
bool b;
|
||||||
int i;
|
int i;
|
||||||
double d1;
|
double d1;
|
||||||
};
|
};
|
||||||
#else
|
|
||||||
// internal
|
|
||||||
struct X {
|
struct Internal {
|
||||||
bool b;
|
bool b;
|
||||||
int i;
|
int i;
|
||||||
double d1, d2, d3, d4,d5;
|
double d1, d2, d3, d4,d5;
|
||||||
};
|
};
|
||||||
#endif
|
|
||||||
int main()
|
template <typename Container, typename T>
|
||||||
|
void bench_container()
|
||||||
{
|
{
|
||||||
|
std::cout << typeid(Container).name() << std::endl;
|
||||||
|
|
||||||
CGAL::Memory_sizer ms;
|
CGAL::Memory_sizer ms;
|
||||||
CGAL::Timer t;
|
CGAL::Timer t;
|
||||||
t.start();
|
t.start();
|
||||||
#if 0
|
|
||||||
std::cout <<"blocklist"<< std::endl;
|
T element;
|
||||||
CGAL::Block_list<X, 256> de;
|
Container c;
|
||||||
#elif 0
|
for(int i=0; i <N ; i++){
|
||||||
std::cout <<"boost::container::deque"<< std::endl;
|
c.push_back(element);
|
||||||
boost::container::deque<X> de;
|
|
||||||
#elif 0
|
|
||||||
std::cout <<"std::deque"<< std::endl;
|
|
||||||
std::deque<X> de;
|
|
||||||
#else
|
|
||||||
std::cout <<"vector"<< std::endl;
|
|
||||||
std::vector<X> de;
|
|
||||||
// de.reserve(100000000);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
for(int i=0; i < 10000000; i++){
|
|
||||||
de.push_back(X());
|
|
||||||
}
|
}
|
||||||
t.stop();
|
t.stop();
|
||||||
std::cout << t.time() << "sec"<< std::endl;
|
std::cout << t.time() << "sec"<< std::endl;
|
||||||
std::cout << ms.virtual_size() << " " << ms.resident_size() << std::endl;
|
std::cout << "virtual : " << ms.virtual_size() << std::endl
|
||||||
|
<< "resident: " << ms.resident_size() << std::endl << std::endl;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
void
|
||||||
|
bench()
|
||||||
|
{
|
||||||
|
std::cout << "sizeof(" << typeid(T).name() << ") = " << sizeof(T) <<std::endl;
|
||||||
|
//bench_container<CGAL::Block_list<T, 256>,T>();
|
||||||
|
bench_container<std::deque<T>,T>();
|
||||||
|
bench_container<boost::container::deque<T>,T>();
|
||||||
|
//bench_container<std::vector<T>,T>();
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
bench<double>();
|
||||||
|
bench<Leaf>();
|
||||||
|
bench<Internal>();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue