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 |
---|
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.86 | 1.16 | 1.15 | 1 | 2.35 | 16.5 | 14.56 | 1 | 2 | 2 | 1 | 0 | 12 | 0 | 0 | 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.83 | 1.15 | 1.15 | 1 | 2.63 | 0 | 12.5 | 1.08 | 1.1 | 8 | 1 | 1 | 0 | 11 | 2 | 0 |
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.45 | 1.1 | 1.1 | 1 | 1.15 | 23.03 | 15.38 | 1.5 | 2.41 | 3.75 | 1 | 1.5 | 1 | 0 | 5.5 | 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 | 6.91 | 1.01 | 1.02 | 1 | 3.04 | 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.16 | 0.9 | 0.91 | 1 | 1.43 | 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.92 | 0.87 | 0.87 | 1 | 2.53 | 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.48 | 0.8 | 0.81 | 1 | 1.65 | 23.72 | 15.23 | 1.46 | 2.19 | 3.28 | 1 | 1 | 4 | 1 | 1 | 0 |
886 | omp-cloverleaf - | __intel_avx_rep_memcpy | Single | 4.59 | 0.67 | 0.68 | 1 | 0.00 | 100 | 50 | 1 | 1 | 2 | 1 | 0 | 2 | 0 | 0 | 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.25 | 0.63 | 0.63 | 1 | 2.59 | 16 | 14.5 | 1.08 | 1.27 | 2.44 | 1 | 1 | 5 | 6 | 1 | 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.15 | 0.61 | 0.61 | 1 | 1.98 | 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 | 0.44 | 0.44 | 1 | 1.73 | 20 | 15 | 1 | 1.38 | 6.86 | 1 | 0 | 8 | 2 | 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.93 | 0.43 | 0.43 | 1 | 1.44 | 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.69 | 0.4 | 0.4 | 1 | 1.95 | 6.25 | 13.28 | 1 | 2 | 2 | 1 | 0 | 6 | 0 | 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 | 2.65 | 0.39 | 0.39 | 1 | 1.69 | 75 | 21.88 | 1 | 1 | 1 | 1 | 0 | 3 | 1 | 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.55 | 0.38 | 0.38 | 1 | 2.16 | 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.35 | 0.34 | 0.34 | 1 | 2.32 | 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.28 | 0.34 | 0.33 | 1 | 1.00 | 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.21 | 0.32 | 0.33 | 1 | 2.30 | 45.45 | 18.18 | 1 | 1.42 | 5.89 | 1 | 0 | 2 | 5 | 0 | 0 |
280 | omp-cloverleaf - ideal_gas.cpp:39-45 | ideal_gas(global_variables&, int, bool) | Innermost | 2.18 | 0.32 | 0.32 | 1 | 2.00 | 100 | 50 | 1 | 1 | 1 | 1 | 0 | 4 | 0 | 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.11 | 0.31 | 0.31 | 1 | 1.32 | 0 | 12.5 | 1.04 | 1.2 | 8 | 1 | 0 | 5 | 1 | 0 | 0 |
285 | omp-cloverleaf - ideal_gas.cpp:39-45 | ideal_gas(global_variables&, int, bool) | Innermost | 1.94 | 0.28 | 0.28 | 1 | 2.00 | 100 | 50 | 1 | 1 | 1 | 1 | 0 | 4 | 0 | 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.87 | 0.28 | 0.28 | 1 | 0.57 | 87.5 | 45.31 | 1 | 1.25 | 2.5 | 1 | 0 | 3 | 1 | 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.63 | 0.24 | 0.24 | 1 | 0.71 | 0 | 12.5 | 1 | 1 | 8 | 1 | 0 | 5 | 0 | 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.19 | 0.17 | 0.17 | 1 | 1.35 | 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.16 | 0.17 | 0.17 | 1 | 1.35 | 1.96 | 12.01 | 6.13 | 1.93 | 12.2 | 1 | NA | NA | NA | NA | NA |
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.12 | 0.16 | 0.17 | 1 | 1.41 | 0 | 12.5 | 1.06 | 1.21 | 8 | 1 | 0 | 3 | 3 | 0 | 0 |
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 | 1.02 | 0.15 | 0.15 | 1 | 1.73 | 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.95 | 0.14 | 0.14 | 1 | 0.50 | 0 | 12.5 | 1 | 1.06 | 8 | 1 | 0 | 4 | 1 | 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 | 0.92 | 0.14 | 0.14 | 1 | 2.64 | 0 | 12.5 | 1 | 1.19 | 8 | 1 | 0 | 1 | 2 | 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.65 | 0.09 | 0.1 | 1 | 0.40 | 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.34 | 0.05 | 0.05 | 1 | 0.00 | 0 | 6.25 | 1 | 1 | 16 | 1 | 0 | 11 | 0 | 0 | 0 |
222 | omp-cloverleaf - build_field.cpp:120-128 | build_field(global_variables&) | Innermost | 0.1 | 0.01 | 0.02 | 1 | 0.00 | 0 | 6.25 | 1 | 1 | 16 | 1 | 0 | 8 | 0 | 0 | 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.07 | 0.01 | 0.01 | 1 | 0.00 | 0 | 9.9 | 2.03 | 1.71 | 23.7 | 1 | 1 | 0 | 0 | 5 | 0 |
510 | omp-cloverleaf - update_halo.cpp:162-163 | 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 |
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.07 | 0.01 | 0.01 | 1 | 2.00 | 0 | 12.23 | 1.62 | 1.64 | 7.08 | 1 | 1 | 0 | 0.5 | 3 | 0 |
405 | omp-cloverleaf - update_halo.cpp:539-540 | 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.2 | 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 |
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 |
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 |
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.03 | 0 | 0.01 | 1 | 0.00 | 0 | 12.5 | 1.25 | 1 | 8 | 0 | 0 | 2 | 0 | 0 | 0 |
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.03 | 0 | 0.01 | 1 | 0.00 | 0 | 12.5 | 1 | 1 | 8 | 0 | 0 | 2 | 0 | 0 | 0 |
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 |
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 |
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 |
438 | omp-cloverleaf - update_halo.cpp:420-421 | 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 |
429 | omp-cloverleaf - update_halo.cpp:453-454 | 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 |
525 | omp-cloverleaf - update_halo.cpp:109-110 | 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 |
426 | omp-cloverleaf - update_halo.cpp:463-464 | 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 | 1 | 8 | 0 | 0 | 2 | 0 | 0 | 0 |
522 | omp-cloverleaf - update_halo.cpp:119-120 | 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 | 1 | 8 | 0 | 0 | 2 | 0 | 0 | 0 |
393 | omp-cloverleaf - update_halo.cpp:582-583 | 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.2 | 1 | 8 | 0 | 0 | 2 | 0 | 0 | 0 |
387 | omp-cloverleaf - update_halo.cpp:605-606 | 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 |