# **Analysis Report**

## fix\_errors1(char\*, Param\*)

| Duration                | 1.016 s (1,016,366,934 ns) |  |
|-------------------------|----------------------------|--|
| Grid Size               | [ 256,1,1 ]                |  |
| Block Size              | [ 256,1,1 ]                |  |
| Registers/Thread        | 85                         |  |
| Shared Memory/Block     | 0 B                        |  |
| Shared Memory Requested | 48 KiB                     |  |
| Shared Memory Executed  | 48 KiB                     |  |
| Shared Memory Bank Size | 4 B                        |  |

## [0] Tesla K20m

| [0] 100                        | 14 12011                     |
|--------------------------------|------------------------------|
| Compute Capability             | 3.5                          |
| Max. Threads per Block         | 1024                         |
| Max. Shared Memory per Block   | 48 KiB                       |
| Max. Registers per Block       | 65536                        |
| Max. Grid Dimensions           | [ 2147483647, 65535, 65535 ] |
| Max. Block Dimensions          | [ 1024, 1024, 64 ]           |
| Max. Warps per Multiprocessor  | 64                           |
| Max. Blocks per Multiprocessor | 16                           |
| Number of Multiprocessors      | 13                           |
| Multiprocessor Clock Rate      | 705.5 MHz                    |
| Concurrent Kernel              | true                         |
| Max IPC                        | 7                            |
| Threads per Warp               | 32                           |
| Global Memory Bandwidth        | 208 GB/s                     |
| Global Memory Size             | 4.687 GiB                    |
| Constant Memory Size           | 64 KiB                       |
| L2 Cache Size                  | 1.25 MiB                     |
| Memcpy Engines                 | 2                            |
| PCIe Generation                | 2                            |
| PCIe Link Rate                 | 5 Gbit/s                     |
| PCIe Link Width                | 16                           |
|                                |                              |

### 1. Compute, Bandwidth, or Latency Bound

The first step in analyzing an individual kernel is to determine if the performance of the kernel is bounded by computation, memory bandwidth, or instruction/memory latency. The results below indicate that the performance of kernel "fix\_errors1" is most likely limited by instruction and memory latency. You should first examine the information in the "Instruction And Memory Latency" section to determine how it is limiting performance.

#### 1.1. Kernel Performance Is Bound By Instruction And Memory Latency

This kernel exhibits low compute throughput and memory bandwidth utilization relative to the peak performance of "Tesla K20m". These utilization levels indicate that the performance of the kernel is most likely limited by the latency of arithmetic or memory operations. Achieved compute throughput and/or memory bandwidth below 60% of peak typically indicates latency issues.



### 2. Instruction and Memory Latency

Instruction and memory latency limit the performance of a kernel when the GPU does not have enough work to keep busy. The performance of latency-limited kernels can often be improved by increasing occupancy. Occupancy is a measure of how many warps the kernel has active on the GPU, relative to the maximum number of warps supported by the GPU. Theoretical occupancy provides an upper bound while achieved occupancy indicates the kernel's actual occupancy. The results below indicate that occupancy can be improved by reducing the number of registers used by the kernel.

#### 2.1. GPU Utilization Is Limited By Register Usage

The kernel uses 85 registers for each thread (21760 registers for each block). This register usage is likely preventing the kernel from fully utilizing the GPU. Device "Tesla K20m" provides up to 65536 registers for each block. Because the kernel uses 21760 registers for each block each SM is limited to simultaneously executing 2 blocks (16 warps). Chart "Varying Register Count" below shows how changing register usage will change the number of blocks that can execute on each SM.

Optimization: Use the -maxrregcount flag or the \_launch\_bounds\_\_ qualifier to decrease the number of registers used by each thread. This will increase the number of blocks that can execute on each SM.

| Variable            | Achieved | Theoretical | Device Limit | Grid Si | ze: [ 2 | 256,1,1 | ] (25 | 6 block | (s) Blo | ock Siz | e: [ 25 | 6,1,1 |
|---------------------|----------|-------------|--------------|---------|---------|---------|-------|---------|---------|---------|---------|-------|
| Occupancy Per SM    |          |             |              |         |         |         |       |         |         |         |         |       |
| Active Blocks       |          | 2           | 16           | 0       | 2       | 4       | 6     | 8       | 10      | 12      | 14      | 16    |
| Active Warps        | 15.76    | 16          | 64           | 0       | 9       | 18      | 2     | 7 3     | 6       | 45      | 54      | 6634  |
| Active Threads      |          | 512         | 2048         | 0       |         | 512     |       | 1024    |         | 1536    | ĵ.      | 204   |
| Occupancy           | 24.6%    | 25%         | 100%         | 0%      |         | 25%     |       | 50%     |         | 75%     | 6       | 100   |
| Warps               |          |             |              |         |         |         |       |         |         |         |         |       |
| Threads/Block       |          | 256         | 1024         | 0       |         | 256     |       | 512     |         | 768     |         | 102   |
| Warps/Block         |          | 8           | 32           | 0       | 4       | 8       | 12    | 16      | 20      | 24      | 28      | 32    |
| Block Limit         |          | 8           | 16           | 0       | 2       | 4       | 6     | 8       | 10      | 12      | 14      | 16    |
| Registers           |          |             |              |         |         |         |       |         |         |         |         |       |
| Registers/Thread    |          | 85          | 255          | 0       |         | 64      |       | 128     |         | 192     |         | 25!   |
| Registers/Block     |          | 22528       | 65536        | 0       |         | 16k     |       | 32k     |         | 48k     | (       | 64    |
| Block Limit         |          | 2           | 16           | 0       | 2       | 4       | 6     | 8       | 10      | 12      | 14      | 16    |
| Shared Memory       |          |             |              |         |         |         |       |         |         |         |         |       |
| Shared Memory/Block |          | 0           | 49152        | 0       |         |         | L6k   |         | .3      | 2k      |         | 48    |
| Block Limit         |          |             | 16           |         |         |         |       |         |         |         |         |       |

### 2.2. Occupancy Charts

The following charts show how varying different components of the kernel will impact theoretical occupancy.





#### Varying Shared Memory Usage



#### 3. Compute Resources

GPU compute resources limit the performance of a kernel when those resources are insufficient or poorly utilized. Compute resources are used most efficiently when all threads in a warp have the same branching and predication behavior. The results below indicate that a significant fraction of the available compute performance is being wasted because branch and predication behavior is differing for threads within a warp.

#### 3.1. Low Warp Execution Efficiency

Warp execution efficiency is the average percentage of active threads in each executed warp. Increasing warp execution efficiency will increase utilization of the GPU's compute resources. The kernel's warp execution efficiency of 3.3% is less than 100% due to divergent branches and predicated instructions. If predicated instructions are not taken into account the warp execution efficiency for these kernels is 3.5%.

Optimization: Reduce the amount of intra-warp divergence and predication in the kernel.

#### 3.2. Function Unit Utilization

Different types of instructions are executed on different function units within each SM. Performance can be limited if a function unit is over-used by the instructions executed by the kernel. The following results show that the kernel's performance is not limited by overuse of any function unit.

Load/Store - Load and store instructions for local, shared, global, constant, etc. memory.

Arithmetic - All arithmetic instructions including integer and floating-point add and multiply, logical and binary operations, etc. Control-Flow - Direct and indirect branches, jumps, and calls.

Texture - Texture operations.



#### 3.3. Instruction Execution Counts

The following chart shows the mix of instructions executed by the kernel. The instructions are grouped into classes and for each class the chart shows the percentage of thread execution cycles that were devoted to executing instructions in that class. The "Inactive" result shows the thread executions that did not execute any instruction because the thread was predicated or inactive due to divergence.



#### 3.4. Floating-Point Operation Counts

The following chart shows the mix of floating-point operations executed by the kernel. The operations are grouped into classes and for each class the chart shows the percentage of thread execution cycles that were devoted to executing operations in that class. The results do not sum to 100% because non-floating-point operations executed by the kernel are not shown in this chart.



#### 4. Memory Bandwidth

Memory bandwidth limits the performance of a kernel when one or more memories in the GPU cannot provide data at the rate requested by the kernel.

### 4.1. Memory Bandwidth And Utilization

The following table shows the memory bandwidth used by this kernel for the various types of memory on the device. The table also shows the utilization of each memory type relative to the maximum throughput supported by the memory.

