Commit 47939cb
Depthwise convolution for oneAPI (#1131)
* snapshot adding oneapi
* fix reduce constexpr
* further updates
* update the bridge and testbench
* fix issues discovered when compiling
* update bridge writing files
* build library (but not tested)
* fix a bug in testbench
* snapshot after some debugging
* remove forgotten debug printing
* add build
* pre-commit fixes
* fix more pre-commit
* fix more pre-commit errors
* snapshot of work before reworking types
* Use using to decide array type, some preliminary updates
* snapshot unifying types
* fix the testbench and bridge
* snapshot updating nnet_utils (not finished)
* define array in nnet_types for oneAPI
* fix parallel conv2d
* add back the streaming versions of algs, most unconverted
* tentatively complete streaming for dense but not functional
* first version that compiles streaming
* change how the pipe value type is extracted
* fix pre-commit error
* always treat elu as ELU class
* fix batchnorm
* snapshot towards fixing conv
* snapshot fixing test for streaming
* fix conv1d
* fix conv2d
* fix reshape and flatten for oneAPI
* initial oneAPI tests
* remove nnet_dense_compressed from oneAPI
* add merge functionality (untested)
* fix merge for oneAPI
* fix merge for oneAPI (missing commit)
* add zeropadding
* standardize paralellization spelling
* fix pointwise for oneAPI
* remove references to quartus
* more replace quartus with oneapi
* snapshot on the way towards implementing pooling
* fix io_stream pooling for oneAPI
* add fix for Conv2DBatchnorm
* accidentally committed CMakeLists.txt in my debug setup
* reshaping, not fully tested
* fix cloning of streams
* fix pytest library loading
* remove unused template
* fix some activation bugs
* fix the overwriting of directories in the pytest
* update version of test repository
* try to fix docker issue
* bump hls4ml-testing tag to 0.5.2
* try not restricting tensorflow-model-optimizatoin
* Update to 0.5.3 for testing
* bump to docker image 0.5.4, suggested by Ben
* fix pre-commit warning
* dial down N_TESTS_PER_YAML to 4
* revert tensorflow-model-optimization change
* fix issue of saving in "obsolete" h5 format
* fix embedding for oneAPI
* First attempt at adding RNNs to oneAPI
* fix bug in array size
* fix order or indices
* make queues static in bridge
* fix logic error in repack stream
* changing the style, but functionally identical
* update pointwise optimizer for oneAPI
* add oneAPI to test_multi_dense.py
* fix updating weight types
* initial changes of templates, for testing
* fix weight naming, product selection
* make im2col the default; fix winograd size
* fix up streaming dense and convolution
* fix prelu, some batchnorm
* fix weight array of exponential types
* move ACExponentialPrecisionDefinition to oneapi_types
* attempt to fix batchnorm and recurrent
* fixed BatchNormalizationQuantizedTanhConfigTemplate template selection
* fix embedding_stream
* fix lstm and simple rnn
* fix GRU
* fix winograd, and also disable it by default
* fix threshold name
* split bn_quant to be backend-specific
* add type inference to oneAPI
* add oneAPI to pytorch tests
* fix pooling with padding for oneAPI and Quartus
* Compilation for larger models enabled by increasing -fconstexpr-steps
* add oneapi clone tests; remove reduntand multi_clone test
* remove some attributes to avoid overwrite warnings
* make extra handling for oneAPI like others (as in PR #1067)
* remove warnings for extra optimizers that are not scheduled on purpose
* update parametrized activations
* intial depthconv2d implementation
* intial depthconv2d implementation
* Rename to depthconv, add strides and add tests
* Remove class for DepthwiseConv2D
* Remove Separable convolution template
* Remove layer optimizer for sepconv
* Loop unroll
* Pre-commit format
* Fix spelling
* depthconv1d, channel order in loop, product
* Gather result to accum
---------
Co-authored-by: Jovan Mitrevski <jmitrevs@fnal.gov>
Co-authored-by: Jovan Mitrevski <j.p.mitrevski@gmail.com>1 parent 3c63e27 commit 47939cb
File tree
12 files changed
+222
-10
lines changed- hls4ml
- backends
- fpga
- oneapi/passes
- model/optimizer
- passes
- templates/oneapi/firmware/nnet_utils
- test/pytest
12 files changed
+222
-10
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
94 | 94 | | |
95 | 95 | | |
96 | 96 | | |
97 | | - | |
| 97 | + | |
98 | 98 | | |
99 | 99 | | |
100 | 100 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
4 | | - | |
| 4 | + | |
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
| |||
70 | 70 | | |
71 | 71 | | |
72 | 72 | | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
73 | 84 | | |
74 | 85 | | |
75 | | - | |
| 86 | + | |
76 | 87 | | |
77 | 88 | | |
78 | 89 | | |
| |||
137 | 148 | | |
138 | 149 | | |
139 | 150 | | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
140 | 157 | | |
141 | 158 | | |
142 | 159 | | |
| |||
183 | 200 | | |
184 | 201 | | |
185 | 202 | | |
186 | | - | |
| 203 | + | |
187 | 204 | | |
188 | 205 | | |
189 | 206 | | |
| |||
233 | 250 | | |
234 | 251 | | |
235 | 252 | | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
59 | 59 | | |
60 | 60 | | |
61 | 61 | | |
62 | | - | |
| 62 | + | |
63 | 63 | | |
64 | 64 | | |
65 | 65 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | | - | |
| 2 | + | |
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
13 | | - | |
14 | | - | |
| 13 | + | |
| 14 | + | |
15 | 15 | | |
16 | 16 | | |
17 | 17 | | |
| |||
70 | 70 | | |
71 | 71 | | |
72 | 72 | | |
73 | | - | |
| 73 | + | |
74 | 74 | | |
75 | 75 | | |
76 | 76 | | |
| |||
100 | 100 | | |
101 | 101 | | |
102 | 102 | | |
103 | | - | |
| 103 | + | |
104 | 104 | | |
105 | 105 | | |
106 | 106 | | |
| |||
Lines changed: 19 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
Lines changed: 60 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
Lines changed: 19 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
Lines changed: 76 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
23 | 23 | | |
24 | 24 | | |
25 | 25 | | |
| 26 | + | |
26 | 27 | | |
27 | 28 | | |
28 | 29 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
24 | 24 | | |
25 | 25 | | |
26 | 26 | | |
| 27 | + | |
27 | 28 | | |
28 | 29 | | |
29 | 30 | | |
| |||
0 commit comments