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
|
#include "benchmark_helpers.hpp"
#include "cache_aligned_array.hpp"
#include "../simd_math.hpp"
#include <cmath>
using namespace nova;
using namespace std;
aligned_array<float, 64> out, in;
void __noinline__ bench_1_simd(unsigned int n)
{
tan_vec_simd(out.begin(), in.begin(), n);
}
void __noinline__ bench_1(unsigned int n)
{
for (int i = 0; i != n; ++i)
out[i] = tan(in[i]);
}
int main(void)
{
out.assign(0.f);
const unsigned int iterations = 5000000;
in.assign(0.2f);
cout << "tan(0.2):" << endl;
run_bench(boost::bind(bench_1, 64), iterations);
run_bench(boost::bind(bench_1_simd, 64), iterations);
}
|