blob: 043064349405ccb44afca6b7ad35abc1db42e40c [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#
Jim Flynn3091b062019-02-15 14:45:04 +00005cmake_minimum_required (VERSION 3.0.2) # 3.0.2 required for return() statement used in AddDllCopyCommands.cmake
telsoa014fcda012018-03-09 14:13:49 +00006project(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
Matteo Martincighe7d44982019-08-05 12:16:47 +010018if (DYNAMIC_BACKEND_PATHS)
19 # It's expected to have the format: DYNAMIC_BACKEND_PATHS="PATH_1:PATH_2...:PATH_N"
20 add_definitions('-DDYNAMIC_BACKEND_PATHS="${DYNAMIC_BACKEND_PATHS}"')
21endif()
22
Matthew Benthama7b79282019-06-03 13:00:50 +010023include(GNUInstallDirs)
24
Ruomei Yandb7c3912019-03-08 17:50:25 +000025add_subdirectory(samples)
26add_subdirectory(src/armnnTfLiteParser)
27add_subdirectory(src/armnnSerializer)
28
telsoa014fcda012018-03-09 14:13:49 +000029if (BUILD_TESTS)
30 add_subdirectory(tests)
31endif()
32
33# Include the additional cmake files in their own target so that they will appear nicely in IDEs
34add_custom_target(AdditionalCMakeFiles SOURCES ${additional_cmake_files})
35
36set(armnnUtils_sources)
37list(APPEND armnnUtils_sources
38 src/armnnUtils/GraphTopologicalSort.hpp
arovir01616e7752018-10-01 17:08:59 +010039 src/armnnUtils/Half.hpp
telsoa014fcda012018-03-09 14:13:49 +000040 src/armnnUtils/Logging.hpp
telsoa014fcda012018-03-09 14:13:49 +000041 src/armnnUtils/Logging.cpp
Matteo Martincigh21350152018-11-28 16:22:22 +000042 src/armnnUtils/Permute.hpp
telsoa014fcda012018-03-09 14:13:49 +000043 src/armnnUtils/Permute.cpp
Matteo Martincigh21350152018-11-28 16:22:22 +000044 src/armnnUtils/DataLayoutIndexed.cpp
45 src/armnnUtils/DataLayoutIndexed.hpp
surmeh01bceff2f2018-03-29 16:29:27 +010046 src/armnnUtils/DotSerializer.cpp
47 src/armnnUtils/DotSerializer.hpp
surmeh013537c2c2018-05-18 16:31:43 +010048 src/armnnUtils/HeapProfiling.cpp
49 src/armnnUtils/HeapProfiling.hpp
50 src/armnnUtils/LeakChecking.cpp
51 src/armnnUtils/LeakChecking.hpp
Éanna Ó Catháina4247d52019-05-08 14:00:45 +010052 src/armnnUtils/ModelAccuracyChecker.cpp
53 src/armnnUtils/ModelAccuracyChecker.hpp
telsoa01c577f2c2018-08-31 09:22:23 +010054 src/armnnUtils/CsvReader.cpp
55 src/armnnUtils/CsvReader.hpp
56 src/armnnUtils/FloatingPointConverter.cpp
57 src/armnnUtils/FloatingPointConverter.hpp
58 src/armnnUtils/VerificationHelpers.hpp
59 src/armnnUtils/VerificationHelpers.cpp
Sadik Armagan479045b2018-10-01 11:51:37 +010060 src/armnnUtils/ParserHelper.hpp
61 src/armnnUtils/ParserHelper.cpp
Matthew Bentham4057d912019-01-21 15:45:51 +000062 src/armnnUtils/ParserPrototxtFixture.hpp
63 src/armnnUtils/PrototxtConversions.hpp
64 src/armnnUtils/PrototxtConversions.cpp
Jim Flynn2fd61002019-05-03 12:54:26 +010065 src/armnnUtils/TensorIOUtils.hpp
Nina Drozdd41b2592018-11-19 13:03:36 +000066 src/armnnUtils/TensorUtils.hpp
67 src/armnnUtils/TensorUtils.cpp
telsoa014fcda012018-03-09 14:13:49 +000068 )
telsoa014fcda012018-03-09 14:13:49 +000069
70add_library_ex(armnnUtils STATIC ${armnnUtils_sources})
Jim Flynnf92dfce2019-05-02 11:33:25 +010071target_include_directories(armnnUtils PRIVATE src/backends)
telsoa014fcda012018-03-09 14:13:49 +000072
73if(BUILD_CAFFE_PARSER)
74 # ArmNN Parser source files required for all build options
75 set(armnn_caffe_parser_sources)
76 list(APPEND armnn_caffe_parser_sources
77 include/armnnCaffeParser/ICaffeParser.hpp
telsoa01c577f2c2018-08-31 09:22:23 +010078 src/armnnCaffeParser/RecordByRecordCaffeParser.hpp
79 src/armnnCaffeParser/RecordByRecordCaffeParser.cpp
telsoa014fcda012018-03-09 14:13:49 +000080 src/armnnCaffeParser/CaffeParser.hpp
81 src/armnnCaffeParser/CaffeParser.cpp
82 ${CAFFE_GENERATED_SOURCES}/caffe/proto/caffe.pb.cc
83 )
84 # The generated Caffe protobuf .cc file is not warning clean and we can't fix them.
85 if(COMPILER_IS_GNU_LIKE)
86 set_source_files_properties(${CAFFE_GENERATED_SOURCES}/caffe/proto/caffe.pb.cc PROPERTIES COMPILE_FLAGS "-Wno-conversion -Wno-sign-conversion")
87 endif()
88
89 add_library_ex(armnnCaffeParser SHARED ${armnn_caffe_parser_sources})
90 set_target_properties(armnnCaffeParser PROPERTIES COMPILE_FLAGS "${CAFFE_PARSER_ADDITIONAL_COMPILE_FLAGS}")
91
92 target_include_directories(armnnCaffeParser PRIVATE src/armnnUtils)
93
94 target_link_libraries(armnnCaffeParser ${Boost_LOG_LIBRARY} ${Boost_THREAD_LIBRARY} ${Boost_SYSTEM_LIBRARY})
95
96 target_link_libraries(armnnCaffeParser armnn)
97 target_link_libraries(armnnCaffeParser ${PROTOBUF_LIBRARIES})
telsoa01c577f2c2018-08-31 09:22:23 +010098
99endif()
100
101if(BUILD_ONNX_PARSER)
102 set(armnn_onnx_parser_sources)
103 list(APPEND armnn_onnx_parser_sources
104 include/armnnOnnxParser/IOnnxParser.hpp
105 src/armnnOnnxParser/OnnxParser.hpp
106 src/armnnOnnxParser/OnnxParser.cpp
107 ${ONNX_GENERATED_SOURCES}/onnx/onnx.pb.cc
108 )
109 # The generated onnx protobuf .cc files are not warning clean and we can't fix them.
110 if(COMPILER_IS_GNU_LIKE)
111 set_source_files_properties(${ONNX_GENERATED_SOURCES}/onnx/onnx.pb.cc PROPERTIES COMPILE_FLAGS "-Wno-conversion -Wno-sign-conversion")
112 endif()
113
114 add_library_ex(armnnOnnxParser SHARED ${armnn_onnx_parser_sources})
115
116 target_include_directories(armnnOnnxParser PRIVATE src/armnnUtils)
117
118 target_link_libraries(armnnOnnxParser armnn)
119
120 # Protobuf
121 target_link_libraries(armnnOnnxParser ${PROTOBUF_LIBRARIES})
telsoa014fcda012018-03-09 14:13:49 +0000122endif()
123
surmeh01bceff2f2018-03-29 16:29:27 +0100124if(BUILD_TF_PARSER)
125 set(armnn_tf_parser_sources)
126 list(APPEND armnn_tf_parser_sources
127 include/armnnTfParser/ITfParser.hpp
128 src/armnnTfParser/TfParser.hpp
129 src/armnnTfParser/TfParser.cpp
130 ${TF_PROTOBUFS}
131 )
132 # The generated tensorflow protobuf .cc files are not warning clean and we can't fix them.
133 if(COMPILER_IS_GNU_LIKE)
134 set_source_files_properties(${TF_PROTOBUFS} PROPERTIES COMPILE_FLAGS "-Wno-conversion -Wno-sign-conversion")
135 endif()
136
137 add_library_ex(armnnTfParser SHARED ${armnn_tf_parser_sources})
138
139 target_include_directories(armnnTfParser PRIVATE src/armnnUtils)
140
141 target_link_libraries(armnnTfParser armnn)
142
143 # Protobuf (use the specific version tensorflow wants)
144 target_link_libraries(armnnTfParser ${PROTOBUF_LIBRARIES})
145endif()
146
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100147if(BUILD_ARMNN_QUANTIZER AND ARMNNREF)
Jim Flynn3091b062019-02-15 14:45:04 +0000148 if(NOT BUILD_ARMNN_SERIALIZER)
Ruomei Yandb7c3912019-03-08 17:50:25 +0000149 message(ERROR, "In order to build the ArmNN Quantization Tool you must set BUILD_ARMNN_SERIALIZER = YES")
Jim Flynn3091b062019-02-15 14:45:04 +0000150 endif()
151
Nina Drozd59e15b02019-04-25 15:45:20 +0100152 set(armnn_quantizer_sources)
153 list(APPEND armnn_quantizer_sources
154 src/armnnQuantizer/QuantizationDataSet.hpp
155 src/armnnQuantizer/QuantizationDataSet.cpp
156 src/armnnQuantizer/QuantizationInput.hpp
157 src/armnnQuantizer/QuantizationInput.cpp
Jim Flynn3091b062019-02-15 14:45:04 +0000158 src/armnnQuantizer/CommandLineProcessor.hpp
159 src/armnnQuantizer/CommandLineProcessor.cpp
Nina Drozd59e15b02019-04-25 15:45:20 +0100160 )
161
162 add_library_ex(armnnQuantizer SHARED ${armnn_quantizer_sources})
163
164 target_include_directories(armnnQuantizer PRIVATE include/armnnDeserializer)
165 target_include_directories(armnnQuantizer PRIVATE src/armnnUtils)
166 target_include_directories(armnnQuantizer PRIVATE src/armnn)
167
168 include_directories(SYSTEM "${FLATBUFFERS_INCLUDE_PATH}")
169 set_target_properties(armnnQuantizer PROPERTIES LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR})
170
171 target_link_libraries(armnnQuantizer
Guillaume GARDETe315c8f2019-06-05 10:58:47 +0200172 armnn
Nina Drozd59e15b02019-04-25 15:45:20 +0100173 ${Boost_SYSTEM_LIBRARY}
174 ${Boost_PROGRAM_OPTIONS_LIBRARY}
175 ${Boost_FILESYSTEM_LIBRARY}
176 ${Boost_LOG_LIBRARY}
177 ${Boost_THREAD_LIBRARY} )
178
179 add_executable_ex(ArmnnQuantizer
Jim Flynn3091b062019-02-15 14:45:04 +0000180 src/armnnQuantizer/ArmNNQuantizerMain.cpp)
181
Ruomei Yandb7c3912019-03-08 17:50:25 +0000182 target_include_directories(ArmnnQuantizer PRIVATE include/armnnDeserializer)
Nina Drozd59e15b02019-04-25 15:45:20 +0100183 target_include_directories(ArmnnQuantizer PRIVATE src/armnn)
Jim Flynn3091b062019-02-15 14:45:04 +0000184
185 target_link_libraries(ArmnnQuantizer
186 ${Boost_SYSTEM_LIBRARY}
187 ${Boost_PROGRAM_OPTIONS_LIBRARY}
188 ${Boost_FILESYSTEM_LIBRARY}
189 ${Boost_LOG_LIBRARY}
190 ${Boost_THREAD_LIBRARY} )
191
192 target_link_libraries(ArmnnQuantizer
Nina Drozd59e15b02019-04-25 15:45:20 +0100193 armnnQuantizer
Jim Flynn3091b062019-02-15 14:45:04 +0000194 armnnSerializer
195 armnn
Nina Drozd59e15b02019-04-25 15:45:20 +0100196 armnnUtils
Jim Flynn3091b062019-02-15 14:45:04 +0000197 ${FLATBUFFERS_LIBRARY})
198
199 if(Threads_FOUND AND (NOT ("${CMAKE_SYSTEM_NAME}" STREQUAL Android)))
200 target_link_libraries(ArmnnQuantizer pthread)
201 endif()
202
203endif()
204
205
telsoa014fcda012018-03-09 14:13:49 +0000206list(APPEND armnn_sources
207 include/armnn/ArmNN.hpp
Matteo Martincigh6db5f202019-09-05 12:02:04 +0100208 include/armnn/BackendHelper.hpp
David Beck9df2d952018-10-10 15:11:44 +0100209 include/armnn/BackendId.hpp
Matteo Martincigh6db5f202019-09-05 12:02:04 +0100210 include/armnn/Conversion.hpp
211 include/armnn/Deprecated.hpp
telsoa014fcda012018-03-09 14:13:49 +0000212 include/armnn/Descriptors.hpp
213 include/armnn/DescriptorsFwd.hpp
David Beck9df2d952018-10-10 15:11:44 +0100214 include/armnn/Exceptions.hpp
David Becke97c6e02018-10-03 13:09:28 +0100215 include/armnn/ILayerSupport.hpp
jimfly015f4e41f2019-01-23 16:10:17 +0000216 include/armnn/ILayerVisitor.hpp
telsoa014fcda012018-03-09 14:13:49 +0000217 include/armnn/INetwork.hpp
David Beck9df2d952018-10-10 15:11:44 +0100218 include/armnn/IProfiler.hpp
219 include/armnn/IRuntime.hpp
220 include/armnn/LayerSupport.hpp
Mike Kelly8c1701a2019-02-11 17:01:27 +0000221 include/armnn/LayerVisitorBase.hpp
David Beck9df2d952018-10-10 15:11:44 +0100222 include/armnn/LstmParams.hpp
Derek Lambertif674aa02019-08-01 15:56:25 +0100223 include/armnn/MemorySources.hpp
David Beck9df2d952018-10-10 15:11:44 +0100224 include/armnn/NetworkFwd.hpp
David Beck5eec11d2018-10-04 15:43:17 +0100225 include/armnn/Optional.hpp
James Conroyee18dc82019-07-17 11:27:46 +0100226 include/armnn/QuantizedLstmParams.hpp
telsoa014fcda012018-03-09 14:13:49 +0000227 include/armnn/Tensor.hpp
228 include/armnn/TensorFwd.hpp
229 include/armnn/Types.hpp
230 include/armnn/TypesUtils.hpp
231 include/armnn/Utils.hpp
telsoa014fcda012018-03-09 14:13:49 +0000232 include/armnn/Version.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100233 src/armnn/layers/LayerCloneBase.hpp
234 src/armnn/layers/LayerWithParameters.hpp
Kevin May868eb142019-09-04 17:29:31 +0100235 src/armnn/layers/AbsLayer.hpp
236 src/armnn/layers/AbsLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100237 src/armnn/layers/ActivationLayer.hpp
238 src/armnn/layers/ActivationLayer.cpp
239 src/armnn/layers/AdditionLayer.hpp
240 src/armnn/layers/AdditionLayer.cpp
Nikhil Rajee391d52019-09-05 17:50:44 +0100241 src/armnn/layers/ArgMinMaxLayer.hpp
242 src/armnn/layers/ArgMinMaxLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100243 src/armnn/layers/BatchNormalizationLayer.hpp
244 src/armnn/layers/BatchNormalizationLayer.cpp
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +0000245 src/armnn/layers/BatchToSpaceNdLayer.hpp
246 src/armnn/layers/BatchToSpaceNdLayer.cpp
Jim Flynne242f2d2019-05-22 14:24:13 +0100247 src/armnn/layers/ConcatLayer.hpp
248 src/armnn/layers/ConcatLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100249 src/armnn/layers/ConstantLayer.hpp
250 src/armnn/layers/ConstantLayer.cpp
251 src/armnn/layers/Convolution2dLayer.hpp
252 src/armnn/layers/Convolution2dLayer.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100253 src/armnn/layers/ConvertFp16ToFp32Layer.hpp
254 src/armnn/layers/ConvertFp16ToFp32Layer.cpp
255 src/armnn/layers/ConvertFp32ToFp16Layer.hpp
256 src/armnn/layers/ConvertFp32ToFp16Layer.cpp
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000257 src/armnn/layers/DebugLayer.hpp
258 src/armnn/layers/DebugLayer.cpp
Aron Virginas-Tardd6247f2019-09-19 14:31:17 +0100259 src/armnn/layers/DepthToSpaceLayer.hpp
260 src/armnn/layers/DepthToSpaceLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100261 src/armnn/layers/DepthwiseConvolution2dLayer.hpp
262 src/armnn/layers/DepthwiseConvolution2dLayer.cpp
Nattapat Chaimanowonge4294fd2019-03-28 09:56:53 +0000263 src/armnn/layers/DequantizeLayer.hpp
264 src/armnn/layers/DequantizeLayer.cpp
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000265 src/armnn/layers/DetectionPostProcessLayer.hpp
266 src/armnn/layers/DetectionPostProcessLayer.cpp
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000267 src/armnn/layers/ElementwiseBaseLayer.hpp
268 src/armnn/layers/ElementwiseBaseLayer.cpp
FrancisMurtagh20995952018-12-17 12:11:36 +0000269 src/armnn/layers/EqualLayer.hpp
270 src/armnn/layers/EqualLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100271 src/armnn/layers/FakeQuantizationLayer.hpp
272 src/armnn/layers/FakeQuantizationLayer.cpp
273 src/armnn/layers/FloorLayer.hpp
274 src/armnn/layers/FloorLayer.cpp
275 src/armnn/layers/FullyConnectedLayer.hpp
276 src/armnn/layers/FullyConnectedLayer.cpp
narpra01b89b05f2019-01-16 09:53:09 +0000277 src/armnn/layers/GatherLayer.cpp
278 src/armnn/layers/GatherLayer.hpp
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000279 src/armnn/layers/GreaterLayer.cpp
280 src/armnn/layers/GreaterLayer.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100281 src/armnn/layers/InputLayer.hpp
282 src/armnn/layers/InputLayer.cpp
Kevin Mayce5045a2019-10-02 14:07:47 +0100283 src/armnn/layers/InstanceNormalizationLayer.hpp
284 src/armnn/layers/InstanceNormalizationLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100285 src/armnn/layers/L2NormalizationLayer.hpp
286 src/armnn/layers/L2NormalizationLayer.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100287 src/armnn/layers/LstmLayer.cpp
288 src/armnn/layers/LstmLayer.hpp
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000289 src/armnn/layers/MaximumLayer.cpp
290 src/armnn/layers/MaximumLayer.hpp
narpra0132b90462018-09-13 11:07:48 +0100291 src/armnn/layers/MeanLayer.hpp
292 src/armnn/layers/MeanLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100293 src/armnn/layers/MemCopyLayer.hpp
294 src/armnn/layers/MemCopyLayer.cpp
Derek Lambertif674aa02019-08-01 15:56:25 +0100295 src/armnn/layers/MemImportLayer.hpp
296 src/armnn/layers/MemImportLayer.cpp
Nattapat Chaimanowong1f886302019-04-05 13:37:19 +0100297 src/armnn/layers/MergeLayer.hpp
298 src/armnn/layers/MergeLayer.cpp
kevmay0190539692018-11-29 08:40:19 +0000299 src/armnn/layers/MinimumLayer.cpp
300 src/armnn/layers/MinimumLayer.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100301 src/armnn/layers/MultiplicationLayer.hpp
302 src/armnn/layers/MultiplicationLayer.cpp
303 src/armnn/layers/NormalizationLayer.hpp
304 src/armnn/layers/NormalizationLayer.cpp
305 src/armnn/layers/OutputLayer.hpp
306 src/armnn/layers/OutputLayer.cpp
Mohamed Nour Abouelseoud5662c202018-09-24 13:30:09 +0100307 src/armnn/layers/PadLayer.hpp
308 src/armnn/layers/PadLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100309 src/armnn/layers/PermuteLayer.hpp
310 src/armnn/layers/PermuteLayer.cpp
311 src/armnn/layers/Pooling2dLayer.hpp
312 src/armnn/layers/Pooling2dLayer.cpp
Derek Lambertia9cca6a2019-03-25 15:41:58 +0000313 src/armnn/layers/QuantizeLayer.cpp
314 src/armnn/layers/QuantizeLayer.hpp
James Conroyee18dc82019-07-17 11:27:46 +0100315 src/armnn/layers/QuantizedLstmLayer.hpp
316 src/armnn/layers/QuantizedLstmLayer.cpp
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100317 src/armnn/layers/DivisionLayer.cpp
318 src/armnn/layers/DivisionLayer.hpp
Matteo Martincigh49124022019-01-11 13:25:59 +0000319 src/armnn/layers/PreCompiledLayer.hpp
320 src/armnn/layers/PreCompiledLayer.cpp
Matteo Martincigh0e406ee2019-06-12 15:42:18 +0100321 src/armnn/layers/PreluLayer.hpp
322 src/armnn/layers/PreluLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100323 src/armnn/layers/ReshapeLayer.hpp
324 src/armnn/layers/ReshapeLayer.cpp
Teresa Charlina9075df2019-06-27 15:41:57 +0100325 src/armnn/layers/ResizeLayer.hpp
326 src/armnn/layers/ResizeLayer.cpp
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000327 src/armnn/layers/RsqrtLayer.cpp
328 src/armnn/layers/RsqrtLayer.hpp
Aron Virginas-Tar636ab402019-09-16 14:27:45 +0100329 src/armnn/layers/SliceLayer.cpp
330 src/armnn/layers/SliceLayer.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100331 src/armnn/layers/SoftmaxLayer.hpp
332 src/armnn/layers/SoftmaxLayer.cpp
Matteo Martincigh0e406ee2019-06-12 15:42:18 +0100333 src/armnn/layers/SpaceToBatchNdLayer.hpp
334 src/armnn/layers/SpaceToBatchNdLayer.cpp
335 src/armnn/layers/SpaceToDepthLayer.hpp
336 src/armnn/layers/SpaceToDepthLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100337 src/armnn/layers/SplitterLayer.hpp
338 src/armnn/layers/SplitterLayer.cpp
Matthew Jackson2b8c1da2019-07-04 14:59:16 +0100339 src/armnn/layers/StackLayer.hpp
340 src/armnn/layers/StackLayer.cpp
Conor Kennedy430b5d82018-11-14 15:28:28 +0000341 src/armnn/layers/StridedSliceLayer.cpp
342 src/armnn/layers/StridedSliceLayer.hpp
David Beckc2044fe2018-09-05 15:00:38 +0100343 src/armnn/layers/SubtractionLayer.cpp
344 src/armnn/layers/SubtractionLayer.hpp
Sadik Armaganeff363d2019-04-05 15:25:46 +0100345 src/armnn/layers/SwitchLayer.cpp
346 src/armnn/layers/SwitchLayer.hpp
Aron Virginas-Tar639fb042019-06-20 14:28:19 +0100347 src/armnn/layers/TransposeConvolution2dLayer.cpp
348 src/armnn/layers/TransposeConvolution2dLayer.hpp
Matteo Martincigh49124022019-01-11 13:25:59 +0000349 src/armnn/BackendSettings.hpp
Ferran Balaguerf54c9462019-07-10 12:43:58 +0100350 src/armnn/BackendHelper.cpp
Nattapat Chaimanowong649dd952019-01-22 16:10:44 +0000351 src/armnn/CompatibleTypes.hpp
telsoa014fcda012018-03-09 14:13:49 +0000352 src/armnn/Descriptors.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100353 src/armnn/DeviceSpec.hpp
Jim Flynnf92dfce2019-05-02 11:33:25 +0100354 src/armnn/DynamicQuantizationVisitor.cpp
355 src/armnn/DynamicQuantizationVisitor.hpp
telsoa014fcda012018-03-09 14:13:49 +0000356 src/armnn/Exceptions.cpp
Teresa Charlin4de9f672019-04-10 13:59:49 +0100357 src/armnn/ExecutionFrame.cpp
358 src/armnn/ExecutionFrame.hpp
telsoa014fcda012018-03-09 14:13:49 +0000359 src/armnn/Graph.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100360 src/armnn/Graph.hpp
361 src/armnn/IGraphObservable.hpp
362 src/armnn/Instrument.hpp
363 src/armnn/InternalTypes.cpp
364 src/armnn/InternalTypes.hpp
Derek Lambertiff05cc52019-04-26 13:05:17 +0100365 src/armnn/ISubgraphViewConverter.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100366 src/armnn/JsonPrinter.cpp
367 src/armnn/JsonPrinter.hpp
368 src/armnn/Layer.cpp
369 src/armnn/LayerFwd.hpp
370 src/armnn/Layer.hpp
371 src/armnn/LayersFwd.hpp
372 src/armnn/LayerSupportCommon.hpp
373 src/armnn/LayerSupport.cpp
374 src/armnn/LoadedNetwork.cpp
375 src/armnn/LoadedNetwork.hpp
telsoa014fcda012018-03-09 14:13:49 +0000376 src/armnn/Network.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100377 src/armnn/Network.hpp
Nattapat Chaimanowong7ac07f32019-03-20 11:51:14 +0000378 src/armnn/NetworkQuantizationScheme.hpp
Derek Lamberti27d83072019-02-05 16:00:08 +0000379 src/armnn/NetworkQuantizer.cpp
380 src/armnn/NetworkQuantizer.hpp
Matteo Martincigha8d572d2019-02-07 17:51:09 +0000381 src/armnn/NetworkQuantizerUtils.cpp
382 src/armnn/NetworkQuantizerUtils.hpp
Aron Virginas-Tar5fdfe822018-11-21 13:14:42 +0000383 src/armnn/NetworkUtils.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100384 src/armnn/NetworkUtils.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100385 src/armnn/Observable.cpp
386 src/armnn/Observable.hpp
387 src/armnn/Optimizer.cpp
388 src/armnn/Optimizer.hpp
Matteo Martincigha8d572d2019-02-07 17:51:09 +0000389 src/armnn/OverrideInputRangeVisitor.cpp
390 src/armnn/OverrideInputRangeVisitor.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100391 src/armnn/Profiling.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100392 src/armnn/ProfilingEvent.cpp
393 src/armnn/ProfilingEvent.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100394 src/armnn/Profiling.hpp
Derek Lamberti27d83072019-02-05 16:00:08 +0000395 src/armnn/QuantizerVisitor.cpp
396 src/armnn/QuantizerVisitor.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100397 src/armnn/Runtime.cpp
398 src/armnn/Runtime.hpp
Derek Lamberti8a4ca102019-02-08 17:54:20 +0000399 src/armnn/RangeTracker.cpp
400 src/armnn/RangeTracker.hpp
Aron Virginas-Tard4f0fea2019-04-09 14:08:06 +0100401 src/armnn/ResolveType.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100402 src/armnn/SerializeLayerParameters.cpp
403 src/armnn/SerializeLayerParameters.hpp
Derek Lamberti27d83072019-02-05 16:00:08 +0000404 src/armnn/StaticRangeVisitor.cpp
405 src/armnn/StaticRangeVisitor.hpp
Derek Lambertiff05cc52019-04-26 13:05:17 +0100406 src/armnn/SubgraphView.cpp
407 src/armnn/SubgraphView.hpp
408 src/armnn/SubgraphViewSelector.cpp
409 src/armnn/SubgraphViewSelector.hpp
telsoa014fcda012018-03-09 14:13:49 +0000410 src/armnn/Tensor.cpp
Aron Virginas-Tard4f0fea2019-04-09 14:08:06 +0100411 src/armnn/TypesUtils.cpp
telsoa014fcda012018-03-09 14:13:49 +0000412 src/armnn/Utils.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100413 src/armnn/WallClockTimer.cpp
414 src/armnn/WallClockTimer.hpp
Nina Drozd861985f2019-04-18 14:48:51 +0100415 src/armnn/optimizations/AddDebug.hpp
telsoa014fcda012018-03-09 14:13:49 +0000416 src/armnn/optimizations/All.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100417 src/armnn/optimizations/ConvertConstants.hpp
Nina Drozd861985f2019-04-18 14:48:51 +0100418 src/armnn/optimizations/ConvertFp32NetworkToFp16.hpp
419 src/armnn/optimizations/FoldPadIntoConvolution2d.hpp
telsoa014fcda012018-03-09 14:13:49 +0000420 src/armnn/optimizations/MovePermuteUp.hpp
421 src/armnn/optimizations/Optimization.hpp
422 src/armnn/optimizations/OptimizeConsecutiveReshapes.hpp
Nina Drozd861985f2019-04-18 14:48:51 +0100423 src/armnn/optimizations/OptimizeInverseConversions.hpp
telsoa014fcda012018-03-09 14:13:49 +0000424 src/armnn/optimizations/OptimizeInversePermutes.hpp
Rob Hughes3a7d3a72019-09-24 16:59:56 +0100425 src/armnn/optimizations/PermuteAndBatchToSpaceAsDepthToSpace.hpp
426 src/armnn/optimizations/PermuteAndBatchToSpaceAsDepthToSpace.cpp
telsoa014fcda012018-03-09 14:13:49 +0000427 src/armnn/optimizations/PermuteAsReshape.hpp
428 src/armnn/optimizations/SquashEqualSiblings.hpp
Narumol Prangnawarat7be47ef2019-09-27 18:00:11 +0100429 src/profiling/BufferManager.cpp
430 src/profiling/BufferManager.hpp
Matteo Martincigh8a837172019-10-04 17:01:07 +0100431 src/profiling/CommandHandler.cpp
432 src/profiling/CommandHandler.hpp
Francis Murtagh11f99b42019-08-16 11:28:52 +0100433 src/profiling/CommandHandlerFunctor.cpp
434 src/profiling/CommandHandlerFunctor.hpp
Francis Murtagh1f7db452019-08-14 09:49:34 +0100435 src/profiling/CommandHandlerKey.cpp
436 src/profiling/CommandHandlerKey.hpp
Francis Murtagh94d79152019-08-16 17:45:07 +0100437 src/profiling/CommandHandlerRegistry.cpp
438 src/profiling/CommandHandlerRegistry.hpp
Sadik Armaganb5f01b22019-09-18 17:29:00 +0100439 src/profiling/ConnectionAcknowledgedCommandHandler.cpp
440 src/profiling/ConnectionAcknowledgedCommandHandler.hpp
Aron Virginas-Tar4e5fc1f2019-08-22 18:10:52 +0100441 src/profiling/CounterDirectory.cpp
442 src/profiling/CounterDirectory.hpp
Nikhil Rajd88e47c2019-08-19 10:04:23 +0100443 src/profiling/EncodeVersion.hpp
Francis Murtagh68f78d82019-09-04 16:42:29 +0100444 src/profiling/Holder.cpp
445 src/profiling/Holder.hpp
Narumol Prangnawarat404b2752019-09-24 17:23:16 +0100446 src/profiling/IBufferManager.hpp
Matteo Martincigh6db5f202019-09-05 12:02:04 +0100447 src/profiling/ICounterDirectory.hpp
Matteo Martincighe0e6efc2019-10-04 17:17:42 +0100448 src/profiling/ICounterValues.hpp
Matteo Martincigh6db5f202019-09-05 12:02:04 +0100449 src/profiling/ISendCounterPacket.hpp
Narumol Prangnawarat404b2752019-09-24 17:23:16 +0100450 src/profiling/IPacketBuffer.hpp
Matteo Martincigh6db5f202019-09-05 12:02:04 +0100451 src/profiling/IPeriodicCounterCapture.hpp
Aron Virginas-Tar1a0f6912019-08-23 15:18:44 +0100452 src/profiling/IProfilingConnection.hpp
Matteo Martincigh54fb9572019-10-02 12:50:57 +0100453 src/profiling/IProfilingConnectionFactory.hpp
Nikhil Rajbc626052019-08-15 15:49:45 +0100454 src/profiling/Packet.hpp
Narumol Prangnawarat7be47ef2019-09-27 18:00:11 +0100455 src/profiling/PacketBuffer.cpp
456 src/profiling/PacketBuffer.hpp
Aron Virginas-Tare898db92019-08-22 12:56:34 +0100457 src/profiling/PacketVersionResolver.cpp
458 src/profiling/PacketVersionResolver.hpp
Francis Murtaghfcb8ef62019-09-20 15:40:09 +0100459 src/profiling/PeriodicCounterCapture.hpp
460 src/profiling/PeriodicCounterCapture.cpp
Ferran Balaguer1b941722019-08-28 16:57:18 +0100461 src/profiling/PeriodicCounterSelectionCommandHandler.cpp
462 src/profiling/PeriodicCounterSelectionCommandHandler.hpp
Aron Virginas-Tardfa14772019-09-24 18:24:47 +0100463 src/profiling/ProfilingConnectionDumpToFileDecorator.cpp
464 src/profiling/ProfilingConnectionDumpToFileDecorator.hpp
Matteo Martincigh6db5f202019-09-05 12:02:04 +0100465 src/profiling/ProfilingConnectionFactory.cpp
466 src/profiling/ProfilingConnectionFactory.hpp
467 src/profiling/ProfilingService.cpp
468 src/profiling/ProfilingService.hpp
469 src/profiling/ProfilingStateMachine.cpp
470 src/profiling/ProfilingStateMachine.hpp
471 src/profiling/ProfilingUtils.cpp
472 src/profiling/ProfilingUtils.hpp
Narumol Prangnawarat48033692019-09-20 12:04:55 +0100473 src/profiling/RequestCounterDirectoryCommandHandler.cpp
474 src/profiling/RequestCounterDirectoryCommandHandler.hpp
Matteo Martincigh6db5f202019-09-05 12:02:04 +0100475 src/profiling/SendCounterPacket.cpp
476 src/profiling/SendCounterPacket.hpp
477 src/profiling/SocketProfilingConnection.cpp
478 src/profiling/SocketProfilingConnection.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100479 third-party/half/half.hpp
telsoa014fcda012018-03-09 14:13:49 +0000480 )
481
telsoa014fcda012018-03-09 14:13:49 +0000482# Files used for Streamline-based profiling backend
483if(PROFILING_BACKEND_STREAMLINE)
484 list(APPEND armnn_sources
485 ${GATOR_ROOT}/annotate/streamline_annotate.h
486 ${GATOR_ROOT}/annotate/streamline_annotate.c)
487endif()
488
David Beck10b4dfd2018-09-19 12:03:20 +0100489# the backends under src/backends extend the list of
David Beck3cc9a622018-10-12 10:38:31 +0100490# object libs armnn to include in the build
David Beck10b4dfd2018-09-19 12:03:20 +0100491include(src/backends/backends.cmake)
David Beck3cc9a622018-10-12 10:38:31 +0100492foreach(lib ${armnnLibraries})
493 message("Adding object library dependency to armnn: ${lib}")
494 list(APPEND armnn_sources $<TARGET_OBJECTS:${lib}>)
495endforeach()
496
497add_library_ex(armnn SHARED ${armnn_sources})
David Beck10b4dfd2018-09-19 12:03:20 +0100498
telsoa014fcda012018-03-09 14:13:49 +0000499target_include_directories(armnn PRIVATE src/armnn)
500target_include_directories(armnn PRIVATE src/armnnUtils)
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +0000501target_include_directories(armnn PRIVATE src/backends)
Matteo Martincigh6db5f202019-09-05 12:02:04 +0100502target_include_directories(armnn PRIVATE src/profiling)
David Beck3cc9a622018-10-12 10:38:31 +0100503
504target_link_libraries(armnn armnnUtils)
505
telsoa014fcda012018-03-09 14:13:49 +0000506target_link_libraries(armnn ${CMAKE_DL_LIBS})
507
Matthew Benthama7b79282019-06-03 13:00:50 +0100508install(TARGETS armnn
Rob Hughes91e1d892019-08-23 10:11:58 +0100509 LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
510 RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
telsoa014fcda012018-03-09 14:13:49 +0000511if(BUILD_CAFFE_PARSER)
Matthew Benthama7b79282019-06-03 13:00:50 +0100512 install(TARGETS armnnCaffeParser
Rob Hughes91e1d892019-08-23 10:11:58 +0100513 LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
514 RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
telsoa014fcda012018-03-09 14:13:49 +0000515endif()
telsoa01c577f2c2018-08-31 09:22:23 +0100516if(BUILD_ONNX_PARSER)
Matthew Benthama7b79282019-06-03 13:00:50 +0100517 install(TARGETS armnnOnnxParser
Rob Hughes91e1d892019-08-23 10:11:58 +0100518 LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
519 RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
telsoa01c577f2c2018-08-31 09:22:23 +0100520endif()
surmeh01bceff2f2018-03-29 16:29:27 +0100521if(BUILD_TF_PARSER)
Matthew Benthama7b79282019-06-03 13:00:50 +0100522 install(TARGETS armnnTfParser
Rob Hughes91e1d892019-08-23 10:11:58 +0100523 LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
524 RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
surmeh01bceff2f2018-03-29 16:29:27 +0100525endif()
Ruomei Yandb7c3912019-03-08 17:50:25 +0000526
Matthew Benthama7b79282019-06-03 13:00:50 +0100527install(DIRECTORY include/ DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
telsoa014fcda012018-03-09 14:13:49 +0000528
Matteo Martincighe7d44982019-08-05 12:16:47 +0100529target_link_libraries(armnn ${Boost_LOG_LIBRARY} ${Boost_THREAD_LIBRARY}
530 ${Boost_SYSTEM_LIBRARY} ${Boost_FILESYSTEM_LIBRARY})
telsoa014fcda012018-03-09 14:13:49 +0000531
532if(ARMCOMPUTENEON OR ARMCOMPUTECL)
533 target_link_libraries(armnn ${ARMCOMPUTE_LIBRARIES})
534endif()
535if(ARMCOMPUTECL)
536 target_link_libraries(armnn ${OPENCL_LIBRARIES})
537endif()
538
539if(PROFILING_BACKEND_STREAMLINE)
540 target_link_libraries(armnn pthread)
541endif()
542
telsoa014fcda012018-03-09 14:13:49 +0000543if(BUILD_UNIT_TESTS)
544 set(unittest_sources)
545 list(APPEND unittest_sources
jimfly01aebf2e72019-02-05 09:20:11 +0000546 src/armnn/test/ConstTensorLayerVisitor.hpp
547 src/armnn/test/ConstTensorLayerVisitor.cpp
telsoa014fcda012018-03-09 14:13:49 +0000548 src/armnn/test/CreateWorkload.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100549 src/armnn/test/CsvReaderTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100550 src/armnn/test/EndToEndTest.cpp
Teresa Charlin4de9f672019-04-10 13:59:49 +0100551 src/armnn/test/ExecutionFrameTest.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100552 src/armnn/test/FloatingPointConverterTest.cpp
Matthew Benthamd78b891d2019-04-30 10:17:40 +0100553 src/armnn/test/FlowControl.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100554 src/armnn/test/GraphTests.cpp
narpra016f37f832018-12-21 18:30:00 +0000555 src/armnn/test/GraphUtils.cpp
telsoa014fcda012018-03-09 14:13:49 +0000556 src/armnn/test/GraphUtils.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100557 src/armnn/test/InstrumentTests.cpp
Matteo Martincighbf0e7222019-06-20 17:17:45 +0100558 src/armnn/test/InferOutputTests.cpp
559 src/armnn/test/InferOutputTests.hpp
Éanna Ó Catháina4247d52019-05-08 14:00:45 +0100560 src/armnn/test/ModelAccuracyCheckerTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100561 src/armnn/test/NetworkTests.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100562 src/armnn/test/ObservableTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100563 src/armnn/test/OptimizerTests.cpp
Rob Hughes95e73d72019-09-24 09:34:53 +0100564 src/armnn/test/optimizations/ConvertConstantsFloatToHalfTests.cpp
565 src/armnn/test/optimizations/ConvertConstantsHalfToFloatTests.cpp
566 src/armnn/test/optimizations/Fp32NetworkToFp16ConverterTests.cpp
567 src/armnn/test/optimizations/InsertDebugLayerTests.cpp
568 src/armnn/test/optimizations/MovePermuteUpTests.cpp
569 src/armnn/test/optimizations/OptimizeConsecutiveReshapesTests.cpp
570 src/armnn/test/optimizations/OptimizeInverseConversionsTests.cpp
571 src/armnn/test/optimizations/OptimizeInversePermutesTests.cpp
Rob Hughes3a7d3a72019-09-24 16:59:56 +0100572 src/armnn/test/optimizations/PermuteAndBatchToSpaceAsDepthToSpaceTests.cpp
Rob Hughes95e73d72019-09-24 09:34:53 +0100573 src/armnn/test/optimizations/PermuteAsReshapeTests.cpp
574 src/armnn/test/optimizations/SquashEqualSiblingsTests.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100575 src/armnn/test/OptionalTest.cpp
576 src/armnn/test/ProfilerTests.cpp
577 src/armnn/test/ProfilingEventTest.cpp
Derek Lambertiff05cc52019-04-26 13:05:17 +0100578 src/armnn/test/SubgraphViewTests.cpp
Derek Lamberti84da38b2019-06-13 11:40:08 +0100579 src/armnn/test/TensorHandleStrategyTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100580 src/armnn/test/TensorHelpers.hpp
581 src/armnn/test/TensorTest.cpp
FrancisMurtagh531ef942019-02-01 11:48:58 +0000582 src/armnn/test/TestInputOutputLayerVisitor.cpp
583 src/armnn/test/TestInputOutputLayerVisitor.hpp
FrancisMurtagh1306b192019-01-28 14:03:21 +0000584 src/armnn/test/TestLayerVisitor.cpp
585 src/armnn/test/TestLayerVisitor.hpp
FrancisMurtagh28d3d632019-01-29 12:15:23 +0000586 src/armnn/test/TestNameOnlyLayerVisitor.cpp
587 src/armnn/test/TestNameOnlyLayerVisitor.hpp
FrancisMurtaghf08876f2019-02-04 15:41:17 +0000588 src/armnn/test/TestNameAndDescriptorLayerVisitor.hpp
589 src/armnn/test/TestNameAndDescriptorLayerVisitor.cpp
Matteo Martincighbf0e7222019-06-20 17:17:45 +0100590 src/armnn/test/TestUtils.cpp
591 src/armnn/test/TestUtils.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100592 src/armnn/test/UnitTests.cpp
593 src/armnn/test/UnitTests.hpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000594 src/armnn/test/UtilsTests.cpp
Matthew Bentham4057d912019-01-21 15:45:51 +0000595 src/armnnUtils/test/PrototxtConversionsTest.cpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000596 src/armnnUtils/test/ParserHelperTest.cpp
Narumol Prangnawarat02807852019-09-11 16:43:09 +0100597 src/armnnUtils/test/TensorUtilsTest.cpp
Narumol Prangnawarat7be47ef2019-09-27 18:00:11 +0100598 src/profiling/test/BufferTests.cpp
Aron Virginas-Tardfa14772019-09-24 18:24:47 +0100599 src/profiling/test/ProfilingConnectionDumpToFileDecoratorTests.cpp
Francis Murtagh1f7db452019-08-14 09:49:34 +0100600 src/profiling/test/ProfilingTests.cpp
Matteo Martincighd0613b52019-10-09 16:47:04 +0100601 src/profiling/test/ProfilingTests.hpp
Ferran Balagueraf5c46b2019-08-30 15:49:15 +0100602 src/profiling/test/SendCounterPacketTests.cpp
Matteo Martincighd0613b52019-10-09 16:47:04 +0100603 src/profiling/test/SendCounterPacketTests.hpp
Matteo Martincigh0aed4f92019-10-01 14:25:34 +0100604 src/profiling/test/TimelinePacketTests.cpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000605 )
telsoa014fcda012018-03-09 14:13:49 +0000606
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100607 if(ARMNNREF)
Matteo Martincighe67edb22019-08-14 14:05:46 +0100608 list(APPEND unittest_sources
609 src/armnn/test/DebugCallbackTest.cpp
610 src/armnn/test/QuantizerTest.cpp
611 src/armnn/test/RuntimeTests.cpp
612 src/armnn/test/RuntimeTests.hpp
613 )
614 endif()
615
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100616 if(BUILD_TF_PARSER AND ARMNNREF)
surmeh01bceff2f2018-03-29 16:29:27 +0100617 list(APPEND unittest_sources
618 src/armnnTfParser/test/Activations.cpp
619 src/armnnTfParser/test/Addition.cpp
Ferran Balaguerfbdad032018-12-28 18:15:24 +0000620 src/armnnTfParser/test/AddN.cpp
narpra016f37f832018-12-21 18:30:00 +0000621 src/armnnTfParser/test/Assert.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100622 src/armnnTfParser/test/BiasAdd.cpp
623 src/armnnTfParser/test/BroadcastForAdd.cpp
624 src/armnnTfParser/test/Convolution2d.cpp
625 src/armnnTfParser/test/Concat.cpp
626 src/armnnTfParser/test/ConcatOfConcats.cpp
627 src/armnnTfParser/test/DepthwiseConvolution2d.cpp
jimfly0184c70e62018-12-19 13:14:46 +0000628 src/armnnTfParser/test/Equal.cpp
Conor Kennedyc2130a02018-12-05 11:05:54 +0000629 src/armnnTfParser/test/ExpandDims.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100630 src/armnnTfParser/test/FusedBatchNorm.cpp
FrancisMurtagh94412af2019-01-24 10:53:39 +0000631 src/armnnTfParser/test/Gather.cpp
jimfly01a06bf312018-12-18 16:24:51 +0000632 src/armnnTfParser/test/Greater.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100633 src/armnnTfParser/test/Identity.cpp
634 src/armnnTfParser/test/LocalResponseNormalization.cpp
Sadik Armagan975c09a2018-12-04 10:02:08 +0000635 src/armnnTfParser/test/Maximum.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100636 src/armnnTfParser/test/MaximumForLeakyRelu.cpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000637 src/armnnTfParser/test/Mean.cpp
Nattapat Chaimanowong24df8222018-12-04 13:47:02 +0000638 src/armnnTfParser/test/Minimum.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100639 src/armnnTfParser/test/Multiplication.cpp
jimfly01f6ba7472018-12-04 10:09:52 +0000640 src/armnnTfParser/test/Pad.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100641 src/armnnTfParser/test/MultiOutput.cpp
642 src/armnnTfParser/test/PassThru.cpp
643 src/armnnTfParser/test/Pooling.cpp
saoste01bbd40612018-08-28 15:41:51 +0100644 src/armnnTfParser/test/RealDiv.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100645 src/armnnTfParser/test/Reshape.cpp
646 src/armnnTfParser/test/ResizeBilinear.cpp
Mohamed Nour Abouelseoud7a8892f2019-01-09 14:19:58 +0000647 src/armnnTfParser/test/Rsqrt.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100648 src/armnnTfParser/test/Shape.cpp
649 src/armnnTfParser/test/Softmax.cpp
650 src/armnnTfParser/test/TestDependencies.cpp
651 src/armnnTfParser/test/FullyConnected.cpp
652 src/armnnTfParser/test/Constant.cpp
653 src/armnnTfParser/test/TestMultiInputsOutputs.cpp
Sadik Armagan2ad6cb42018-12-27 11:23:44 +0000654 src/armnnTfParser/test/Split.cpp
jimfly0123be07e2018-12-04 17:47:22 +0000655 src/armnnTfParser/test/Squeeze.cpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000656 src/armnnTfParser/test/Sub.cpp
657 )
Matteo Martincighe67edb22019-08-14 14:05:46 +0100658
surmeh01bceff2f2018-03-29 16:29:27 +0100659 endif()
660
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100661 if(BUILD_TF_LITE_PARSER AND ARMNNREF)
Matthew Bentham6c8e8e72019-01-15 17:57:00 +0000662 enable_language(ASM)
telsoa01c577f2c2018-08-31 09:22:23 +0100663 list(APPEND unittest_sources
Sadik Armagan479045b2018-10-01 11:51:37 +0100664 src/armnnTfLiteParser/test/Activations.cpp
Bruno Goncalvesd4ac6a42018-12-18 12:56:22 -0200665 src/armnnTfLiteParser/test/Addition.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100666 src/armnnTfLiteParser/test/AvgPool2D.cpp
Bruno Goncalvesdb947e22019-02-08 18:52:21 -0200667 src/armnnTfLiteParser/test/BatchToSpaceND.cpp
Sadik Armagan479045b2018-10-01 11:51:37 +0100668 src/armnnTfLiteParser/test/Concatenation.cpp
Bruno Goncalves3d7efe92018-12-27 14:21:43 -0200669 src/armnnTfLiteParser/test/Constant.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100670 src/armnnTfLiteParser/test/Conv2D.cpp
671 src/armnnTfLiteParser/test/DepthwiseConvolution2D.cpp
keidav011b3e2ea2019-02-21 10:07:37 +0000672 src/armnnTfLiteParser/test/DetectionPostProcess.cpp
Sadik Armagan8853c1f2018-10-22 09:04:18 +0100673 src/armnnTfLiteParser/test/FullyConnected.cpp
Matthew Jackson28c94572019-07-18 10:47:03 +0100674 src/armnnTfLiteParser/test/L2Normalization.cpp
Bruno Goncalvesb8d805e2019-02-12 22:57:13 -0200675 src/armnnTfLiteParser/test/Maximum.cpp
Nattapat Chaimanowongb66504b2018-10-17 15:19:14 +0100676 src/armnnTfLiteParser/test/MaxPool2D.cpp
Bruno Goncalves2235cee2018-12-19 12:51:45 -0200677 src/armnnTfLiteParser/test/Mean.cpp
Bruno Goncalves8f6d7a72019-02-12 22:58:18 -0200678 src/armnnTfLiteParser/test/Minimum.cpp
Bruno Goncalvesf803f782018-12-18 13:40:30 -0200679 src/armnnTfLiteParser/test/Multiplication.cpp
Matthew Jacksonbcca1f42019-07-16 11:39:21 +0100680 src/armnnTfLiteParser/test/Pack.cpp
Bruno Goncalves6c2355b2018-12-19 12:52:01 -0200681 src/armnnTfLiteParser/test/Pad.cpp
Sadik Armagan479045b2018-10-01 11:51:37 +0100682 src/armnnTfLiteParser/test/Reshape.cpp
Bruno Goncalves3f58ddb2019-02-07 18:40:11 -0200683 src/armnnTfLiteParser/test/ResizeBilinear.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100684 src/armnnTfLiteParser/test/Softmax.cpp
Bruno Goncalvesbaded142019-02-08 19:02:48 -0200685 src/armnnTfLiteParser/test/SpaceToBatchND.cpp
Nina Drozd0324f482019-04-08 10:52:10 +0100686 src/armnnTfLiteParser/test/Split.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100687 src/armnnTfLiteParser/test/Squeeze.cpp
Bruno Goncalves451d95b2019-02-12 22:59:22 -0200688 src/armnnTfLiteParser/test/StridedSlice.cpp
Nina Drozd0324f482019-04-08 10:52:10 +0100689 src/armnnTfLiteParser/test/Sub.cpp
Matthew Jackson74bf7da2019-08-16 16:51:42 +0100690 src/armnnTfLiteParser/test/TransposeConv.cpp
Keith Davis4cd29a02019-09-09 14:49:20 +0100691 src/armnnTfLiteParser/test/Transpose.cpp
Nina Drozd200e3802019-04-15 09:47:39 +0100692 src/armnnTfLiteParser/test/Unpack.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100693 src/armnnTfLiteParser/test/LoadModel.cpp
694 src/armnnTfLiteParser/test/GetBuffer.cpp
695 src/armnnTfLiteParser/test/OutputShapeOfSqueeze.cpp
696 src/armnnTfLiteParser/test/InputOutputTensorNames.cpp
697 src/armnnTfLiteParser/test/GetTensorIds.cpp
698 src/armnnTfLiteParser/test/GetSubgraphInputsOutputs.cpp
699 src/armnnTfLiteParser/test/GetInputsOutputs.cpp
Matthew Bentham6c8e8e72019-01-15 17:57:00 +0000700 src/armnnTfLiteParser/test/Schema.s
telsoa01c577f2c2018-08-31 09:22:23 +0100701 )
Matthew Bentham6c8e8e72019-01-15 17:57:00 +0000702 set_source_files_properties(src/armnnTfLiteParser/test/Schema.s PROPERTIES COMPILE_FLAGS "-x assembler-with-cpp")
Matteo Martincighe67edb22019-08-14 14:05:46 +0100703
telsoa01c577f2c2018-08-31 09:22:23 +0100704 endif()
705
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100706 if(BUILD_CAFFE_PARSER AND ARMNNREF)
telsoa014fcda012018-03-09 14:13:49 +0000707 list(APPEND unittest_sources
708 src/armnnCaffeParser/test/TestAdd.cpp
709 src/armnnCaffeParser/test/TestConcat.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100710 src/armnnCaffeParser/test/TestConvolution.cpp
telsoa014fcda012018-03-09 14:13:49 +0000711 src/armnnCaffeParser/test/TestDropout.cpp
712 src/armnnCaffeParser/test/TestInputs.cpp
713 src/armnnCaffeParser/test/TestMul.cpp
714 src/armnnCaffeParser/test/TestPooling2d.cpp
715 src/armnnCaffeParser/test/TestInPlace.cpp
716 src/armnnCaffeParser/test/TestMultiInputsOutputs.cpp
717 src/armnnCaffeParser/test/TestSplit.cpp
718 )
719 endif()
720
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100721 if(BUILD_ONNX_PARSER AND ARMNNREF)
Matteo Martincighe67edb22019-08-14 14:05:46 +0100722 list(APPEND unittest_sources
723 src/armnnOnnxParser/test/Constructor.cpp
724 src/armnnOnnxParser/test/CreateNetwork.cpp
725 src/armnnOnnxParser/test/ProtoxtFixture.cpp
726 src/armnnOnnxParser/test/Const.cpp
727 src/armnnOnnxParser/test/Pooling.cpp
728 src/armnnOnnxParser/test/Reshape.cpp
729 src/armnnOnnxParser/test/Relu.cpp
730 src/armnnOnnxParser/test/Conv2D.cpp
731 src/armnnOnnxParser/test/Addition.cpp
732 src/armnnOnnxParser/test/FullyConnected.cpp
733 src/armnnOnnxParser/test/GetInputsOutputs.cpp
734 src/armnnOnnxParser/test/BatchNorm.cpp
735 src/armnnOnnxParser/test/DepthConv.cpp
736 )
737 endif()
738
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100739 if(BUILD_ARMNN_QUANTIZER AND ARMNNREF)
Nina Drozd59e15b02019-04-25 15:45:20 +0100740 list(APPEND unittest_sources
741 src/armnnQuantizer/test/QuantizationDataSetTests.cpp
742 )
743 endif()
744
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100745 if(BUILD_ARMNN_SERIALIZER AND ARMNNREF)
Kevin May43a799c2019-02-08 16:31:42 +0000746 enable_language(ASM)
747 list(APPEND unittest_sources
Ruomei Yandb7c3912019-03-08 17:50:25 +0000748 src/armnnSerializer/test/ActivationSerializationTests.cpp
749 src/armnnSerializer/test/SerializerTests.cpp
FinnWilliamsArm4ffcc8f2019-09-05 14:34:20 +0100750 src/armnnDeserializer/test/DeserializeAbs.cpp
Ruomei Yandb7c3912019-03-08 17:50:25 +0000751 src/armnnDeserializer/test/DeserializeActivation.cpp
752 src/armnnDeserializer/test/DeserializeAdd.cpp
753 src/armnnDeserializer/test/DeserializeBatchToSpaceNd.cpp
754 src/armnnDeserializer/test/DeserializeBatchNormalization.cpp
755 src/armnnDeserializer/test/DeserializeConstant.cpp
756 src/armnnDeserializer/test/DeserializeConvolution2d.cpp
Aron Virginas-Tar11b2eca2019-09-24 11:01:51 +0100757 src/armnnDeserializer/test/DeserializeDepthToSpace.cpp
Ruomei Yandb7c3912019-03-08 17:50:25 +0000758 src/armnnDeserializer/test/DeserializeDivision.cpp
759 src/armnnDeserializer/test/DeserializeEqual.cpp
760 src/armnnDeserializer/test/DeserializeFloor.cpp
761 src/armnnDeserializer/test/DeserializeFullyConnected.cpp
762 src/armnnDeserializer/test/DeserializeGather.cpp
763 src/armnnDeserializer/test/DeserializeGreater.cpp
Aron Virginas-Tar92bbcae2019-10-09 10:36:34 +0100764 src/armnnDeserializer/test/DeserializeInstanceNormalization.cpp
Ferran Balaguer0dcffec2019-06-18 16:25:06 +0100765 src/armnnDeserializer/test/DeserializeL2Normalization.cpp
Ruomei Yandb7c3912019-03-08 17:50:25 +0000766 src/armnnDeserializer/test/DeserializeMean.cpp
767 src/armnnDeserializer/test/DeserializeMultiplication.cpp
768 src/armnnDeserializer/test/DeserializeNormalization.cpp
769 src/armnnDeserializer/test/DeserializePad.cpp
770 src/armnnDeserializer/test/DeserializePermute.cpp
771 src/armnnDeserializer/test/DeserializePooling2d.cpp
772 src/armnnDeserializer/test/DeserializeReshape.cpp
773 src/armnnDeserializer/test/DeserializeResizeBilinear.cpp
774 src/armnnDeserializer/test/DeserializeRsqrt.cpp
Aron Virginas-Tara2f4b4b2019-09-20 11:21:14 +0100775 src/armnnDeserializer/test/DeserializeSlice.cpp
Ruomei Yandb7c3912019-03-08 17:50:25 +0000776 src/armnnDeserializer/test/DeserializeSpaceToBatchNd.cpp
777 src/armnnDeserializer/test/DeserializeStridedSlice.cpp
778 src/armnnDeserializer/test/DeserializeSubtraction.cpp
779 src/armnnDeserializer/test/ParserFlatbuffersSerializeFixture.hpp
780 src/armnnDeserializer/test/SchemaSerialize.s
781 )
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000782 set_source_files_properties(src/armnnDeserializer/test/SchemaSerialize.s PROPERTIES COMPILE_FLAGS "-x assembler-with-cpp")
Kevin May43a799c2019-02-08 16:31:42 +0000783 endif()
784
Colm Donelana21620d2019-10-11 13:09:49 +0100785 if(BUILD_GATORD_MOCK)
786 list(APPEND unittest_sources
787 tests/profiling/gatordmock/tests/GatordMockTests.cpp
788 )
789 endif()
790
Matteo Martincigh4423ac72018-10-11 17:39:30 +0100791 foreach(lib ${armnnUnitTestLibraries})
David Beck3cc9a622018-10-12 10:38:31 +0100792 message("Adding object library dependency to UnitTests: ${lib}")
Matteo Martincigh4423ac72018-10-11 17:39:30 +0100793 list(APPEND unittest_sources $<TARGET_OBJECTS:${lib}>)
794 endforeach()
795
796 add_executable(UnitTests ${unittest_sources})
telsoa014fcda012018-03-09 14:13:49 +0000797 target_include_directories(UnitTests PRIVATE src/armnn)
798 target_include_directories(UnitTests PRIVATE src/armnnUtils)
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +0000799 target_include_directories(UnitTests PRIVATE src/backends)
Matteo Martincigh6db5f202019-09-05 12:02:04 +0100800 target_include_directories(UnitTests PRIVATE src/profiling)
telsoa014fcda012018-03-09 14:13:49 +0000801
telsoa01c577f2c2018-08-31 09:22:23 +0100802 if(VALGRIND_FOUND)
803 if(HEAP_PROFILING OR LEAK_CHECKING)
804 message("Valgrind is disabled for heap profiling and leak checking builds.")
805 else()
806 # Valgrind works with gperftools version number <= 2.4
807 target_compile_definitions(UnitTests PRIVATE "WITH_VALGRIND=1")
808 endif()
telsoa014fcda012018-03-09 14:13:49 +0000809 endif()
810
telsoa014fcda012018-03-09 14:13:49 +0000811 target_link_libraries(UnitTests ${CMAKE_THREAD_LIBS_INIT})
telsoa01c577f2c2018-08-31 09:22:23 +0100812 target_link_libraries(UnitTests ${Boost_UNIT_TEST_FRAMEWORK_LIBRARY} ${Boost_SYSTEM_LIBRARY} ${Boost_FILESYSTEM_LIBRARY})
telsoa014fcda012018-03-09 14:13:49 +0000813
Matteo Martincigh4423ac72018-10-11 17:39:30 +0100814 target_link_libraries(UnitTests armnn)
815 target_link_libraries(UnitTests armnnUtils)
816
surmeh01bceff2f2018-03-29 16:29:27 +0100817 if(BUILD_TF_PARSER)
818 target_link_libraries(UnitTests armnnTfParser)
819 endif()
820
Colm Donelana21620d2019-10-11 13:09:49 +0100821 if(BUILD_GATORD_MOCK)
822 target_link_libraries(UnitTests gatordMockService)
823 endif()
824
Ruomei Yandb7c3912019-03-08 17:50:25 +0000825 if(BUILD_TF_LITE_PARSER)
826 target_include_directories(UnitTests SYSTEM PRIVATE "${TF_LITE_SCHEMA_INCLUDE_PATH}")
827 target_include_directories(UnitTests SYSTEM PRIVATE "${FLATBUFFERS_INCLUDE_PATH}")
828 target_link_libraries(UnitTests armnnTfLiteParser)
829 endif()
830
telsoa014fcda012018-03-09 14:13:49 +0000831 if(BUILD_CAFFE_PARSER)
832 target_link_libraries(UnitTests armnnCaffeParser)
833 endif()
834
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100835 if(BUILD_ARMNN_SERIALIZER AND ARMNNREF)
Mike Kelly8c1701a2019-02-11 17:01:27 +0000836 target_include_directories(UnitTests SYSTEM PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/src/armnnSerializer)
Ruomei Yandb7c3912019-03-08 17:50:25 +0000837 target_include_directories(UnitTests SYSTEM PRIVATE "${FLATBUFFERS_INCLUDE_PATH}")
Kevin May43a799c2019-02-08 16:31:42 +0000838 target_link_libraries(UnitTests armnnSerializer)
839 endif()
840
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100841 if(BUILD_ARMNN_QUANTIZER AND ARMNNREF)
Nina Drozd59e15b02019-04-25 15:45:20 +0100842 target_include_directories(UnitTests SYSTEM PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/src/armnnQuantizer)
843 target_include_directories(UnitTests SYSTEM PRIVATE "${FLATBUFFERS_INCLUDE_PATH}")
844 target_link_libraries(UnitTests armnnQuantizer armnnSerializer)
845 endif()
846
telsoa01c577f2c2018-08-31 09:22:23 +0100847 if(BUILD_ONNX_PARSER)
848 target_link_libraries(UnitTests armnnOnnxParser)
849 endif()
850
telsoa014fcda012018-03-09 14:13:49 +0000851 addDllCopyCommands(UnitTests)
852endif()
Nattapat Chaimanowong4fbae332019-02-14 15:28:02 +0000853
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100854if (BUILD_ARMNN_SERIALIZER AND (BUILD_TF_PARSER OR BUILD_TF_LITE_PARSER OR BUILD_ONNX_PARSER OR BUILD_CAFFE_PARSER) AND ARMNNREF)
Nattapat Chaimanowong4fbae332019-02-14 15:28:02 +0000855 set(ArmnnConverter_sources
856 src/armnnConverter/ArmnnConverter.cpp)
857
858 add_executable_ex(ArmnnConverter ${ArmnnConverter_sources})
859 target_include_directories(ArmnnConverter PRIVATE src/armnn)
860 target_include_directories(ArmnnConverter PRIVATE src/armnnUtils)
861
Sadik Armagan232cfc22019-03-13 18:33:10 +0000862 if(BUILD_CAFFE_PARSER)
863 target_link_libraries(ArmnnConverter armnnCaffeParser)
864 endif()
865
866 if(BUILD_ONNX_PARSER)
867 target_link_libraries(ArmnnConverter armnnOnnxParser)
868 endif()
869
870 if(BUILD_TF_PARSER)
871 target_link_libraries(ArmnnConverter armnnTfParser)
872 endif()
873
874 if(BUILD_TF_LITE_PARSER)
875 target_link_libraries(ArmnnConverter armnnTfLiteParser)
876 endif()
877
Nattapat Chaimanowong4fbae332019-02-14 15:28:02 +0000878 target_link_libraries(ArmnnConverter armnnSerializer)
879
880 target_link_libraries(ArmnnConverter armnn)
881 target_link_libraries(ArmnnConverter ${CMAKE_THREAD_LIBS_INIT})
882 target_link_libraries(ArmnnConverter
883 ${Boost_SYSTEM_LIBRARY}
884 ${Boost_FILESYSTEM_LIBRARY}
885 ${Boost_PROGRAM_OPTIONS_LIBRARY})
886 addDllCopyCommands(ArmnnConverter)
887endif()
Colm Donelan366023f2019-09-05 10:03:56 +0100888
889if(BUILD_GATORD_MOCK)
890 set(gatord_mock_sources)
891 list(APPEND gatord_mock_sources
Colm Donelana21620d2019-10-11 13:09:49 +0100892 tests/profiling/gatordmock/CommandFileParser.hpp
893 tests/profiling/gatordmock/CommandFileParser.cpp
894 tests/profiling/gatordmock/CommandLineProcessor.hpp
895 tests/profiling/gatordmock/CommandLineProcessor.cpp
896 tests/profiling/gatordmock/GatordMockService.hpp
897 tests/profiling/gatordmock/GatordMockService.cpp
898 tests/profiling/gatordmock/MockUtils.hpp
899 tests/profiling/gatordmock/PeriodicCounterCaptureCommandHandler.cpp
900 tests/profiling/gatordmock/PeriodicCounterCaptureCommandHandler.hpp
Colm Donelan366023f2019-09-05 10:03:56 +0100901 )
902
Colm Donelana21620d2019-10-11 13:09:49 +0100903 include_directories( ${Boost_INCLUDE_DIRS} src/profiling)
Colm Donelan366023f2019-09-05 10:03:56 +0100904
Colm Donelana21620d2019-10-11 13:09:49 +0100905 add_library_ex(gatordMockService STATIC ${gatord_mock_sources})
Colm Donelan366023f2019-09-05 10:03:56 +0100906
Colm Donelana21620d2019-10-11 13:09:49 +0100907 add_executable_ex(GartordMock tests/profiling/gatordmock/GatordMockMain.cpp)
908
909 if(Threads_FOUND AND (NOT ("${CMAKE_SYSTEM_NAME}" STREQUAL Android)))
910 target_link_libraries(GartordMock pthread)
911 endif()
912
913 target_link_libraries(GartordMock armnn gatordMockService)
Colm Donelan366023f2019-09-05 10:03:56 +0100914 target_link_libraries(GartordMock
Colm Donelana21620d2019-10-11 13:09:49 +0100915 ${Boost_PROGRAM_OPTIONS_LIBRARY} ${Boost_SYSTEM_LIBRARY}
Colm Donelan366023f2019-09-05 10:03:56 +0100916 )
917
Colm Donelana21620d2019-10-11 13:09:49 +0100918endif()