-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathmerge_out_gnu.h
38 lines (33 loc) · 969 Bytes
/
merge_out_gnu.h
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
#pragma once
#define paral_prog_decl\
int perc = 0;\
size_t prog = 0;\
benchmark::timer ms("time");\
_Pragma("omp parallel for")
#define paral_prog_report(arr)\
const int cur_perc = (int)((float)(prog+1)/arr.size()*100);\
if(perc != cur_perc)\
{\
perc = cur_perc;\
_Pragma("omp critical")\
{\
std::cout << "progress: " << perc << "/" << 100 << " ";\
ms.reset();\
}\
}\
_Pragma("omp atomic")\
prog++;
#define paral_crit\
_Pragma("omp critical")
#define lin_prog_decl\
int prog = 0;\
int perc = 0;\
size_t num_voxels = (size_t)rle_info.glo_dim.x*rle_info.glo_dim.y*rle_info.glo_dim.z;\
benchmark::timer ms("time");
#define lin_prog_report\
const int cur_perc = (int)((float)prog++/num_voxels*100);\
if(perc != cur_perc) {\
perc = cur_perc;\
std::cout << "progress: " << perc << "/" << 100 << " ";\
ms.reset();\
}