blob: 47c0ae039b4008070b299ca34aef24e2446f13ca [file] [log] [blame]
David Beck10b4dfd2018-09-19 12:03:20 +01001#
2# Copyright © 2017 Arm Ltd. All rights reserved.
3# SPDX-License-Identifier: MIT
4#
telsoa014fcda012018-03-09 14:13:49 +00005cmake_minimum_required (VERSION 3.0.2) # 3.0.2 required for return() statement used in AddDllCopyCommands.cmake.
6project(armnn)
7
8set(additional_cmake_files)
9list(APPEND additional_cmake_files
10 cmake/Utils.cmake
11 cmake/GlobalConfig.cmake
12 cmake/AddDllCopyCommands.cmake)
13
14foreach(cmake_file ${additional_cmake_files})
15 include(${cmake_file})
16endforeach()
17
18if (BUILD_TESTS)
19 add_subdirectory(tests)
20endif()
21
telsoa01c577f2c2018-08-31 09:22:23 +010022add_subdirectory(samples)
23
telsoa014fcda012018-03-09 14:13:49 +000024# Include the additional cmake files in their own target so that they will appear nicely in IDEs
25add_custom_target(AdditionalCMakeFiles SOURCES ${additional_cmake_files})
26
27set(armnnUtils_sources)
28list(APPEND armnnUtils_sources
29 src/armnnUtils/GraphTopologicalSort.hpp
arovir01616e7752018-10-01 17:08:59 +010030 src/armnnUtils/Half.hpp
telsoa014fcda012018-03-09 14:13:49 +000031 src/armnnUtils/Logging.hpp
telsoa014fcda012018-03-09 14:13:49 +000032 src/armnnUtils/Logging.cpp
Matteo Martincigh21350152018-11-28 16:22:22 +000033 src/armnnUtils/Permute.hpp
telsoa014fcda012018-03-09 14:13:49 +000034 src/armnnUtils/Permute.cpp
Matteo Martincigh21350152018-11-28 16:22:22 +000035 src/armnnUtils/DataLayoutIndexed.cpp
36 src/armnnUtils/DataLayoutIndexed.hpp
surmeh01bceff2f2018-03-29 16:29:27 +010037 src/armnnUtils/DotSerializer.cpp
38 src/armnnUtils/DotSerializer.hpp
surmeh013537c2c2018-05-18 16:31:43 +010039 src/armnnUtils/HeapProfiling.cpp
40 src/armnnUtils/HeapProfiling.hpp
41 src/armnnUtils/LeakChecking.cpp
42 src/armnnUtils/LeakChecking.hpp
telsoa01c577f2c2018-08-31 09:22:23 +010043 src/armnnUtils/CsvReader.cpp
44 src/armnnUtils/CsvReader.hpp
45 src/armnnUtils/FloatingPointConverter.cpp
46 src/armnnUtils/FloatingPointConverter.hpp
47 src/armnnUtils/VerificationHelpers.hpp
48 src/armnnUtils/VerificationHelpers.cpp
Sadik Armagan479045b2018-10-01 11:51:37 +010049 src/armnnUtils/ParserHelper.hpp
50 src/armnnUtils/ParserHelper.cpp
Matthew Bentham4057d912019-01-21 15:45:51 +000051 src/armnnUtils/ParserPrototxtFixture.hpp
52 src/armnnUtils/PrototxtConversions.hpp
53 src/armnnUtils/PrototxtConversions.cpp
Nina Drozdd41b2592018-11-19 13:03:36 +000054 src/armnnUtils/TensorUtils.hpp
55 src/armnnUtils/TensorUtils.cpp
telsoa014fcda012018-03-09 14:13:49 +000056 )
telsoa014fcda012018-03-09 14:13:49 +000057
58add_library_ex(armnnUtils STATIC ${armnnUtils_sources})
59
60if(BUILD_CAFFE_PARSER)
61 # ArmNN Parser source files required for all build options
62 set(armnn_caffe_parser_sources)
63 list(APPEND armnn_caffe_parser_sources
64 include/armnnCaffeParser/ICaffeParser.hpp
telsoa01c577f2c2018-08-31 09:22:23 +010065 src/armnnCaffeParser/RecordByRecordCaffeParser.hpp
66 src/armnnCaffeParser/RecordByRecordCaffeParser.cpp
telsoa014fcda012018-03-09 14:13:49 +000067 src/armnnCaffeParser/CaffeParser.hpp
68 src/armnnCaffeParser/CaffeParser.cpp
69 ${CAFFE_GENERATED_SOURCES}/caffe/proto/caffe.pb.cc
70 )
71 # The generated Caffe protobuf .cc file is not warning clean and we can't fix them.
72 if(COMPILER_IS_GNU_LIKE)
73 set_source_files_properties(${CAFFE_GENERATED_SOURCES}/caffe/proto/caffe.pb.cc PROPERTIES COMPILE_FLAGS "-Wno-conversion -Wno-sign-conversion")
74 endif()
75
76 add_library_ex(armnnCaffeParser SHARED ${armnn_caffe_parser_sources})
77 set_target_properties(armnnCaffeParser PROPERTIES COMPILE_FLAGS "${CAFFE_PARSER_ADDITIONAL_COMPILE_FLAGS}")
78
79 target_include_directories(armnnCaffeParser PRIVATE src/armnnUtils)
80
81 target_link_libraries(armnnCaffeParser ${Boost_LOG_LIBRARY} ${Boost_THREAD_LIBRARY} ${Boost_SYSTEM_LIBRARY})
82
83 target_link_libraries(armnnCaffeParser armnn)
84 target_link_libraries(armnnCaffeParser ${PROTOBUF_LIBRARIES})
telsoa01c577f2c2018-08-31 09:22:23 +010085
86endif()
87
88if(BUILD_ONNX_PARSER)
89 set(armnn_onnx_parser_sources)
90 list(APPEND armnn_onnx_parser_sources
91 include/armnnOnnxParser/IOnnxParser.hpp
92 src/armnnOnnxParser/OnnxParser.hpp
93 src/armnnOnnxParser/OnnxParser.cpp
94 ${ONNX_GENERATED_SOURCES}/onnx/onnx.pb.cc
95 )
96 # The generated onnx protobuf .cc files are not warning clean and we can't fix them.
97 if(COMPILER_IS_GNU_LIKE)
98 set_source_files_properties(${ONNX_GENERATED_SOURCES}/onnx/onnx.pb.cc PROPERTIES COMPILE_FLAGS "-Wno-conversion -Wno-sign-conversion")
99 endif()
100
101 add_library_ex(armnnOnnxParser SHARED ${armnn_onnx_parser_sources})
102
103 target_include_directories(armnnOnnxParser PRIVATE src/armnnUtils)
104
105 target_link_libraries(armnnOnnxParser armnn)
106
107 # Protobuf
108 target_link_libraries(armnnOnnxParser ${PROTOBUF_LIBRARIES})
telsoa014fcda012018-03-09 14:13:49 +0000109endif()
110
surmeh01bceff2f2018-03-29 16:29:27 +0100111if(BUILD_TF_PARSER)
112 set(armnn_tf_parser_sources)
113 list(APPEND armnn_tf_parser_sources
114 include/armnnTfParser/ITfParser.hpp
115 src/armnnTfParser/TfParser.hpp
116 src/armnnTfParser/TfParser.cpp
117 ${TF_PROTOBUFS}
118 )
119 # The generated tensorflow protobuf .cc files are not warning clean and we can't fix them.
120 if(COMPILER_IS_GNU_LIKE)
121 set_source_files_properties(${TF_PROTOBUFS} PROPERTIES COMPILE_FLAGS "-Wno-conversion -Wno-sign-conversion")
122 endif()
123
124 add_library_ex(armnnTfParser SHARED ${armnn_tf_parser_sources})
125
126 target_include_directories(armnnTfParser PRIVATE src/armnnUtils)
127
128 target_link_libraries(armnnTfParser armnn)
129
130 # Protobuf (use the specific version tensorflow wants)
131 target_link_libraries(armnnTfParser ${PROTOBUF_LIBRARIES})
132endif()
133
telsoa01c577f2c2018-08-31 09:22:23 +0100134if(BUILD_TF_LITE_PARSER)
135 set(armnn_tf_lite_parser_sources)
136 list(APPEND armnn_tf_lite_parser_sources
137 include/armnnTfLiteParser/ITfLiteParser.hpp
138 src/armnnTfLiteParser/TfLiteParser.hpp
139 src/armnnTfLiteParser/TfLiteParser.cpp
Matteo Martincigh21350152018-11-28 16:22:22 +0000140 )
telsoa01c577f2c2018-08-31 09:22:23 +0100141
Matteo Martincigh21350152018-11-28 16:22:22 +0000142 add_library_ex(armnnTfLiteParser SHARED ${armnn_tf_lite_parser_sources})
telsoa01c577f2c2018-08-31 09:22:23 +0100143
Matteo Martincigh21350152018-11-28 16:22:22 +0000144 target_include_directories(armnnTfLiteParser PRIVATE src/armnn)
145 target_include_directories(armnnTfLiteParser PRIVATE src/armnnUtils)
Nattapat Chaimanowong949f1252019-01-31 15:36:39 +0000146 target_include_directories(armnnTfLiteParser SYSTEM PRIVATE "${TF_LITE_SCHEMA_INCLUDE_PATH}")
telsoa01c577f2c2018-08-31 09:22:23 +0100147
Matteo Martincigh21350152018-11-28 16:22:22 +0000148 target_link_libraries(armnnTfLiteParser ${Boost_FILESYSTEM_LIBRARY} ${Boost_THREAD_LIBRARY})
149 target_link_libraries(armnnTfLiteParser armnn ${FLATBUFFERS_LIBRARY})
telsoa01c577f2c2018-08-31 09:22:23 +0100150endif()
151
Nattapat Chaimanowong949f1252019-01-31 15:36:39 +0000152if(BUILD_ARMNN_SERIALIZER)
153 add_custom_command (
154 OUTPUT src/armnnSerializer/Schema_generated.h
155 COMMAND ${FLATC_DIR}/flatc -o ${CMAKE_CURRENT_BINARY_DIR}/src/armnnSerializer --cpp
156 ${CMAKE_CURRENT_SOURCE_DIR}/src/armnnSerializer/Schema.fbs
157 )
158
159 set(armnn_serializer_sources)
160 list(APPEND armnn_serializer_sources
Nattapat Chaimanowongac9cadc2019-02-13 15:52:41 +0000161 include/armnnSerializer/ISerializer.hpp
Kevin May43a799c2019-02-08 16:31:42 +0000162 include/armnnDeserializeParser/IDeserializeParser.hpp
Mike Kelly8c1701a2019-02-11 17:01:27 +0000163 src/armnnSerializer/Schema_generated.h
164 src/armnnSerializer/Serializer.hpp
165 src/armnnSerializer/Serializer.cpp
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000166 src/armnnSerializer/SerializerUtils.hpp
167 src/armnnSerializer/SerializerUtils.cpp
Kevin May43a799c2019-02-08 16:31:42 +0000168 src/armnnDeserializeParser/DeserializeParser.hpp
169 src/armnnDeserializeParser/DeserializeParser.cpp
Nattapat Chaimanowong949f1252019-01-31 15:36:39 +0000170 )
171
172 add_library_ex(armnnSerializer SHARED ${armnn_serializer_sources})
173
174 target_include_directories(armnnSerializer PRIVATE src/armnn)
175 target_include_directories(armnnSerializer PRIVATE src/armnnUtils)
176
177 # System include to suppress warnings for flatbuffers generated files
178 target_include_directories(armnnSerializer SYSTEM PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/src/armnnSerializer)
179
180 target_link_libraries(armnnSerializer armnn ${FLATBUFFERS_LIBRARY})
181endif()
182
telsoa014fcda012018-03-09 14:13:49 +0000183list(APPEND armnn_sources
184 include/armnn/ArmNN.hpp
David Beck9df2d952018-10-10 15:11:44 +0100185 include/armnn/BackendId.hpp
telsoa014fcda012018-03-09 14:13:49 +0000186 include/armnn/Descriptors.hpp
187 include/armnn/DescriptorsFwd.hpp
David Beck9df2d952018-10-10 15:11:44 +0100188 include/armnn/Exceptions.hpp
David Becke97c6e02018-10-03 13:09:28 +0100189 include/armnn/ILayerSupport.hpp
jimfly015f4e41f2019-01-23 16:10:17 +0000190 include/armnn/ILayerVisitor.hpp
telsoa014fcda012018-03-09 14:13:49 +0000191 include/armnn/INetwork.hpp
Derek Lamberti27d83072019-02-05 16:00:08 +0000192 include/armnn/INetworkQuantizer.hpp
David Beck9df2d952018-10-10 15:11:44 +0100193 include/armnn/IProfiler.hpp
194 include/armnn/IRuntime.hpp
195 include/armnn/LayerSupport.hpp
Mike Kelly8c1701a2019-02-11 17:01:27 +0000196 include/armnn/LayerVisitorBase.hpp
David Beck9df2d952018-10-10 15:11:44 +0100197 include/armnn/LstmParams.hpp
198 include/armnn/NetworkFwd.hpp
David Beck5eec11d2018-10-04 15:43:17 +0100199 include/armnn/Optional.hpp
telsoa014fcda012018-03-09 14:13:49 +0000200 include/armnn/Tensor.hpp
201 include/armnn/TensorFwd.hpp
202 include/armnn/Types.hpp
203 include/armnn/TypesUtils.hpp
204 include/armnn/Utils.hpp
telsoa014fcda012018-03-09 14:13:49 +0000205 include/armnn/Version.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100206 src/armnn/layers/LayerCloneBase.hpp
207 src/armnn/layers/LayerWithParameters.hpp
208 src/armnn/layers/ActivationLayer.hpp
209 src/armnn/layers/ActivationLayer.cpp
210 src/armnn/layers/AdditionLayer.hpp
211 src/armnn/layers/AdditionLayer.cpp
212 src/armnn/layers/BatchNormalizationLayer.hpp
213 src/armnn/layers/BatchNormalizationLayer.cpp
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +0000214 src/armnn/layers/BatchToSpaceNdLayer.hpp
215 src/armnn/layers/BatchToSpaceNdLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100216 src/armnn/layers/ConstantLayer.hpp
217 src/armnn/layers/ConstantLayer.cpp
218 src/armnn/layers/Convolution2dLayer.hpp
219 src/armnn/layers/Convolution2dLayer.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100220 src/armnn/layers/ConvertFp16ToFp32Layer.hpp
221 src/armnn/layers/ConvertFp16ToFp32Layer.cpp
222 src/armnn/layers/ConvertFp32ToFp16Layer.hpp
223 src/armnn/layers/ConvertFp32ToFp16Layer.cpp
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000224 src/armnn/layers/DebugLayer.hpp
225 src/armnn/layers/DebugLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100226 src/armnn/layers/DepthwiseConvolution2dLayer.hpp
227 src/armnn/layers/DepthwiseConvolution2dLayer.cpp
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000228 src/armnn/layers/DetectionPostProcessLayer.hpp
229 src/armnn/layers/DetectionPostProcessLayer.cpp
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000230 src/armnn/layers/ElementwiseBaseLayer.hpp
231 src/armnn/layers/ElementwiseBaseLayer.cpp
FrancisMurtagh20995952018-12-17 12:11:36 +0000232 src/armnn/layers/EqualLayer.hpp
233 src/armnn/layers/EqualLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100234 src/armnn/layers/FakeQuantizationLayer.hpp
235 src/armnn/layers/FakeQuantizationLayer.cpp
236 src/armnn/layers/FloorLayer.hpp
237 src/armnn/layers/FloorLayer.cpp
238 src/armnn/layers/FullyConnectedLayer.hpp
239 src/armnn/layers/FullyConnectedLayer.cpp
narpra01b89b05f2019-01-16 09:53:09 +0000240 src/armnn/layers/GatherLayer.cpp
241 src/armnn/layers/GatherLayer.hpp
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000242 src/armnn/layers/GreaterLayer.cpp
243 src/armnn/layers/GreaterLayer.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100244 src/armnn/layers/InputLayer.hpp
245 src/armnn/layers/InputLayer.cpp
246 src/armnn/layers/L2NormalizationLayer.hpp
247 src/armnn/layers/L2NormalizationLayer.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100248 src/armnn/layers/LstmLayer.cpp
249 src/armnn/layers/LstmLayer.hpp
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000250 src/armnn/layers/MaximumLayer.cpp
251 src/armnn/layers/MaximumLayer.hpp
narpra0132b90462018-09-13 11:07:48 +0100252 src/armnn/layers/MeanLayer.hpp
253 src/armnn/layers/MeanLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100254 src/armnn/layers/MemCopyLayer.hpp
255 src/armnn/layers/MemCopyLayer.cpp
256 src/armnn/layers/MergerLayer.hpp
257 src/armnn/layers/MergerLayer.cpp
kevmay0190539692018-11-29 08:40:19 +0000258 src/armnn/layers/MinimumLayer.cpp
259 src/armnn/layers/MinimumLayer.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100260 src/armnn/layers/MultiplicationLayer.hpp
261 src/armnn/layers/MultiplicationLayer.cpp
262 src/armnn/layers/NormalizationLayer.hpp
263 src/armnn/layers/NormalizationLayer.cpp
264 src/armnn/layers/OutputLayer.hpp
265 src/armnn/layers/OutputLayer.cpp
Mohamed Nour Abouelseoud5662c202018-09-24 13:30:09 +0100266 src/armnn/layers/PadLayer.hpp
267 src/armnn/layers/PadLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100268 src/armnn/layers/PermuteLayer.hpp
269 src/armnn/layers/PermuteLayer.cpp
270 src/armnn/layers/Pooling2dLayer.hpp
271 src/armnn/layers/Pooling2dLayer.cpp
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100272 src/armnn/layers/DivisionLayer.cpp
273 src/armnn/layers/DivisionLayer.hpp
Matteo Martincigh49124022019-01-11 13:25:59 +0000274 src/armnn/layers/PreCompiledLayer.hpp
275 src/armnn/layers/PreCompiledLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100276 src/armnn/layers/ReshapeLayer.hpp
277 src/armnn/layers/ReshapeLayer.cpp
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000278 src/armnn/layers/SpaceToBatchNdLayer.hpp
279 src/armnn/layers/SpaceToBatchNdLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100280 src/armnn/layers/ResizeBilinearLayer.hpp
281 src/armnn/layers/ResizeBilinearLayer.cpp
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000282 src/armnn/layers/RsqrtLayer.cpp
283 src/armnn/layers/RsqrtLayer.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100284 src/armnn/layers/SoftmaxLayer.hpp
285 src/armnn/layers/SoftmaxLayer.cpp
286 src/armnn/layers/SplitterLayer.hpp
287 src/armnn/layers/SplitterLayer.cpp
Conor Kennedy430b5d82018-11-14 15:28:28 +0000288 src/armnn/layers/StridedSliceLayer.cpp
289 src/armnn/layers/StridedSliceLayer.hpp
David Beckc2044fe2018-09-05 15:00:38 +0100290 src/armnn/layers/SubtractionLayer.cpp
291 src/armnn/layers/SubtractionLayer.hpp
Matteo Martincigh49124022019-01-11 13:25:59 +0000292 src/armnn/BackendSettings.hpp
Nattapat Chaimanowong649dd952019-01-22 16:10:44 +0000293 src/armnn/CompatibleTypes.hpp
telsoa014fcda012018-03-09 14:13:49 +0000294 src/armnn/Descriptors.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100295 src/armnn/DeviceSpec.hpp
telsoa014fcda012018-03-09 14:13:49 +0000296 src/armnn/Exceptions.cpp
telsoa014fcda012018-03-09 14:13:49 +0000297 src/armnn/Graph.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100298 src/armnn/Graph.hpp
299 src/armnn/IGraphObservable.hpp
300 src/armnn/Instrument.hpp
301 src/armnn/InternalTypes.cpp
302 src/armnn/InternalTypes.hpp
Matteo Martincigh49124022019-01-11 13:25:59 +0000303 src/armnn/ISubGraphConverter.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100304 src/armnn/JsonPrinter.cpp
305 src/armnn/JsonPrinter.hpp
306 src/armnn/Layer.cpp
307 src/armnn/LayerFwd.hpp
308 src/armnn/Layer.hpp
309 src/armnn/LayersFwd.hpp
310 src/armnn/LayerSupportCommon.hpp
311 src/armnn/LayerSupport.cpp
312 src/armnn/LoadedNetwork.cpp
313 src/armnn/LoadedNetwork.hpp
telsoa014fcda012018-03-09 14:13:49 +0000314 src/armnn/Network.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100315 src/armnn/Network.hpp
Derek Lamberti27d83072019-02-05 16:00:08 +0000316 src/armnn/NetworkQuantizer.cpp
317 src/armnn/NetworkQuantizer.hpp
Matteo Martincigha8d572d2019-02-07 17:51:09 +0000318 src/armnn/NetworkQuantizerUtils.cpp
319 src/armnn/NetworkQuantizerUtils.hpp
Aron Virginas-Tar5fdfe822018-11-21 13:14:42 +0000320 src/armnn/NetworkUtils.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100321 src/armnn/NetworkUtils.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100322 src/armnn/Observable.cpp
323 src/armnn/Observable.hpp
324 src/armnn/Optimizer.cpp
325 src/armnn/Optimizer.hpp
Matteo Martincigha8d572d2019-02-07 17:51:09 +0000326 src/armnn/OverrideInputRangeVisitor.cpp
327 src/armnn/OverrideInputRangeVisitor.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100328 src/armnn/Profiling.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100329 src/armnn/ProfilingEvent.cpp
330 src/armnn/ProfilingEvent.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100331 src/armnn/Profiling.hpp
Derek Lamberti27d83072019-02-05 16:00:08 +0000332 src/armnn/QuantizerVisitor.cpp
333 src/armnn/QuantizerVisitor.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100334 src/armnn/Runtime.cpp
335 src/armnn/Runtime.hpp
Derek Lamberti8a4ca102019-02-08 17:54:20 +0000336 src/armnn/RangeTracker.cpp
337 src/armnn/RangeTracker.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100338 src/armnn/SerializeLayerParameters.cpp
339 src/armnn/SerializeLayerParameters.hpp
Derek Lamberti27d83072019-02-05 16:00:08 +0000340 src/armnn/StaticRangeVisitor.cpp
341 src/armnn/StaticRangeVisitor.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100342 src/armnn/SubGraph.cpp
343 src/armnn/SubGraph.hpp
344 src/armnn/SubGraphSelector.cpp
345 src/armnn/SubGraphSelector.hpp
telsoa014fcda012018-03-09 14:13:49 +0000346 src/armnn/Tensor.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100347 src/armnn/TypeUtils.hpp
telsoa014fcda012018-03-09 14:13:49 +0000348 src/armnn/Utils.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100349 src/armnn/WallClockTimer.cpp
350 src/armnn/WallClockTimer.hpp
telsoa014fcda012018-03-09 14:13:49 +0000351 src/armnn/optimizations/All.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100352 src/armnn/optimizations/ConvertConstants.hpp
telsoa014fcda012018-03-09 14:13:49 +0000353 src/armnn/optimizations/MovePermuteUp.hpp
354 src/armnn/optimizations/Optimization.hpp
355 src/armnn/optimizations/OptimizeConsecutiveReshapes.hpp
356 src/armnn/optimizations/OptimizeInversePermutes.hpp
357 src/armnn/optimizations/PermuteAsReshape.hpp
358 src/armnn/optimizations/SquashEqualSiblings.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100359 src/armnn/optimizations/OptimizeInverseConversions.hpp
360 src/armnn/optimizations/ConvertFp32NetworkToFp16.hpp
keidav01738c2e62018-12-11 16:14:20 +0000361 src/armnn/optimizations/AddDebug.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100362 third-party/half/half.hpp
telsoa014fcda012018-03-09 14:13:49 +0000363 )
364
telsoa014fcda012018-03-09 14:13:49 +0000365# Files used for Streamline-based profiling backend
366if(PROFILING_BACKEND_STREAMLINE)
367 list(APPEND armnn_sources
368 ${GATOR_ROOT}/annotate/streamline_annotate.h
369 ${GATOR_ROOT}/annotate/streamline_annotate.c)
370endif()
371
David Beck10b4dfd2018-09-19 12:03:20 +0100372# the backends under src/backends extend the list of
David Beck3cc9a622018-10-12 10:38:31 +0100373# object libs armnn to include in the build
David Beck10b4dfd2018-09-19 12:03:20 +0100374include(src/backends/backends.cmake)
David Beck3cc9a622018-10-12 10:38:31 +0100375foreach(lib ${armnnLibraries})
376 message("Adding object library dependency to armnn: ${lib}")
377 list(APPEND armnn_sources $<TARGET_OBJECTS:${lib}>)
378endforeach()
379
380add_library_ex(armnn SHARED ${armnn_sources})
David Beck10b4dfd2018-09-19 12:03:20 +0100381
telsoa014fcda012018-03-09 14:13:49 +0000382target_include_directories(armnn PRIVATE src/armnn)
383target_include_directories(armnn PRIVATE src/armnnUtils)
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +0000384target_include_directories(armnn PRIVATE src/backends)
David Beck3cc9a622018-10-12 10:38:31 +0100385
386target_link_libraries(armnn armnnUtils)
387
telsoa014fcda012018-03-09 14:13:49 +0000388target_link_libraries(armnn ${CMAKE_DL_LIBS})
389
390install(TARGETS armnn DESTINATION ${CMAKE_INSTALL_PREFIX}/lib)
391if(BUILD_CAFFE_PARSER)
392 install(TARGETS armnnCaffeParser DESTINATION ${CMAKE_INSTALL_PREFIX}/lib)
393endif()
telsoa01c577f2c2018-08-31 09:22:23 +0100394if(BUILD_ONNX_PARSER)
395 install(TARGETS armnnOnnxParser DESTINATION ${CMAKE_INSTALL_PREFIX}/lib)
396endif()
surmeh01bceff2f2018-03-29 16:29:27 +0100397if(BUILD_TF_PARSER)
398 install(TARGETS armnnTfParser DESTINATION ${CMAKE_INSTALL_PREFIX}/lib)
399endif()
telsoa01c577f2c2018-08-31 09:22:23 +0100400if(BUILD_TF_LITE_PARSER)
401 install(TARGETS armnnTfLiteParser DESTINATION ${CMAKE_INSTALL_PREFIX}/lib)
402endif()
Nattapat Chaimanowong949f1252019-01-31 15:36:39 +0000403if(BUILD_ARMNN_SERIALIZER)
404 install(TARGETS armnnSerializer DESTINATION ${CMAKE_INSTALL_PREFIX}/lib)
405endif()
telsoa014fcda012018-03-09 14:13:49 +0000406install(DIRECTORY include/ DESTINATION ${CMAKE_INSTALL_PREFIX}/include)
407
408target_link_libraries(armnn ${Boost_LOG_LIBRARY} ${Boost_THREAD_LIBRARY} ${Boost_SYSTEM_LIBRARY})
409
410if(ARMCOMPUTENEON OR ARMCOMPUTECL)
411 target_link_libraries(armnn ${ARMCOMPUTE_LIBRARIES})
412endif()
413if(ARMCOMPUTECL)
414 target_link_libraries(armnn ${OPENCL_LIBRARIES})
415endif()
416
417if(PROFILING_BACKEND_STREAMLINE)
418 target_link_libraries(armnn pthread)
419endif()
420
telsoa014fcda012018-03-09 14:13:49 +0000421if(BUILD_UNIT_TESTS)
422 set(unittest_sources)
423 list(APPEND unittest_sources
jimfly01aebf2e72019-02-05 09:20:11 +0000424 src/armnn/test/ConstTensorLayerVisitor.hpp
425 src/armnn/test/ConstTensorLayerVisitor.cpp
telsoa014fcda012018-03-09 14:13:49 +0000426 src/armnn/test/CreateWorkload.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100427 src/armnn/test/CsvReaderTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100428 src/armnn/test/EndToEndTest.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100429 src/armnn/test/FloatingPointConverterTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100430 src/armnn/test/GraphTests.cpp
narpra016f37f832018-12-21 18:30:00 +0000431 src/armnn/test/GraphUtils.cpp
telsoa014fcda012018-03-09 14:13:49 +0000432 src/armnn/test/GraphUtils.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100433 src/armnn/test/InstrumentTests.cpp
Éanna Ó Catháin262553e2018-11-14 11:26:23 +0000434 src/armnn/test/LayerValidateOutputTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100435 src/armnn/test/NetworkTests.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100436 src/armnn/test/ObservableTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100437 src/armnn/test/OptimizerTests.cpp
438 src/armnn/test/OptionalTest.cpp
439 src/armnn/test/ProfilerTests.cpp
440 src/armnn/test/ProfilingEventTest.cpp
Derek Lamberti7205fed2019-02-06 16:20:46 +0000441 src/armnn/test/QuantizerTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100442 src/armnn/test/RuntimeTests.cpp
443 src/armnn/test/RuntimeTests.hpp
444 src/armnn/test/SubGraphTests.cpp
445 src/armnn/test/TensorHelpers.hpp
446 src/armnn/test/TensorTest.cpp
FrancisMurtagh531ef942019-02-01 11:48:58 +0000447 src/armnn/test/TestInputOutputLayerVisitor.cpp
448 src/armnn/test/TestInputOutputLayerVisitor.hpp
FrancisMurtagh1306b192019-01-28 14:03:21 +0000449 src/armnn/test/TestLayerVisitor.cpp
450 src/armnn/test/TestLayerVisitor.hpp
FrancisMurtagh28d3d632019-01-29 12:15:23 +0000451 src/armnn/test/TestNameOnlyLayerVisitor.cpp
452 src/armnn/test/TestNameOnlyLayerVisitor.hpp
FrancisMurtaghf08876f2019-02-04 15:41:17 +0000453 src/armnn/test/TestNameAndDescriptorLayerVisitor.hpp
454 src/armnn/test/TestNameAndDescriptorLayerVisitor.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100455 src/armnn/test/UnitTests.cpp
456 src/armnn/test/UnitTests.hpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000457 src/armnn/test/UtilsTests.cpp
Matthew Bentham4057d912019-01-21 15:45:51 +0000458 src/armnnUtils/test/PrototxtConversionsTest.cpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000459 src/armnnUtils/test/ParserHelperTest.cpp
460 )
telsoa014fcda012018-03-09 14:13:49 +0000461
surmeh01bceff2f2018-03-29 16:29:27 +0100462 if(BUILD_TF_PARSER)
463 list(APPEND unittest_sources
464 src/armnnTfParser/test/Activations.cpp
465 src/armnnTfParser/test/Addition.cpp
Ferran Balaguerfbdad032018-12-28 18:15:24 +0000466 src/armnnTfParser/test/AddN.cpp
narpra016f37f832018-12-21 18:30:00 +0000467 src/armnnTfParser/test/Assert.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100468 src/armnnTfParser/test/BiasAdd.cpp
469 src/armnnTfParser/test/BroadcastForAdd.cpp
470 src/armnnTfParser/test/Convolution2d.cpp
471 src/armnnTfParser/test/Concat.cpp
472 src/armnnTfParser/test/ConcatOfConcats.cpp
473 src/armnnTfParser/test/DepthwiseConvolution2d.cpp
jimfly0184c70e62018-12-19 13:14:46 +0000474 src/armnnTfParser/test/Equal.cpp
Conor Kennedyc2130a02018-12-05 11:05:54 +0000475 src/armnnTfParser/test/ExpandDims.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100476 src/armnnTfParser/test/FusedBatchNorm.cpp
FrancisMurtagh94412af2019-01-24 10:53:39 +0000477 src/armnnTfParser/test/Gather.cpp
jimfly01a06bf312018-12-18 16:24:51 +0000478 src/armnnTfParser/test/Greater.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100479 src/armnnTfParser/test/Identity.cpp
480 src/armnnTfParser/test/LocalResponseNormalization.cpp
Sadik Armagan975c09a2018-12-04 10:02:08 +0000481 src/armnnTfParser/test/Maximum.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100482 src/armnnTfParser/test/MaximumForLeakyRelu.cpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000483 src/armnnTfParser/test/Mean.cpp
Nattapat Chaimanowong24df8222018-12-04 13:47:02 +0000484 src/armnnTfParser/test/Minimum.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100485 src/armnnTfParser/test/Multiplication.cpp
jimfly01f6ba7472018-12-04 10:09:52 +0000486 src/armnnTfParser/test/Pad.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100487 src/armnnTfParser/test/MultiOutput.cpp
488 src/armnnTfParser/test/PassThru.cpp
489 src/armnnTfParser/test/Pooling.cpp
saoste01bbd40612018-08-28 15:41:51 +0100490 src/armnnTfParser/test/RealDiv.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100491 src/armnnTfParser/test/Reshape.cpp
492 src/armnnTfParser/test/ResizeBilinear.cpp
Mohamed Nour Abouelseoud7a8892f2019-01-09 14:19:58 +0000493 src/armnnTfParser/test/Rsqrt.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100494 src/armnnTfParser/test/Shape.cpp
495 src/armnnTfParser/test/Softmax.cpp
496 src/armnnTfParser/test/TestDependencies.cpp
497 src/armnnTfParser/test/FullyConnected.cpp
498 src/armnnTfParser/test/Constant.cpp
499 src/armnnTfParser/test/TestMultiInputsOutputs.cpp
Sadik Armagan2ad6cb42018-12-27 11:23:44 +0000500 src/armnnTfParser/test/Split.cpp
jimfly0123be07e2018-12-04 17:47:22 +0000501 src/armnnTfParser/test/Squeeze.cpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000502 src/armnnTfParser/test/Sub.cpp
503 )
surmeh01bceff2f2018-03-29 16:29:27 +0100504 endif()
505
telsoa01c577f2c2018-08-31 09:22:23 +0100506 if(BUILD_TF_LITE_PARSER)
Matthew Bentham6c8e8e72019-01-15 17:57:00 +0000507 enable_language(ASM)
telsoa01c577f2c2018-08-31 09:22:23 +0100508 list(APPEND unittest_sources
509 src/armnnTfLiteParser/test/ParserFlatbuffersFixture.hpp
Sadik Armagan479045b2018-10-01 11:51:37 +0100510 src/armnnTfLiteParser/test/Activations.cpp
Bruno Goncalvesd4ac6a42018-12-18 12:56:22 -0200511 src/armnnTfLiteParser/test/Addition.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100512 src/armnnTfLiteParser/test/AvgPool2D.cpp
Sadik Armagan479045b2018-10-01 11:51:37 +0100513 src/armnnTfLiteParser/test/Concatenation.cpp
Bruno Goncalves3d7efe92018-12-27 14:21:43 -0200514 src/armnnTfLiteParser/test/Constant.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100515 src/armnnTfLiteParser/test/Conv2D.cpp
516 src/armnnTfLiteParser/test/DepthwiseConvolution2D.cpp
Sadik Armagan8853c1f2018-10-22 09:04:18 +0100517 src/armnnTfLiteParser/test/FullyConnected.cpp
Nattapat Chaimanowongb66504b2018-10-17 15:19:14 +0100518 src/armnnTfLiteParser/test/MaxPool2D.cpp
Bruno Goncalves2235cee2018-12-19 12:51:45 -0200519 src/armnnTfLiteParser/test/Mean.cpp
Bruno Goncalvesf803f782018-12-18 13:40:30 -0200520 src/armnnTfLiteParser/test/Multiplication.cpp
Bruno Goncalves6c2355b2018-12-19 12:52:01 -0200521 src/armnnTfLiteParser/test/Pad.cpp
Sadik Armagan479045b2018-10-01 11:51:37 +0100522 src/armnnTfLiteParser/test/Reshape.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100523 src/armnnTfLiteParser/test/Softmax.cpp
524 src/armnnTfLiteParser/test/Squeeze.cpp
525 src/armnnTfLiteParser/test/LoadModel.cpp
526 src/armnnTfLiteParser/test/GetBuffer.cpp
527 src/armnnTfLiteParser/test/OutputShapeOfSqueeze.cpp
528 src/armnnTfLiteParser/test/InputOutputTensorNames.cpp
529 src/armnnTfLiteParser/test/GetTensorIds.cpp
530 src/armnnTfLiteParser/test/GetSubgraphInputsOutputs.cpp
531 src/armnnTfLiteParser/test/GetInputsOutputs.cpp
Matthew Bentham6c8e8e72019-01-15 17:57:00 +0000532 src/armnnTfLiteParser/test/Schema.s
telsoa01c577f2c2018-08-31 09:22:23 +0100533 )
Matthew Bentham6c8e8e72019-01-15 17:57:00 +0000534 set_source_files_properties(src/armnnTfLiteParser/test/Schema.s PROPERTIES COMPILE_FLAGS "-x assembler-with-cpp")
telsoa01c577f2c2018-08-31 09:22:23 +0100535 endif()
536
telsoa014fcda012018-03-09 14:13:49 +0000537 if(BUILD_CAFFE_PARSER)
538 list(APPEND unittest_sources
539 src/armnnCaffeParser/test/TestAdd.cpp
540 src/armnnCaffeParser/test/TestConcat.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100541 src/armnnCaffeParser/test/TestConvolution.cpp
telsoa014fcda012018-03-09 14:13:49 +0000542 src/armnnCaffeParser/test/TestDropout.cpp
543 src/armnnCaffeParser/test/TestInputs.cpp
544 src/armnnCaffeParser/test/TestMul.cpp
545 src/armnnCaffeParser/test/TestPooling2d.cpp
546 src/armnnCaffeParser/test/TestInPlace.cpp
547 src/armnnCaffeParser/test/TestMultiInputsOutputs.cpp
548 src/armnnCaffeParser/test/TestSplit.cpp
549 )
550 endif()
551
Kevin May43a799c2019-02-08 16:31:42 +0000552 if(BUILD_ARMNN_SERIALIZER)
553 enable_language(ASM)
554 list(APPEND unittest_sources
555 src/armnnSerializer/Schema_generated.h
Mike Kelly8c1701a2019-02-11 17:01:27 +0000556 src/armnnSerializer/test/SerializerTests.cpp
Kevin May43a799c2019-02-08 16:31:42 +0000557 src/armnnDeserializeParser/test/DeserializeAdd.cpp
Sadik Armagan5f450272019-02-12 14:31:45 +0000558 src/armnnDeserializeParser/test/DeserializeMultiplication.cpp
Saoirse Stewart3166c3e2019-02-18 15:24:53 +0000559 src/armnnDeserializeParser/test/DeserializePooling2d.cpp
Kevin May43a799c2019-02-08 16:31:42 +0000560 src/armnnDeserializeParser/test/ParserFlatbuffersSerializeFixture.hpp
561 src/armnnDeserializeParser/test/SchemaSerialize.s
562 )
563 set_source_files_properties(src/armnnDeserializeParser/test/SchemaSerialize.s PROPERTIES COMPILE_FLAGS "-x assembler-with-cpp")
564 endif()
565
telsoa01c577f2c2018-08-31 09:22:23 +0100566 if(BUILD_ONNX_PARSER)
567 list(APPEND unittest_sources
568 src/armnnOnnxParser/test/Constructor.cpp
569 src/armnnOnnxParser/test/CreateNetwork.cpp
570 src/armnnOnnxParser/test/ProtoxtFixture.cpp
571 src/armnnOnnxParser/test/Const.cpp
572 src/armnnOnnxParser/test/Pooling.cpp
573 src/armnnOnnxParser/test/Reshape.cpp
574 src/armnnOnnxParser/test/Relu.cpp
575 src/armnnOnnxParser/test/Conv2D.cpp
576 src/armnnOnnxParser/test/Addition.cpp
577 src/armnnOnnxParser/test/FullyConnected.cpp
578 src/armnnOnnxParser/test/GetInputsOutputs.cpp
579 src/armnnOnnxParser/test/BatchNorm.cpp
580 src/armnnOnnxParser/test/DepthConv.cpp
581 )
582 endif()
583
Matteo Martincigh4423ac72018-10-11 17:39:30 +0100584 foreach(lib ${armnnUnitTestLibraries})
David Beck3cc9a622018-10-12 10:38:31 +0100585 message("Adding object library dependency to UnitTests: ${lib}")
Matteo Martincigh4423ac72018-10-11 17:39:30 +0100586 list(APPEND unittest_sources $<TARGET_OBJECTS:${lib}>)
587 endforeach()
588
589 add_executable(UnitTests ${unittest_sources})
telsoa014fcda012018-03-09 14:13:49 +0000590 target_include_directories(UnitTests PRIVATE src/armnn)
591 target_include_directories(UnitTests PRIVATE src/armnnUtils)
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +0000592 target_include_directories(UnitTests PRIVATE src/backends)
telsoa014fcda012018-03-09 14:13:49 +0000593
Nattapat Chaimanowong949f1252019-01-31 15:36:39 +0000594 if(BUILD_TF_LITE_PARSER)
595 target_include_directories(UnitTests SYSTEM PRIVATE "${TF_LITE_SCHEMA_INCLUDE_PATH}")
596 endif()
597
telsoa01c577f2c2018-08-31 09:22:23 +0100598 if(VALGRIND_FOUND)
599 if(HEAP_PROFILING OR LEAK_CHECKING)
600 message("Valgrind is disabled for heap profiling and leak checking builds.")
601 else()
602 # Valgrind works with gperftools version number <= 2.4
603 target_compile_definitions(UnitTests PRIVATE "WITH_VALGRIND=1")
604 endif()
telsoa014fcda012018-03-09 14:13:49 +0000605 endif()
606
telsoa014fcda012018-03-09 14:13:49 +0000607 target_link_libraries(UnitTests ${CMAKE_THREAD_LIBS_INIT})
telsoa01c577f2c2018-08-31 09:22:23 +0100608 target_link_libraries(UnitTests ${Boost_UNIT_TEST_FRAMEWORK_LIBRARY} ${Boost_SYSTEM_LIBRARY} ${Boost_FILESYSTEM_LIBRARY})
telsoa014fcda012018-03-09 14:13:49 +0000609
Matteo Martincigh4423ac72018-10-11 17:39:30 +0100610 target_link_libraries(UnitTests armnn)
611 target_link_libraries(UnitTests armnnUtils)
612
surmeh01bceff2f2018-03-29 16:29:27 +0100613 if(BUILD_TF_PARSER)
614 target_link_libraries(UnitTests armnnTfParser)
615 endif()
616
telsoa014fcda012018-03-09 14:13:49 +0000617 if(BUILD_CAFFE_PARSER)
618 target_link_libraries(UnitTests armnnCaffeParser)
619 endif()
620
Kevin May43a799c2019-02-08 16:31:42 +0000621 if(BUILD_ARMNN_SERIALIZER)
Mike Kelly8c1701a2019-02-11 17:01:27 +0000622 target_include_directories(UnitTests SYSTEM PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/src/armnnSerializer)
Kevin May43a799c2019-02-08 16:31:42 +0000623 target_link_libraries(UnitTests armnnSerializer)
624 endif()
625
telsoa01c577f2c2018-08-31 09:22:23 +0100626 if(BUILD_TF_LITE_PARSER)
627 target_link_libraries(UnitTests armnnTfLiteParser)
628 endif()
629
630 if(BUILD_ONNX_PARSER)
631 target_link_libraries(UnitTests armnnOnnxParser)
632 endif()
633
telsoa014fcda012018-03-09 14:13:49 +0000634 addDllCopyCommands(UnitTests)
635endif()
Nattapat Chaimanowong4fbae332019-02-14 15:28:02 +0000636
637if (BUILD_ARMNN_SERIALIZER AND BUILD_TF_PARSER)
638 set(ArmnnConverter_sources
639 src/armnnConverter/ArmnnConverter.cpp)
640
641 add_executable_ex(ArmnnConverter ${ArmnnConverter_sources})
642 target_include_directories(ArmnnConverter PRIVATE src/armnn)
643 target_include_directories(ArmnnConverter PRIVATE src/armnnUtils)
644
645 target_link_libraries(ArmnnConverter armnnTfParser)
646 target_link_libraries(ArmnnConverter armnnSerializer)
647
648 target_link_libraries(ArmnnConverter armnn)
649 target_link_libraries(ArmnnConverter ${CMAKE_THREAD_LIBS_INIT})
650 target_link_libraries(ArmnnConverter
651 ${Boost_SYSTEM_LIBRARY}
652 ${Boost_FILESYSTEM_LIBRARY}
653 ${Boost_PROGRAM_OPTIONS_LIBRARY})
654 addDllCopyCommands(ArmnnConverter)
655endif()