Leapfrog uses more frequent GC
[junction.git] / test / junction_driver.cpp
index 62b9d6253a3afb81dc5c094d767ab43ebf8acafb..1609297b6bc54dd3ce864577308a9099c08e05a6 100644 (file)
@@ -13,6 +13,7 @@ const unsigned s_nInsertPercentage = 10;
 const char* kTestName = "InsDelFind";
 // Run GC after "kGCFrequency" operations.
 const size_t kGCFrequency = 3000;
 const char* kTestName = "InsDelFind";
 // Run GC after "kGCFrequency" operations.
 const size_t kGCFrequency = 3000;
+const size_t kLeapfrogGCFrequency = 1500;
 
 const size_t kCrudeMapSize = 10000;
 const size_t kCrudePassCount = 40000;
 
 const size_t kCrudeMapSize = 10000;
 const size_t kCrudePassCount = 40000;
@@ -38,7 +39,8 @@ typedef junction::ConcurrentMap_Leapfrog<size_t, size_t> LeapfrogMap;
 typedef junction::ConcurrentMap_Crude<size_t, size_t> CrudeMap;
 
 template <typename Map>
 typedef junction::ConcurrentMap_Crude<size_t, size_t> CrudeMap;
 
 template <typename Map>
-void run_crude_map(size_t map_size, size_t pass_count, const char* bench_name) {
+void run_crude_map(size_t map_size, size_t pass_count, const char* bench_name,
+    size_t gc_frequency) {
     std::cout << "[ RUN      ] " << kTestName << "." << bench_name << "\n";
     auto start_time = std::chrono::system_clock::now();
 
     std::cout << "[ RUN      ] " << kTestName << "." << bench_name << "\n";
     auto start_time = std::chrono::system_clock::now();
 
@@ -73,7 +75,7 @@ void run_crude_map(size_t map_size, size_t pass_count, const char* bench_name) {
 //                    std::cout << "Erased" << i << "\n";
                 }
             }
 //                    std::cout << "Erased" << i << "\n";
                 }
             }
-            if (++nOperations > kGCFrequency) {
+            if (++nOperations > gc_frequency) {
               junction::DefaultQSBR.update(qsbrContext);
               nOperations = 0;
             }
               junction::DefaultQSBR.update(qsbrContext);
               nOperations = 0;
             }
@@ -97,7 +99,8 @@ void run_crude_map(size_t map_size, size_t pass_count, const char* bench_name) {
 }
 
 template <typename Map>
 }
 
 template <typename Map>
-void run_test(size_t map_size, size_t pass_count, const char* bench_name) {
+void run_test(size_t map_size, size_t pass_count, const char* bench_name,
+    size_t gc_frequency) {
     std::cout << "[ RUN      ] " << kTestName << "." << bench_name << "\n";
     auto start_time = std::chrono::system_clock::now();
 
     std::cout << "[ RUN      ] " << kTestName << "." << bench_name << "\n";
     auto start_time = std::chrono::system_clock::now();
 
@@ -135,7 +138,7 @@ void run_test(size_t map_size, size_t pass_count, const char* bench_name) {
 //                    std::cout << "Erased" << i << "\n";
                 }
             }
 //                    std::cout << "Erased" << i << "\n";
                 }
             }
-            if (++nOperations > kGCFrequency) {
+            if (++nOperations > gc_frequency) {
                 junction::DefaultQSBR.update(qsbrContext);
                 nOperations = 0;
             }
                 junction::DefaultQSBR.update(qsbrContext);
                 nOperations = 0;
             }
@@ -158,9 +161,13 @@ void run_test(size_t map_size, size_t pass_count, const char* bench_name) {
 }
 
 int main() {
 }
 
 int main() {
-    run_test<LinearMap>(kLinearMapSize, kLinearPassCount, kLinearBenchmarkName);
-    run_test<LeapfrogMap>(kLeapfrogMapSize, kLeapfrogPassCount, kLeapfrogBenchmarkName);
-    run_test<GrampaMap>(kGrampaMapSize, kGrampaPassCount, kGrampaBenchmarkName);
-    run_crude_map<CrudeMap>(kCrudeMapSize, kCrudePassCount, kCrudeBenchmarkName);
+    run_test<LeapfrogMap>(kLeapfrogMapSize, kLeapfrogPassCount,
+        kLeapfrogBenchmarkName, kLeapfrogGCFrequency );
+    run_test<LinearMap>(kLinearMapSize, kLinearPassCount, kLinearBenchmarkName,
+        kGCFrequency);
+    run_test<GrampaMap>(kGrampaMapSize, kGrampaPassCount, kGrampaBenchmarkName,
+        kGCFrequency);
+    run_crude_map<CrudeMap>(kCrudeMapSize, kCrudePassCount, kCrudeBenchmarkName,
+        kGCFrequency);
     return 0;
 }
     return 0;
 }