From 1b6b8183a09039faaa0ca82650917eef2e3a7768 Mon Sep 17 00:00:00 2001 From: Christophe Riccio Date: Sat, 25 Oct 2014 21:57:06 +0200 Subject: [PATCH] Updated test --- test/core/core_func_integer.cpp | 40 ++++++++++++++++++++------------- 1 file changed, 25 insertions(+), 15 deletions(-) diff --git a/test/core/core_func_integer.cpp b/test/core/core_func_integer.cpp index adae41ea..6cbe5f0c 100644 --- a/test/core/core_func_integer.cpp +++ b/test/core/core_func_integer.cpp @@ -530,12 +530,12 @@ namespace bitCount {0x00000001, 1}, {0x00000003, 2}, {0x00000002, 1}, - {0xffffffff, 32}, + {0x7fffffff, 31}, {0x00000000, 0} }; template - int bitCount_if(T v) + inline int bitCount_if(T v) { GLM_STATIC_ASSERT(std::numeric_limits::is_integer, "'bitCount' only accept integer values"); @@ -549,7 +549,7 @@ namespace bitCount } template - int bitCount_vec(T v) + inline int bitCount_vec(T v) { GLM_STATIC_ASSERT(std::numeric_limits::is_integer, "'bitCount' only accept integer values"); @@ -566,46 +566,56 @@ namespace bitCount int Error(0); std::size_t Size = 10000000; + std::vector v; + v.resize(Size); + + std::vector w; + w.resize(Size); + std::clock_t TimestampsA = std::clock(); + // bitCount - TimeIf { - std::vector v; - v.resize(Size); - for(std::size_t i = 0, n = v.size(); i < n; ++i) v[i] = bitCount_if(i); } std::clock_t TimestampsB = std::clock(); + // bitCount - TimeVec { - std::vector v; - v.resize(Size); - for(std::size_t i = 0, n = v.size(); i < n; ++i) v[i] = bitCount_vec(i); } std::clock_t TimestampsC = std::clock(); + // bitCount - TimeDefault { - std::vector v; - v.resize(Size); - for(std::size_t i = 0, n = v.size(); i < n; ++i) v[i] = glm::bitCount(i); } std::clock_t TimestampsD = std::clock(); + // bitCount - TimeVec4 + { + for(std::size_t i = 0, n = v.size(); i < n; ++i) + w[i] = glm::bitCount(glm::ivec4(i)); + } + + std::clock_t TimestampsE = std::clock(); + std::clock_t TimeIf = TimestampsB - TimestampsA; std::clock_t TimeVec = TimestampsC - TimestampsB; std::clock_t TimeDefault = TimestampsD - TimestampsC; + std::clock_t TimeVec4 = TimestampsE - TimestampsD; - printf("TimeIf %d\n", TimeIf); - printf("TimeVec %d\n", TimeVec); - printf("TimeDefault %d\n", TimeDefault); + printf("bitCount - TimeIf %d\n", TimeIf); + printf("bitCount - TimeVec %d\n", TimeVec); + printf("bitCount - TimeDefault %d\n", TimeDefault); + printf("bitCount - TimeVec4 %d\n", TimeVec4); return Error; }