README.md 7.12 KB
Newer Older
1
2
# Composable Kernel

Chao Liu's avatar
Chao Liu committed
3
Composable Kernel (CK) library aims to provide a programming model for writing performance critical kernels for machine learning workloads across multiple architectures including GPUs, CPUs, etc, through general purpose kernel languages, like HIP C++.
4

Chao Liu's avatar
Chao Liu committed
5
CK utilizes two concepts to achieve performance portability and code maintainability:
6
7
8
* A tile-based programming model
* Algorithm complexity reduction for complex ML operators, using innovative technique we call "Tensor Coordinate Transformation".

Sam Wu's avatar
Sam Wu committed
9
![ALT](/docs/data/ck_component.png "CK Components")
10
11

## Code Structure
Sam Wu's avatar
Sam Wu committed
12

13
Current CK library are structured into 4 layers:
Chao Liu's avatar
Chao Liu committed
14
* "Templated Tile Operators" layer
15
16
17
18
* "Templated Kernel and Invoker" layer
* "Instantiated Kernel and Invoker" layer
* "Client API" layer

Sam Wu's avatar
Sam Wu committed
19
20
21
22
23
24
25
26
![ALT](/docs/data/ck_layer.png "CK Layers")

## Documentation

Run the steps below to build documentation locally.

```
cd docs
Sam Wu's avatar
Sam Wu committed
27
pip3 install -r sphinx/requirements.txt
Sam Wu's avatar
Sam Wu committed
28
29
python3 -m sphinx -T -E -b html -d _build/doctrees -D language=en . _build/html
```
30
31

## Contributors
Sam Wu's avatar
Sam Wu committed
32

33
34
35
The list of developers and contributors is here: [Contributors](/CONTRIBUTORS.md)

## Citation
Sam Wu's avatar
Sam Wu committed
36

37
38
39
40
41
If you use CK, please use following citations:
* CK paper will be freely available on arXiv soon: [Realizing Tensor Operators Using Coordinate Transformations and Tile Based Programming](???)
* [CITATION.cff](/CITATION.cff)

## License
Sam Wu's avatar
Sam Wu committed
42

43
44
45
CK is released under the MIT license. [License File](/LICENSE)


illsilin's avatar
illsilin committed
46
47
48
49
50
51
# Build Composable Kernel

We recommend building Composable Kernel inside docker containers that include 
all necessary packages. Pre-built docker images are available from this public repo: 

https://hub.docker.com/r/rocm/composable_kernel/tags
52

illsilin's avatar
illsilin committed
53
In order to build a new docker image, you can use the Dockerfile provided with the source code as shown below:
Sam Wu's avatar
Sam Wu committed
54

55
56
57
58
```bash
DOCKER_BUILDKIT=1 docker build -t ck:latest -f Dockerfile .
```

illsilin's avatar
illsilin committed
59
The docker container can then be launched, e.g., using the following command:
Sam Wu's avatar
Sam Wu committed
60

61
62
63
64
65
66
67
```bash
docker run                                     \
-it                                            \
--privileged                                   \
--group-add sudo                               \
-w /root/workspace                             \
-v ${PATH_TO_LOCAL_WORKSPACE}:/root/workspace  \
68
ck:latest                                      \
69
70
/bin/bash
```
Chao Liu's avatar
Chao Liu committed
71

illsilin's avatar
illsilin committed
72
After launching the container you can clone Composable Kernel source code from the github repository and start the build:
Sam Wu's avatar
Sam Wu committed
73

74
```bash
illsilin's avatar
illsilin committed
75
76
77
78
79
git clone https://github.com/ROCmSoftwarePlatform/composable_kernel.git && \
cd composable_kernel && \
mkdir build && \
cd build
```
illsilin's avatar
illsilin committed
80
You will need to set the GPU_TARGETS macro to specify GPU target architecture(s) that you want
illsilin's avatar
illsilin committed
81
to execute CK on, e.g., gfx908, or gfx908;gfx90a;gfx940.
illsilin's avatar
illsilin committed
82
You can specify either single or multiple architectures (use semicolon to separate), e.g.:
Sam Wu's avatar
Sam Wu committed
83

illsilin's avatar
illsilin committed
84
```bash
85
86
87
88
cmake                                                                                             \
-D CMAKE_PREFIX_PATH=/opt/rocm                                                                    \
-D CMAKE_CXX_COMPILER=/opt/rocm/bin/hipcc                                                         \
-D CMAKE_BUILD_TYPE=Release                                                                       \
89
-D GPU_TARGETS="gfx908;gfx90a"                                                                    \
90
91
..
```
illsilin's avatar
illsilin committed
92
93
94
95
If GPU_TARGETS is not set on the cmake command line, CK will be built for all GPU targets supported by the
current compiler (this may take quite a long time).

After that you can build the entire CK library with just
96
97

```bash
illsilin's avatar
illsilin committed
98
make -j
99
```
illsilin's avatar
illsilin committed
100
101

## Install CK
102
103

```bash
illsilin's avatar
illsilin committed
104
make -j install
105
106
```

illsilin's avatar
illsilin committed
107
## Build examples and tests
Sam Wu's avatar
Sam Wu committed
108

109
```bash
110
 make -j examples tests
111
112
```

illsilin's avatar
illsilin committed
113
## Build and run all examples and tests
114
115
116

```bash
 make -j check
117
118
```

119
120
121
Instructions for running each individual examples are under [example](/example)


122
## Build ckProfiler
Sam Wu's avatar
Sam Wu committed
123

124
125
126
```bash
 make -j ckProfiler
```
127
Instructions for running ckProfiler are under [profiler](/profiler)
JD's avatar
JD committed
128

illsilin's avatar
illsilin committed
129
130
131
132
133
134
135
136
Please note the "-j" option for building with multiple threads in parallel. This speeds up the build significantly.
Depending on the number of CPU cores and the amount of RAM on your system, it may be advizable to limit the number of threads.
By default, "-j" will try to launch one thread per CPU core. This could potentially cause the build to run out of memory and crash,
for example if you have a 128-core CPU and 64Gb of RAM. In such cases, you can try to reduce the number of threads to 32 by using "-j32".

Additional cmake flags can be used to significantly speed-up the build:

INSTANCES_ONLY (by default is OFF) must be set to ON in order to build only the instances and library
illsilin's avatar
illsilin committed
137
138
while skipping all tests, examples, and profiler. This is useful in cases when you plan to use CK as a dependency and don't plan to
run any examples or tests.
illsilin's avatar
illsilin committed
139

illsilin's avatar
illsilin committed
140
141
DTYPES (by default not set) can be set to any subset of "fp64;fp32;fp16;fp8;bf16;int8" to build instances
of select data types only. The main default data types are fp32 and fp16, other data types can be safely skipped.
illsilin's avatar
illsilin committed
142

illsilin's avatar
illsilin committed
143
144
145
DL_KERNELS (by default is OFF) must be set to ON in order to build instances, such as, gemm_dl or batched_gemm_multi_d_dl.
Those instances are mostly useful on architectures such the NAVI2x, since of most other platforms miuch faster "xdl" or "wmma"
instances are available.
illsilin's avatar
illsilin committed
146
147
148
149
150
151

## Using sccache for building

The default CK docker images come with pre-installed version of sccache which supports clang being used as hip-compiler
" -x hip". Using sccache can help reduce the time to re-build the code from hours to 1 - 2 minutes. In order to
invoke sccache, you need to run
Sam Wu's avatar
Sam Wu committed
152

153
```bash
illsilin's avatar
illsilin committed
154
155
156
157
158
159
 sccache --start-server
```
and add the following flags to the cmake command line:

```bash
 -DCMAKE_CXX_COMPILER_LAUNCHER=sccache -DCMAKE_C_COMPILER_LAUNCHER=sccache
160
```
illsilin's avatar
illsilin committed
161
162
You may need to clean up the build folder and repeat the cmake and make steps in order to take advantage of the sccache
during the subsequent builds.
163
164

## Using CK as pre-built kernel library
Sam Wu's avatar
Sam Wu committed
165

166
Instructions for using CK as a pre-built kernel library are under [client_example](/client_example)
JD's avatar
JD committed
167

168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
## Contributing

When you contribute to Composable Kernel, make sure to run `clang-format` on all the changed files. We highly recommend using git hooks that are managed by the `pre-commit` framework. To install hooks, run:

```bash
sudo script/install_precommit.sh
```

This way, `pre-commit` will add the appropriate hooks to your local repository and automatically run `clang-format` (and possibly additional checks) before any commit is created.

If you need to uninstall hooks from the repository, you can do so by running the following command:

```bash
script/uninstall_precommit.sh
```

If for any reason, you need to temporarily disable precommit hooks, you can add the `--no-verify` option to the `git commit` command.

JD's avatar
JD committed
186
187
## Caveat
### Kernel Timing and Verification
Sam Wu's avatar
Sam Wu committed
188

JD's avatar
JD committed
189
190
CK's own kernel timer will warn up kernel once, and then run it multiple times
to get average kernel time. For some kernels that use atomic add, this will cause
Chao Liu's avatar
Chao Liu committed
191
output buffer to be accumulated multiple times, causing verification failure.
JD's avatar
JD committed
192
193
194
To work around it, do not use CK's own timer and do verification at the same time.
CK's own timer and verification in each example and ckProfiler can be enabled or
disabled from command line.