options

Stylizer

gcc_o3_ov1_o52/icx_o3_ov1_o52/

[ 3.00 / 3 ] Architecture specific option -march=skylake-avx512 is used

[ 3.00 / 3 ] Architecture specific option -march=native is used

[ 2.40 / 3 ] Most of time spent in analyzed modules comes from functions without compilation information

Functions without compilation information (typically not compiled with -g) cumulate 0.01% of the time spent in analyzed modules. Check that -g is present. Remark: if -g is indeed used, this can also be due to some compiler built-in functions (typically math) or statically linked libraries. This warning can be ignored in that case.

[ 2.40 / 3 ] Most of time spent in analyzed modules comes from functions without compilation information

Functions without compilation information (typically not compiled with -g) cumulate 0.01% of the time spent in analyzed modules. Check that -g is present. Remark: if -g is indeed used, this can also be due to some compiler built-in functions (typically math) or statically linked libraries. This warning can be ignored in that case.

[ 2 / 2 ] Application is correctly profiled ("Others" category represents 0.17 % of the execution time)

To have a representative profiling, it is advised that the category "Others" represents less than 20% of the execution time in order to analyze as much as possible of the user code

[ 2 / 2 ] Application is correctly profiled ("Others" category represents 0.15 % of the execution time)

To have a representative profiling, it is advised that the category "Others" represents less than 20% of the execution time in order to analyze as much as possible of the user code

[ 3 / 3 ] Optimization level option is correctly used

[ 3 / 3 ] Optimization level option is correctly used

[ 4 / 4 ] Application profile is long enough (36.66 s)

To have good quality measurements, it is advised that the application profiling time is greater than 10 seconds.

[ 4 / 4 ] Application profile is long enough (41.69 s)

To have good quality measurements, it is advised that the application profiling time is greater than 10 seconds.

Strategizer

gcc_o3_ov1_o52/icx_o3_ov1_o52/

[ 4 / 4 ] Loop profile is not flat

At least one loop coverage is greater than 4% (81.31%), representing an hotspot for the application

[ 4 / 4 ] Loop profile is not flat

At least one loop coverage is greater than 4% (50.97%), representing an hotspot for the application

[ 2 / 2 ] Less than 10% (0.00%) is spend in BLAS2 operations

BLAS2 calls usually could make a poor cache usage and could benefit from inlining.

[ 2 / 2 ] Less than 10% (0.00%) is spend in BLAS2 operations

BLAS2 calls usually could make a poor cache usage and could benefit from inlining.

[ 4 / 4 ] Enough time of the experiment time spent in analyzed innermost loops (81.32%)

If the time spent in analyzed innermost loops is less than 15%, standard innermost loop optimizations such as vectorisation will have a limited impact on application performances.

[ 4 / 4 ] Enough time of the experiment time spent in analyzed innermost loops (67.26%)

If the time spent in analyzed innermost loops is less than 15%, standard innermost loop optimizations such as vectorisation will have a limited impact on application performances.

[ 3 / 3 ] Less than 10% (0.00%) is spend in BLAS1 operations

It could be more efficient to inline by hand BLAS1 operations

[ 3 / 3 ] Less than 10% (0.00%) is spend in BLAS1 operations

It could be more efficient to inline by hand BLAS1 operations

[ 2 / 2 ] Less than 10% (0.00%) is spend in Libm/SVML (special functions)

[ 2 / 2 ] Less than 10% (0.00%) is spend in Libm/SVML (special functions)

[ 4 / 4 ] Enough time of the experiment time spent in analyzed loops (84.96%)

If the time spent in analyzed loops is less than 30%, standard loop optimizations will have a limited impact on application performances.

[ 4 / 4 ] Enough time of the experiment time spent in analyzed loops (85.95%)

If the time spent in analyzed loops is less than 30%, standard loop optimizations will have a limited impact on application performances.

[ 3 / 3 ] Cumulative Outermost/In between loops coverage (3.64%) lower than cumulative innermost loop coverage (81.32%)

Having cumulative Outermost/In between loops coverage greater than cumulative innermost loop coverage will make loop optimization more complex

[ 3 / 3 ] Cumulative Outermost/In between loops coverage (18.68%) lower than cumulative innermost loop coverage (67.26%)

Having cumulative Outermost/In between loops coverage greater than cumulative innermost loop coverage will make loop optimization more complex

Optimizer

Analysisr_1r_2
Loop Computation IssuesLess than 10% of the FP ADD/SUB/MUL arithmetic operations are performed using FMA01
Presence of a large number of scalar integer instructions22
Low iteration count01
Control Flow IssuesPresence of calls11
Presence of 2 to 4 paths32
Presence of more than 4 paths01
Non-innermost loop33
Low iteration count01
Data Access IssuesPresence of constant non-unit stride data access20
Presence of indirect access32
Presence of expensive instructions: scatter/gather01
Presence of special instructions executing on a single port01
More than 20% of the loads are accessing the stack13
Vectorization RoadblocksPresence of calls11
Presence of 2 to 4 paths32
Presence of more than 4 paths01
Non-innermost loop33
Presence of constant non-unit stride data access20
Presence of indirect access32
Inefficient VectorizationPresence of expensive instructions: scatter/gather01
Presence of special instructions executing on a single port01
×