Skip to content

gty111/GEMM_MMA

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 

Repository files navigation

cutlass:3.1 CUDA:11.4.4

GEMM MMA 首先构建了一个初级的GEMM kernel, 它使用CUDA mma.sync指令来使用GPU tensor core单元,之后每次引入一个优化概念并对比性能变化

最终优化的性能: 73.65% (相比cutlass算子,测试维度为8192x8192x8192)

source code: gemm.cu

一步步优化GEMM系列,每次引入一个优化概念并对比性能变化,代码在每个分支的gemm.cu

baseline性能: 3.44%

vector分支主要介绍向量化load/store,

优化后性能: 4.74%

bfco分支主要介绍如何通过解决shared memory bank conflict 和 memory coalesce (访存合并) 来优化性能

优化后性能: 5.00%

ldgsts 分支主要来介绍使用Ampere引入的异步拷贝来优化性能

优化后性能: 5.36%

reg 分支介绍使用寄存器来优化性能

优化后性能: 35.39%

prefetch 分支介绍使用数据预取来优化性能

优化后性能:39.36%

ptxas 分支分享一个调优过程中发现的关于ptxas(ptx汇编器)有意思的东西

prefetchx 分支和之前的prefetch分支类似,区别是增加了预取数据大小并利用了同步指令cp.async.waitgroup N

优化后性能:46.89%

shape 分支调整了每个block和warp计算的矩阵C的大小

优化后性能:62.39%

swizzle 分支调整每个thread block分配到的计算位置来优化性能

优化后性能: 68.43%

ldmatrix 分支使用ldmatrix指令来加载共享内存

优化后性能: 73.65%

epilogue 分支增加了对参数alphabeta的支持

About

Optimize GEMM with tensorcore step by step

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published