Number of Paths
Estimated static path count
Description
This metric measures the number of static paths in a function.
The recommended upper limit for this metric is 80. If the number of paths is high, the code is difficult to read and can cause more orange checks. Try to limit the value of this metric.
To enforce limits on metrics, see Compute Code Complexity Metrics Using Polyspace.
Computation Details
The number of paths is calculated according to these rules:
- If the statements in a function do not break the control flow, the number of paths is one. - Even an empty statement such as - ;or empty block such as- {}counts as one path.
- A control flow statement introduces branches and adds to the original one path. - if-else if-else: Each- ifkeyword introduces a new branch. The contribution from an- if-else if-elseblock is the number of branches plus one (the original path). If a catch-all- elseis present, all paths go through the block; otherwise, one path bypasses the block.- For instance, a function with an - if(..) {} else if(..) {} else {}statement has three paths. A function with one- if() {}only has two paths, one that goes through the- ifblock and one that bypasses the block.
- switch-case: Each- caselabel introduces a new branch. The contribution from a- switchblock is the number of- caselabels plus one (the original path). If a catch-all- defaultis present, all paths go through the block; otherwise, one path bypasses the block.- For instance, a function with a statement - switch (var) { case 1: .. break; case 2: .. break; default: .. }has three paths, all going through the- switchblock. If you omit the- default, the function still has three paths, two going through the- switchblock and one bypassing the block.
- forand- while: Each loop statement introduces a new branch. The contribution from a loop is two - a path that goes through the loop and a path that bypasses the loop.
- do-while: Each- do-whilestatement introduces a new branch except when the condition of the- whilestatement is explicitly false. Statements written as- do{/*..*/}while(0)do not function as loops. Such statements are often used for enclosing multiple lines of macros within braces. For instance, this- do-whilestatement serves to encapsulate the multiline macro rather than create a new path:Polyspace® considers such statements to be a single path.- #define myfunc(x) do{ ...\\ ...\\ ...}while(0);
 - Note that a statement with a ternary operator such as is not considered as a statement that breaks the control flow.- result = a > b ? a : b; 
- If more than one control flow statement are present in a sequence without any nesting, the number of paths is the product of the contributions from each control flow statement. - For instance, if a function has three - forloops and two- if-elseblocks, one after another, the number of paths is 2 × 2 × 2 × 2 × 2 = 32.- If many control flow statements are present in a function, the number of paths can be large. Nested control flow statements reduce the number of paths at the cost of increasing the depth of nesting. For an example, see Function with Nested Control Flow Statements. 
- The software displays specific values in cases where the metric is not calculated: - If - gotostatements are present in the body of the function, Polyspace cannot calculate the number of paths and shows the number of paths as- Not Computedinstead.
- If the number of paths reaches an upper limit of 1,000,000,000, Polyspace stops the calculation and displays just the upper limit. The actual value might be higher. 
 
- The number of path is calculated statically. This statically calculated number represents the upper limit of the possible path in a function. Typically, the number of possible path during run time is lower than the number Polyspace reports. 
- Polyspace ignores compiler generated conditional statements in C++ when calculating the number of paths. The compiler might generate implicit conditional statements in operations such as initializing static variables or calling virtual functions. 
Examples
Metric Information
| Group: Function | 
| Acronym: PATH | 
| HIS Metric: Yes |