forked from IntelPython/BlackScholes_bench
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.c
84 lines (71 loc) · 2.51 KB
/
main.c
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/*
* Copyright (C) 2014-2015, 2018 Intel Corporation
*
* SPDX-License-Identifier: MIT
*/
#include <stdio.h>
#include <time.h>
#include "euro_opt.h"
#include "rdtsc.h"
#define STEPS 18
int main(int argc, char * argv[])
{
int nopt = 1 * 1024;
int steps = STEPS;
tfloat *s0, *x, *t, *vcall_mkl, *vput_mkl, *vcall_compiler, *vput_compiler;
clock_t t1 = 0, t2 = 0;
/* Read nopt number of options parameter from command line */
if (argc < 2)
{
printf("Usage: expect nopt input integer parameter, defaulting to %d\n", nopt);
}
else
{
sscanf(argv[1], "%d", &nopt);
/* Read steps number of options parameter from command line */
if (argc > 2)
{
sscanf(argv[2], "%d", &steps);
}
}
int i, j;
for(i = 0; i < steps; i++) {
/* Allocate arrays, generate input data */
InitData( nopt, &s0, &x, &t, &vcall_compiler, &vput_compiler, &vcall_mkl, &vput_mkl );
/* Warm up cycle */
for(j = 0; j < 10; j++) {
#ifdef BLACK_SCHOLES_MKL
BlackScholesFormula_MKL( nopt, RISK_FREE, VOLATILITY, s0, x, t, vcall_mkl, vput_mkl );
#else
BlackScholesFormula_Compiler( nopt, RISK_FREE, VOLATILITY, s0, x, t, vcall_compiler, vput_compiler );
#endif
}
#ifdef BLACK_SCHOLES_MKL
/* Compute call and put prices using MKL VML functions */
printf("ERF: Native-C-VML: Size: %d MOPS: ", nopt);
#else
/* Compute call and put prices using compiler math libraries */
printf("ERF: Native-C-SVML: Size: %d MOPS: ", nopt);
#endif
t1 = timer_rdtsc();
for(j = 0; j < 100; j++) {
#ifdef BLACK_SCHOLES_MKL
BlackScholesFormula_MKL( nopt, RISK_FREE, VOLATILITY, s0, x, t, vcall_mkl, vput_mkl );
#else
BlackScholesFormula_Compiler( nopt, RISK_FREE, VOLATILITY, s0, x, t, vcall_compiler, vput_compiler );
#endif
}
t2 = timer_rdtsc();
printf("%.6lf\n", (2.0 * nopt * 100 / 1e6)/((double) (t2 - t1) / getHz()));
fflush(stdout);
/* Deallocate arrays */
FreeData( s0, x, t, vcall_compiler, vput_compiler, vcall_mkl, vput_mkl );
nopt = nopt * 2;
}
/* Display a few computed values */
// printf("call_compiler[0/%d]= %g\n", nopt, (double)(vcall_compiler[10]) );
// printf("put_compiler[0/%d]= %g\n", nopt, (double)(vput_compiler[10]) );
// printf("call_mkl[0/%d]= %g\n", nopt, (double)(vcall_mkl[10]) );
// printf("put_mkl[0/%d]= %g\n", nopt, (double)(vput_mkl[10]) );
return 0;
}