This Open Catalog is a collaborative effort to consolidate expert knowledge on best practices for modernizing and optimizing code written in C, C++, and Fortran programming languages. The Catalog consists of a comprehensive set of checks (rules) that describe specific issues in the source code and provide guidance on corrective actions, along with extensive documentation, example codes and references to additional reading resources.
The Open Catalog includes a suite of microbenchmarks designed to demonstrate:
- No performance degradation when implementing the modernization recommendations.
- Potential performance enhancements achievable through the optimization recommendations.
ID | Title | C | Fortran | C++ | AutoFix |
---|---|---|---|---|---|
PWR001 | Declare global variables as function parameters | x | x | x | |
PWR002 | Declare scalar variables in the smallest possible scope | x | x | ||
PWR003 | Explicitly declare pure functions | x | x | ||
PWR004 | Declare OpenMP scoping for all variables | x | x | x | |
PWR005 | Disable default OpenMP scoping | x | x | x | |
PWR006 | Avoid privatization of read-only variables | x | x | x | |
PWR007 | Disable implicit declaration of variables | x | 1 | ||
PWR008 | Declare the intent for each procedure parameter | x | |||
PWR009 | Use OpenMP teams to offload work to GPU | x | x | x | |
PWR010 | Avoid column-major array access in C/C++ | x | x | ||
PWR012 | Pass only required fields from derived type as parameters | x | x | x | |
PWR013 | Avoid copying unused variables to or from the GPU | x | x | x | |
PWR014 | Out-of-dimension-bounds matrix access | x | x | ||
PWR015 | Avoid copying unnecessary array elements to or from the GPU | x | x | x | |
PWR016 | Use separate arrays instead of an Array-of-Structs | x | x | x | |
PWR017 | Using countable while loops instead of for loops may inhibit vectorization | x | x | ||
PWR018 | Call to recursive function within a loop inhibits vectorization | x | x | x | |
PWR019 | Consider interchanging loops to favor vectorization by maximizing inner loop's trip count | x | x | x | |
PWR020 | Consider loop fission to enable vectorization | x | x | x | |
PWR021 | Consider loop fission with scalar to vector promotion to enable vectorization | x | x | x | |
PWR022 | Move invariant conditional out of the loop to facilitate vectorization | x | x | x | |
PWR023 | Add 'restrict' for pointer function parameters to hint the compiler that vectorization is safe | x | x | ||
PWR024 | Loop can be rewritten in OpenMP canonical form | x | x | ||
PWR025 | Consider annotating pure function with OpenMP 'declare simd' | x | x | x | |
PWR026 | Annotate function for OpenMP Offload | x | x | x | |
PWR027 | Annotate function for OpenACC Offload | x | x | x | |
PWR028 | Remove pointer increment preventing performance optimization | x | x | ||
PWR029 | Remove integer increment preventing performance optimization | x | x | x | |
PWR030 | Remove pointer assignment preventing performance optimization for perfectly nested loops | x | x | x | |
PWR031 | Replace call to pow by multiplication, division and/or square root | x | x | ||
PWR032 | Avoid calls to mathematical functions with higher precision than required | x | x | ||
PWR033 | Move invariant conditional out of the loop to avoid redundant computations | x | x | x | |
PWR034 | Avoid strided array access to improve performance | x | x | x | |
PWR035 | Avoid non-consecutive array access to improve performance | x | x | x | |
PWR036 | Avoid indirect array access to improve performance | x | x | x | |
PWR037 | Potential precision loss in call to mathematical function | x | x | ||
PWR039 | Consider loop interchange to improve the locality of reference and enable vectorization | x | x | x | 1 |
PWR040 | Consider loop tiling to improve the locality of reference | x | x | x | |
PWR042 | Consider loop interchange by promoting the scalar reduction variable to an array | x | x | x | |
PWR043 | Consider loop interchange by replacing the scalar reduction value | x | x | x | |
PWR044 | Avoid unnecessary floating-point data conversions involving constants | x | x | ||
PWR045 | Replace division with a multiplication with a reciprocal | x | x | ||
PWR046 | Replace two divisions with a division and a multiplication | x | x | ||
PWR048 | Replace multiplication/addition combo with an explicit call to fused multiply-add | x | x | ||
PWR049 | Move iterator-dependent condition outside of the loop | x | x | x | |
PWR050 | Consider applying multithreading parallelism to forall loop | x | x | x | 1 |
PWR051 | Consider applying multithreading parallelism to scalar reduction loop | x | x | x | 1 |
PWR052 | Consider applying multithreading parallelism to sparse reduction loop | x | x | x | 1 |
PWR053 | Consider applying vectorization to forall loop | x | x | x | 1 |
PWR054 | Consider applying vectorization to scalar reduction loop | x | x | x | 1 |
PWR055 | Consider applying offloading parallelism to forall loop | x | x | x | 1 |
PWR056 | Consider applying offloading parallelism to scalar reduction loop | x | x | x | 1 |
PWR057 | Consider applying offloading parallelism to sparse reduction loop | x | x | x | 1 |
PWR060 | Consider loop fission to separate gather memory access pattern | x | x | x | |
PWR062 | Consider loop interchange by removing accumulation on array value | x | x | x | |
PWR063 | Avoid using legacy Fortran constructs | x | |||
PWR068 | Encapsulate external procedures within modules to avoid the risks of calling implicit interfaces | x | |||
PWR069 | Use the keyword only to explicitly state what to import from a module | x | |||
PWR070 | Declare array dummy arguments as assumed-shape arrays | x | |||
PWR071 | Prefer real(kind=kind_value) for declaring consistent floating types | x | |||
PWR072 | Add an explicit save attribute when initializing variables in their declaration | x | |||
PWR073 | Transform common block into a module for better data encapsulation | x | |||
PWD002 | Unprotected multithreading reduction operation | x | x | x | |
PWD003 | Missing array range in data copy to the GPU | x | x | x | |
PWD004 | Out-of-memory-bounds array access | x | x | x | |
PWD005 | Array range copied to or from the GPU does not cover the used range | x | x | x | |
PWD006 | Missing deep copy of non-contiguous data to the GPU | x | x | x | |
PWD007 | Unprotected multithreading recurrence | x | x | x | |
PWD008 | Unprotected multithreading recurrence due to out-of-dimension-bounds array access | x | x | x | |
PWD009 | Incorrect privatization in parallel region | x | x | x | |
PWD010 | Incorrect sharing in parallel region | x | x | x | |
PWD011 | Missing OpenMP lastprivate clause | x | x | x | |
RMK001 | Loop nesting that might benefit from hybrid parallelization using multithreading and SIMD | x | x | x | |
RMK002 | Loop nesting that might benefit from hybrid parallelization using offloading and SIMD | x | x | x | |
RMK003 | Potentially privatizable temporary variable | x | x | ||
RMK007 | SIMD opportunity within a multithreaded region | x | x | x | |
RMK008 | SIMD opportunity within an offloaded region | x | x | x | |
RMK009 | Outline loop to increase compiler and tooling code coverage | x | x | ||
RMK010 | The vectorization cost model states the loop is not a SIMD opportunity due to strided memory accesses in the loop body | x | x | x | |
RMK012 | The vectorization cost model states the loop is not a SIMD opportunity because conditional execution renders vectorization inefficient | x | x | x | |
RMK013 | The vectorization cost model states the loop is not a SIMD opportunity because loops with low trip count unknown at compile time do not benefit from vectorization | x | x | x | |
RMK014 | The vectorization cost model states the loop is not a SIMD opportunity due to unpredictable memory accesses in the loop body | x | x | x | |
RMK015 | Tune compiler optimization flags to increase the speed of the code | x | x | x | |
RMK016 | Tune compiler optimization flags to avoid potential changes in floating point precision | x | x | x |
AutoFix: Denotes tools that support automatic correction of the corresponding check. Readers are encouraged to report additional tools with autofix capabilities for these checks. The tools are tagged in the table as follows:
- 1: Codee
Contributions are welcomed! Feel free to send pull requests to amend, improve or include new content on the catalog. Issues are also open for any question or suggestion.