README.md 3.54 KB
Newer Older
1
2
3
# Composable Kernel

## Methodology
Sam Wu's avatar
Sam Wu committed
4

Chao Liu's avatar
Chao Liu committed
5
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++.
6

Chao Liu's avatar
Chao Liu committed
7
CK utilizes two concepts to achieve performance portability and code maintainability:
8
9
10
* 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
11
![ALT](/docs/data/ck_component.png "CK Components")
12
13

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

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

Sam Wu's avatar
Sam Wu committed
21
22
23
24
25
26
27
28
![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
29
pip3 install -r sphinx/requirements.txt
Sam Wu's avatar
Sam Wu committed
30
31
python3 -m sphinx -T -E -b html -d _build/doctrees -D language=en . _build/html
```
32
33

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

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

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

39
40
41
42
43
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
44

45
46
47
48
49
50
CK is released under the MIT license. [License File](/LICENSE)


# Build CK

## Build docker image
Sam Wu's avatar
Sam Wu committed
51

52
53
54
55
56
```bash
DOCKER_BUILDKIT=1 docker build -t ck:latest -f Dockerfile .
```

## Launch docker
Sam Wu's avatar
Sam Wu committed
57

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

69
## Build CK
Sam Wu's avatar
Sam Wu committed
70

71
72
73
```bash
mkdir build && cd build

74
# Need to specify target ID, example below is for gfx908 and gfx90a
Sam Wu's avatar
Sam Wu committed
75

76
77
78
79
80
cmake                                                                                             \
-D CMAKE_PREFIX_PATH=/opt/rocm                                                                    \
-D CMAKE_CXX_COMPILER=/opt/rocm/bin/hipcc                                                         \
-D CMAKE_CXX_FLAGS="-O3"                                                                          \
-D CMAKE_BUILD_TYPE=Release                                                                       \
81
-D GPU_TARGETS="gfx908;gfx90a"                                                                    \
82
83
84
..
```

85
### Build examples and tests
Sam Wu's avatar
Sam Wu committed
86

87
```bash
88
 make -j examples tests
89
90
91
 make test
```

92
93
94
Instructions for running each individual examples are under [example](/example)


95
## Build ckProfiler
Sam Wu's avatar
Sam Wu committed
96

97
98
99
```bash
 make -j ckProfiler
```
100
Instructions for running ckProfiler are under [profiler](/profiler)
JD's avatar
JD committed
101

102
## Install CK
Sam Wu's avatar
Sam Wu committed
103

104
105
106
107
108
```bash
make install
```

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

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

## Caveat
### Kernel Timing and Verification
Sam Wu's avatar
Sam Wu committed
114

JD's avatar
JD committed
115
116
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
117
output buffer to be accumulated multiple times, causing verification failure.
JD's avatar
JD committed
118
119
120
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.