Loop id | Source Location | Source Function | Level | Coverage run_0 (%) | Max Time Over Threads run_0 (s) | Time w.r.t. Wall Time run_0 (s) | Nb Threads run_0 | GFLOPS run_0 | Vectorization Ratio (%) | Vector Length Use (%) | Speedup If No Scalar Integer | Speedup If FP Vectorized | Speedup If Fully Vectorized | Speedup If Perfect Load Balancing run_0 | Stride 0 | Stride 1 | Stride n | Stride Unknown | Stride Indirect |
---|
176 | omp-cloverleaf - advec_mom.cpp:182-211 [...] | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 7.88 | 1.15 | 1.15 | 1 | 1.10 | 23.03 | 15.38 | 1.5 | 2.41 | 3.75 | 1 | 1.5 | 1 | 0 | 5.5 | 0 |
148 | omp-cloverleaf - accelerate.cpp:42-53 | accelerate_kernel(int, int, int, int, double, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<doubl... | Innermost | 7.74 | 1.13 | 1.13 | 1 | 2.68 | 0 | 12.5 | 1.08 | 1.1 | 8 | 1 | 1 | 0 | 11 | 2 | 0 |
235 | omp-cloverleaf - calc_dt.cpp:51-75 | calc_dt_kernel(int, int, int, int, double, double, double, double, double, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer1D<double>&, clover::Buffer1D<double>&, clover::Buffer1D<double>&am... | Innermost | 7.67 | 1.12 | 1.12 | 1 | 2.41 | 16.5 | 14.56 | 1 | 2 | 2 | 1 | 0 | 12 | 0 | 0 | 0 |
877 | omp-cloverleaf - viscosity.cpp:38-64 | viscosity_kernel(int, int, int, int, clover::Buffer1D<double>&, clover::Buffer1D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 7.16 | 1.05 | 1.05 | 1 | 2.95 | 29.23 | 16.15 | 1 | 1.68 | 1.68 | 1 | 3 | 3.33 | 6 | 0 | 0 |
154 | omp-cloverleaf - advec_cell.cpp:159-202 [...] | advec_cell_kernel(int, int, int, int, int, int, clover::Buffer1D<double>&, clover::Buffer1D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<dou... | Innermost | 6.37 | 0.93 | 0.93 | 1 | 1.40 | 14.52 | 14.16 | 1.59 | 3.21 | 4.53 | 1 | 1 | 0 | 0 | 9.5 | 1 |
336 | omp-cloverleaf - PdV.cpp:71-83 | PdV_kernel(bool, int, int, int, int, double, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double... | Innermost | 5.93 | 0.86 | 0.87 | 1 | 2.54 | 43.33 | 17.92 | 1.16 | 1.4 | 3.13 | 1 | 1 | 2 | 9 | 1 | 0 |
187 | omp-cloverleaf - advec_mom.cpp:110-139 [...] | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 5.24 | 0.77 | 0.77 | 1 | 1.74 | 23.72 | 15.23 | 1.46 | 2.19 | 3.28 | 1 | 1 | 4 | 1 | 1 | 0 |
338 | omp-cloverleaf - PdV.cpp:50-63 [...] | PdV_kernel(bool, int, int, int, int, double, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double... | Innermost | 4.62 | 0.68 | 0.67 | 1 | 2.43 | 16 | 14.5 | 1.08 | 1.27 | 2.44 | 1 | 1 | 5 | 6 | 1 | 0 |
886 | omp-cloverleaf - | __intel_avx_rep_memcpy | Single | 4.49 | 0.66 | 0.66 | 1 | 0.00 | 100 | 50 | 1 | 1 | 2 | 1 | 0 | 2 | 0 | 0 | 0 |
165 | omp-cloverleaf - advec_cell.cpp:67-110 [...] | advec_cell_kernel(int, int, int, int, int, int, clover::Buffer1D<double>&, clover::Buffer1D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<dou... | Innermost | 4.45 | 0.65 | 0.65 | 1 | 1.86 | 17.24 | 14.55 | 1.39 | 2.95 | 4.04 | 1 | NA | NA | NA | NA | NA |
248 | omp-cloverleaf - flux_calc.cpp:38-40 [...] | flux_calc_kernel(int, int, int, int, double, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double... | Innermost | 3.12 | 0.45 | 0.45 | 1 | 1.69 | 20 | 15 | 1 | 1.38 | 6.86 | 1 | 0 | 8 | 2 | 0 | 0 |
185 | omp-cloverleaf - advec_mom.cpp:148-149 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 3.05 | 0.44 | 0.44 | 1 | 1.50 | 75 | 21.88 | 1 | 1 | 1 | 1 | 0 | 3 | 1 | 0 | 0 |
174 | omp-cloverleaf - advec_mom.cpp:220-221 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 2.84 | 0.41 | 0.41 | 1 | 1.51 | 0 | 12.5 | 1 | 1.6 | 2 | 1 | 0 | 5 | 0 | 0 | 0 |
162 | omp-cloverleaf - advec_cell.cpp:119-125 | advec_cell_kernel(int, int, int, int, int, int, clover::Buffer1D<double>&, clover::Buffer1D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<dou... | Innermost | 2.6 | 0.38 | 0.38 | 1 | 2.03 | 6.25 | 13.28 | 1 | 2 | 2 | 1 | 0 | 6 | 0 | 0 | 0 |
151 | omp-cloverleaf - advec_cell.cpp:210-216 | advec_cell_kernel(int, int, int, int, int, int, clover::Buffer1D<double>&, clover::Buffer1D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<dou... | Innermost | 2.4 | 0.35 | 0.35 | 1 | 2.34 | 0 | 12.5 | 1 | 1.78 | 2 | 1 | 0 | 9 | 0 | 0 | 0 |
177 | omp-cloverleaf - advec_mom.cpp:169-172 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 2.23 | 0.32 | 0.32 | 1 | 2.47 | 45.45 | 18.18 | 1 | 1.42 | 5.89 | 1 | 0 | 4 | 4 | 0 | 0 |
204 | omp-cloverleaf - advec_mom.cpp:46-48 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 2.12 | 0.31 | 0.31 | 1 | 1.06 | 0 | 12.5 | 1.04 | 1.2 | 8 | 1 | 0 | 5 | 1 | 0 | 0 |
202 | omp-cloverleaf - advec_mom.cpp:55-57 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 2.06 | 0.3 | 0.3 | 1 | 1.37 | 0 | 12.5 | 1.04 | 1.2 | 8 | 1 | 0 | 5 | 1 | 0 | 0 |
188 | omp-cloverleaf - advec_mom.cpp:97-100 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 2.06 | 0.3 | 0.3 | 1 | 2.53 | 45.45 | 18.18 | 1 | 1.42 | 5.89 | 1 | 0 | 2 | 5 | 0 | 0 |
197 | omp-cloverleaf - advec_mom.cpp:73-75 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 1.88 | 0.27 | 0.27 | 1 | 0.59 | 87.5 | 45.31 | 1 | 1.25 | 2.5 | 1 | 0 | 3 | 1 | 0 | 0 |
280 | omp-cloverleaf - ideal_gas.cpp:39-45 | ideal_gas(global_variables&, int, bool) | Innermost | 1.82 | 0.26 | 0.26 | 1 | 2.46 | 100 | 50 | 1 | 1 | 1 | 1 | 0 | 4 | 0 | 0 | 0 |
285 | omp-cloverleaf - ideal_gas.cpp:39-45 | ideal_gas(global_variables&, int, bool) | Innermost | 1.75 | 0.25 | 0.26 | 1 | 2.15 | 100 | 50 | 1 | 1 | 1 | 1 | 0 | 4 | 0 | 0 | 0 |
200 | omp-cloverleaf - advec_mom.cpp:64-66 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 1.37 | 0.2 | 0.2 | 1 | 0.85 | 0 | 12.5 | 1 | 1 | 8 | 1 | 0 | 5 | 0 | 0 | 0 |
192 | omp-cloverleaf - advec_mom.cpp:86-88 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 1.2 | 0.17 | 0.17 | 1 | 2.18 | 0 | 12.5 | 1 | 1.19 | 8 | 1 | 0 | 1 | 2 | 0 | 0 |
158 | omp-cloverleaf - advec_cell.cpp:138-140 | advec_cell_kernel(int, int, int, int, int, int, clover::Buffer1D<double>&, clover::Buffer1D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<dou... | Innermost | 1.1 | 0.16 | 0.16 | 1 | 1.50 | 0 | 12.5 | 1.06 | 1.21 | 8 | 1 | 0 | 3 | 3 | 0 | 0 |
171 | omp-cloverleaf - advec_cell.cpp:46-48 | advec_cell_kernel(int, int, int, int, int, int, clover::Buffer1D<double>&, clover::Buffer1D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<dou... | Innermost | 1.06 | 0.16 | 0.16 | 1 | 1.38 | 0 | 12.5 | 1.06 | 1.21 | 8 | 1 | 0 | 5 | 1 | 0 | 0 |
245 | omp-cloverleaf - field_summary.cpp:49-91 [...] | field_summary(global_variables&, parallel_&) | Outermost | 1.03 | 0.15 | 0.15 | 1 | 1.67 | 1.96 | 12.01 | 6.13 | 1.93 | 12.2 | 1 | NA | NA | NA | NA | NA |
181 | omp-cloverleaf - advec_mom.cpp:158-160 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Innermost | 0.89 | 0.13 | 0.13 | 1 | 2.00 | 0 | 12.5 | 1.03 | 1.19 | 8 | 1 | 0 | 1 | 2 | 0 | 0 |
157 | omp-cloverleaf - advec_cell.cpp:148-150 | advec_cell_kernel(int, int, int, int, int, int, clover::Buffer1D<double>&, clover::Buffer1D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<dou... | Innermost | 0.86 | 0.12 | 0.12 | 1 | 0.58 | 0 | 12.5 | 1 | 1.06 | 8 | 1 | 0 | 4 | 1 | 0 | 0 |
170 | omp-cloverleaf - advec_cell.cpp:56-58 | advec_cell_kernel(int, int, int, int, int, int, clover::Buffer1D<double>&, clover::Buffer1D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<dou... | Innermost | 0.72 | 0.1 | 0.11 | 1 | 0.36 | 87.5 | 45.31 | 1 | 1.25 | 2.5 | 1 | 0 | 3 | 1 | 0 | 0 |
232 | omp-cloverleaf - build_field.cpp:102-113 | build_field(global_variables&) | Innermost | 0.31 | 0.04 | 0.04 | 1 | 0.00 | 0 | 6.25 | 1 | 1 | 16 | 1 | 0 | 11 | 0 | 0 | 0 |
363 | omp-cloverleaf - revert.cpp:35-48 [...] | revert(global_variables&) | InBetween | 0.07 | 0.01 | 0.01 | 1 | 0.00 | 0 | 12.23 | 1 | 1 | 14.19 | 1 | NA | NA | NA | NA | NA |
498 | omp-cloverleaf - update_halo.cpp:205-206 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Innermost | 0.07 | 0.01 | 0.01 | 1 | 0.00 | 0 | 12.5 | 1 | 1 | 8 | 1 | 0 | 2 | 0 | 0 | 0 |
222 | omp-cloverleaf - build_field.cpp:120-128 | build_field(global_variables&) | Innermost | 0.07 | 0.01 | 0.01 | 1 | 0.00 | 0 | 6.25 | 1 | 1 | 16 | 1 | 0 | 8 | 0 | 0 | 0 |
414 | omp-cloverleaf - update_halo.cpp:506-507 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Innermost | 0.07 | 0.01 | 0.01 | 1 | 0.00 | 0 | 12.5 | 1 | 1 | 8 | 1 | 0 | 2 | 0 | 0 | 0 |
417 | omp-cloverleaf - update_halo.cpp:496-497 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Innermost | 0.07 | 0.01 | 0.01 | 1 | 0.00 | 0 | 12.5 | 1.25 | 1 | 8 | 1 | 0 | 2 | 0 | 0 | 0 |
435 | omp-cloverleaf - update_halo.cpp:433-434 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Innermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 66.67 | 16.67 | 1.5 | 1 | 8 | 0 | 0 | 0 | 0 | 2 | 0 |
528 | omp-cloverleaf - update_halo.cpp:99-100 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Innermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 10.94 | 1.13 | 1 | 13.33 | 0 | 0 | 0 | 0 | 2 | 0 |
369 | omp-cloverleaf - update_halo.cpp:668-669 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Innermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 12.5 | 1.25 | 1 | 8 | 0 | 0 | 2 | 0 | 0 | 0 |
887 | omp-cloverleaf - | __intel_avx_rep_memset | Single | 0.03 | 0 | 0.01 | 1 | 0.00 | 100 | 50 | 1 | 1 | 2 | 0 | 0 | 1 | 0 | 0 | 0 |
262 | omp-cloverleaf - generate_chunk.cpp:46-98 [...] | generate_chunk(int, global_variables&) | InBetween | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 12.36 | 3.26 | 1 | 11.48 | 0 | NA | NA | NA | NA | NA |
518 | omp-cloverleaf - update_halo.cpp:131-133 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Outermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 11.46 | 1 | 1 | 13 | 0 | NA | NA | NA | NA | NA |
392 | omp-cloverleaf - update_halo.cpp:581-583 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Outermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 9.9 | 1 | 1 | 13.54 | 0 | NA | NA | NA | NA | NA |
269 | omp-cloverleaf - generate_chunk.cpp:76-80 | generate_chunk(int, global_variables&) | Innermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 100 | 50 | 1 | 1 | 2 | 0 | 0 | 4 | 0 | 0 | 0 |
402 | omp-cloverleaf - update_halo.cpp:549-550 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Innermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 66.67 | 16.67 | 1.13 | 1 | 8 | 0 | 0 | 2 | 0 | 0 | 0 |
184 | omp-cloverleaf - advec_mom.cpp:147-149 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Outermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 12.5 | 2.13 | 1.97 | 6.78 | 0 | 1 | 0 | 0.5 | 3.25 | 0 |
203 | omp-cloverleaf - advec_mom.cpp:45-48 [...] | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Outermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 9.9 | 2.03 | 1.71 | 23.7 | 0 | 1 | 0 | 0 | 5 | 0 |
513 | omp-cloverleaf - update_halo.cpp:152-153 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Innermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 12.5 | 1.25 | 1 | 8 | 0 | 0 | 2 | 0 | 0 | 0 |
155 | omp-cloverleaf - advec_cell.cpp:37-150 [...] | advec_cell_kernel(int, int, int, int, int, int, clover::Buffer1D<double>&, clover::Buffer1D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<dou... | Outermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 11.81 | 1 | 1 | 10.25 | 0 | 1 | 1.5 | 2 | 1.5 | 0 |
497 | omp-cloverleaf - update_halo.cpp:204-206 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Outermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 10.86 | 1 | 1 | 10.67 | 0 | NA | NA | NA | NA | NA |
504 | omp-cloverleaf - update_halo.cpp:185-186 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Innermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 10.94 | 1.13 | 1 | 13.33 | 0 | 0 | 0 | 0 | 2 | 0 |
173 | omp-cloverleaf - advec_mom.cpp:219-221 | advec_mom_kernel(int, int, int, int, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&, clover::Buffer2D<double>&... | Outermost | 0.03 | 0 | 0.01 | 1 | 2.00 | 0 | 12.23 | 1.62 | 1.64 | 7.08 | 0 | 1 | 0 | 0.5 | 3 | 0 |
455 | omp-cloverleaf - update_halo.cpp:356-358 | update_halo_kernel(int, int, int, int, std::array<int, 4ul> const&, std::array<int, 4ul> const&, field_type&, int const*, int) | Outermost | 0.03 | 0 | 0.01 | 1 | 0.00 | 0 | 10.42 | 1 | 1 | 13.26 | 0 | NA | NA | NA | NA | NA |