blob: 976f8dee2ed052e7a57dcaa08854b5e2c76762c8 [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
Matthew Benthama7b79282019-06-03 13:00:50 +010018include(GNUInstallDirs)
19
Ruomei Yandb7c3912019-03-08 17:50:25 +000020add_subdirectory(samples)
21add_subdirectory(src/armnnTfLiteParser)
22add_subdirectory(src/armnnSerializer)
23
telsoa014fcda012018-03-09 14:13:49 +000024if (BUILD_TESTS)
25 add_subdirectory(tests)
26endif()
27
28# Include the additional cmake files in their own target so that they will appear nicely in IDEs
29add_custom_target(AdditionalCMakeFiles SOURCES ${additional_cmake_files})
30
31set(armnnUtils_sources)
32list(APPEND armnnUtils_sources
33 src/armnnUtils/GraphTopologicalSort.hpp
arovir01616e7752018-10-01 17:08:59 +010034 src/armnnUtils/Half.hpp
telsoa014fcda012018-03-09 14:13:49 +000035 src/armnnUtils/Logging.hpp
telsoa014fcda012018-03-09 14:13:49 +000036 src/armnnUtils/Logging.cpp
Matteo Martincigh21350152018-11-28 16:22:22 +000037 src/armnnUtils/Permute.hpp
telsoa014fcda012018-03-09 14:13:49 +000038 src/armnnUtils/Permute.cpp
Matteo Martincigh21350152018-11-28 16:22:22 +000039 src/armnnUtils/DataLayoutIndexed.cpp
40 src/armnnUtils/DataLayoutIndexed.hpp
surmeh01bceff2f2018-03-29 16:29:27 +010041 src/armnnUtils/DotSerializer.cpp
42 src/armnnUtils/DotSerializer.hpp
surmeh013537c2c2018-05-18 16:31:43 +010043 src/armnnUtils/HeapProfiling.cpp
44 src/armnnUtils/HeapProfiling.hpp
45 src/armnnUtils/LeakChecking.cpp
46 src/armnnUtils/LeakChecking.hpp
Éanna Ó Catháina4247d52019-05-08 14:00:45 +010047 src/armnnUtils/ModelAccuracyChecker.cpp
48 src/armnnUtils/ModelAccuracyChecker.hpp
telsoa01c577f2c2018-08-31 09:22:23 +010049 src/armnnUtils/CsvReader.cpp
50 src/armnnUtils/CsvReader.hpp
51 src/armnnUtils/FloatingPointConverter.cpp
52 src/armnnUtils/FloatingPointConverter.hpp
53 src/armnnUtils/VerificationHelpers.hpp
54 src/armnnUtils/VerificationHelpers.cpp
Sadik Armagan479045b2018-10-01 11:51:37 +010055 src/armnnUtils/ParserHelper.hpp
56 src/armnnUtils/ParserHelper.cpp
Matthew Bentham4057d912019-01-21 15:45:51 +000057 src/armnnUtils/ParserPrototxtFixture.hpp
58 src/armnnUtils/PrototxtConversions.hpp
59 src/armnnUtils/PrototxtConversions.cpp
Jim Flynn2fd61002019-05-03 12:54:26 +010060 src/armnnUtils/TensorIOUtils.hpp
Nina Drozdd41b2592018-11-19 13:03:36 +000061 src/armnnUtils/TensorUtils.hpp
62 src/armnnUtils/TensorUtils.cpp
telsoa014fcda012018-03-09 14:13:49 +000063 )
telsoa014fcda012018-03-09 14:13:49 +000064
65add_library_ex(armnnUtils STATIC ${armnnUtils_sources})
Jim Flynnf92dfce2019-05-02 11:33:25 +010066target_include_directories(armnnUtils PRIVATE src/backends)
telsoa014fcda012018-03-09 14:13:49 +000067
68if(BUILD_CAFFE_PARSER)
69 # ArmNN Parser source files required for all build options
70 set(armnn_caffe_parser_sources)
71 list(APPEND armnn_caffe_parser_sources
72 include/armnnCaffeParser/ICaffeParser.hpp
telsoa01c577f2c2018-08-31 09:22:23 +010073 src/armnnCaffeParser/RecordByRecordCaffeParser.hpp
74 src/armnnCaffeParser/RecordByRecordCaffeParser.cpp
telsoa014fcda012018-03-09 14:13:49 +000075 src/armnnCaffeParser/CaffeParser.hpp
76 src/armnnCaffeParser/CaffeParser.cpp
77 ${CAFFE_GENERATED_SOURCES}/caffe/proto/caffe.pb.cc
78 )
79 # The generated Caffe protobuf .cc file is not warning clean and we can't fix them.
80 if(COMPILER_IS_GNU_LIKE)
81 set_source_files_properties(${CAFFE_GENERATED_SOURCES}/caffe/proto/caffe.pb.cc PROPERTIES COMPILE_FLAGS "-Wno-conversion -Wno-sign-conversion")
82 endif()
83
84 add_library_ex(armnnCaffeParser SHARED ${armnn_caffe_parser_sources})
85 set_target_properties(armnnCaffeParser PROPERTIES COMPILE_FLAGS "${CAFFE_PARSER_ADDITIONAL_COMPILE_FLAGS}")
86
87 target_include_directories(armnnCaffeParser PRIVATE src/armnnUtils)
88
89 target_link_libraries(armnnCaffeParser ${Boost_LOG_LIBRARY} ${Boost_THREAD_LIBRARY} ${Boost_SYSTEM_LIBRARY})
90
91 target_link_libraries(armnnCaffeParser armnn)
92 target_link_libraries(armnnCaffeParser ${PROTOBUF_LIBRARIES})
telsoa01c577f2c2018-08-31 09:22:23 +010093
94endif()
95
96if(BUILD_ONNX_PARSER)
97 set(armnn_onnx_parser_sources)
98 list(APPEND armnn_onnx_parser_sources
99 include/armnnOnnxParser/IOnnxParser.hpp
100 src/armnnOnnxParser/OnnxParser.hpp
101 src/armnnOnnxParser/OnnxParser.cpp
102 ${ONNX_GENERATED_SOURCES}/onnx/onnx.pb.cc
103 )
104 # The generated onnx protobuf .cc files are not warning clean and we can't fix them.
105 if(COMPILER_IS_GNU_LIKE)
106 set_source_files_properties(${ONNX_GENERATED_SOURCES}/onnx/onnx.pb.cc PROPERTIES COMPILE_FLAGS "-Wno-conversion -Wno-sign-conversion")
107 endif()
108
109 add_library_ex(armnnOnnxParser SHARED ${armnn_onnx_parser_sources})
110
111 target_include_directories(armnnOnnxParser PRIVATE src/armnnUtils)
112
113 target_link_libraries(armnnOnnxParser armnn)
114
115 # Protobuf
116 target_link_libraries(armnnOnnxParser ${PROTOBUF_LIBRARIES})
telsoa014fcda012018-03-09 14:13:49 +0000117endif()
118
surmeh01bceff2f2018-03-29 16:29:27 +0100119if(BUILD_TF_PARSER)
120 set(armnn_tf_parser_sources)
121 list(APPEND armnn_tf_parser_sources
122 include/armnnTfParser/ITfParser.hpp
123 src/armnnTfParser/TfParser.hpp
124 src/armnnTfParser/TfParser.cpp
125 ${TF_PROTOBUFS}
126 )
127 # The generated tensorflow protobuf .cc files are not warning clean and we can't fix them.
128 if(COMPILER_IS_GNU_LIKE)
129 set_source_files_properties(${TF_PROTOBUFS} PROPERTIES COMPILE_FLAGS "-Wno-conversion -Wno-sign-conversion")
130 endif()
131
132 add_library_ex(armnnTfParser SHARED ${armnn_tf_parser_sources})
133
134 target_include_directories(armnnTfParser PRIVATE src/armnnUtils)
135
136 target_link_libraries(armnnTfParser armnn)
137
138 # Protobuf (use the specific version tensorflow wants)
139 target_link_libraries(armnnTfParser ${PROTOBUF_LIBRARIES})
140endif()
141
Jim Flynn3091b062019-02-15 14:45:04 +0000142if(BUILD_ARMNN_QUANTIZER)
Jim Flynn3091b062019-02-15 14:45:04 +0000143 if(NOT BUILD_ARMNN_SERIALIZER)
Ruomei Yandb7c3912019-03-08 17:50:25 +0000144 message(ERROR, "In order to build the ArmNN Quantization Tool you must set BUILD_ARMNN_SERIALIZER = YES")
Jim Flynn3091b062019-02-15 14:45:04 +0000145 endif()
146
Nina Drozd59e15b02019-04-25 15:45:20 +0100147 set(armnn_quantizer_sources)
148 list(APPEND armnn_quantizer_sources
149 src/armnnQuantizer/QuantizationDataSet.hpp
150 src/armnnQuantizer/QuantizationDataSet.cpp
151 src/armnnQuantizer/QuantizationInput.hpp
152 src/armnnQuantizer/QuantizationInput.cpp
Jim Flynn3091b062019-02-15 14:45:04 +0000153 src/armnnQuantizer/CommandLineProcessor.hpp
154 src/armnnQuantizer/CommandLineProcessor.cpp
Nina Drozd59e15b02019-04-25 15:45:20 +0100155 )
156
157 add_library_ex(armnnQuantizer SHARED ${armnn_quantizer_sources})
158
159 target_include_directories(armnnQuantizer PRIVATE include/armnnDeserializer)
160 target_include_directories(armnnQuantizer PRIVATE src/armnnUtils)
161 target_include_directories(armnnQuantizer PRIVATE src/armnn)
162
163 include_directories(SYSTEM "${FLATBUFFERS_INCLUDE_PATH}")
164 set_target_properties(armnnQuantizer PROPERTIES LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR})
165
166 target_link_libraries(armnnQuantizer
Guillaume GARDETe315c8f2019-06-05 10:58:47 +0200167 armnn
Nina Drozd59e15b02019-04-25 15:45:20 +0100168 ${Boost_SYSTEM_LIBRARY}
169 ${Boost_PROGRAM_OPTIONS_LIBRARY}
170 ${Boost_FILESYSTEM_LIBRARY}
171 ${Boost_LOG_LIBRARY}
172 ${Boost_THREAD_LIBRARY} )
173
174 add_executable_ex(ArmnnQuantizer
Jim Flynn3091b062019-02-15 14:45:04 +0000175 src/armnnQuantizer/ArmNNQuantizerMain.cpp)
176
Ruomei Yandb7c3912019-03-08 17:50:25 +0000177 target_include_directories(ArmnnQuantizer PRIVATE include/armnnDeserializer)
Nina Drozd59e15b02019-04-25 15:45:20 +0100178 target_include_directories(ArmnnQuantizer PRIVATE src/armnn)
Jim Flynn3091b062019-02-15 14:45:04 +0000179
180 target_link_libraries(ArmnnQuantizer
181 ${Boost_SYSTEM_LIBRARY}
182 ${Boost_PROGRAM_OPTIONS_LIBRARY}
183 ${Boost_FILESYSTEM_LIBRARY}
184 ${Boost_LOG_LIBRARY}
185 ${Boost_THREAD_LIBRARY} )
186
187 target_link_libraries(ArmnnQuantizer
Nina Drozd59e15b02019-04-25 15:45:20 +0100188 armnnQuantizer
Jim Flynn3091b062019-02-15 14:45:04 +0000189 armnnSerializer
190 armnn
Nina Drozd59e15b02019-04-25 15:45:20 +0100191 armnnUtils
Jim Flynn3091b062019-02-15 14:45:04 +0000192 ${FLATBUFFERS_LIBRARY})
193
194 if(Threads_FOUND AND (NOT ("${CMAKE_SYSTEM_NAME}" STREQUAL Android)))
195 target_link_libraries(ArmnnQuantizer pthread)
196 endif()
197
198endif()
199
200
telsoa014fcda012018-03-09 14:13:49 +0000201list(APPEND armnn_sources
202 include/armnn/ArmNN.hpp
David Beck9df2d952018-10-10 15:11:44 +0100203 include/armnn/BackendId.hpp
telsoa014fcda012018-03-09 14:13:49 +0000204 include/armnn/Descriptors.hpp
205 include/armnn/DescriptorsFwd.hpp
David Beck9df2d952018-10-10 15:11:44 +0100206 include/armnn/Exceptions.hpp
David Becke97c6e02018-10-03 13:09:28 +0100207 include/armnn/ILayerSupport.hpp
jimfly015f4e41f2019-01-23 16:10:17 +0000208 include/armnn/ILayerVisitor.hpp
telsoa014fcda012018-03-09 14:13:49 +0000209 include/armnn/INetwork.hpp
David Beck9df2d952018-10-10 15:11:44 +0100210 include/armnn/IProfiler.hpp
211 include/armnn/IRuntime.hpp
212 include/armnn/LayerSupport.hpp
Mike Kelly8c1701a2019-02-11 17:01:27 +0000213 include/armnn/LayerVisitorBase.hpp
David Beck9df2d952018-10-10 15:11:44 +0100214 include/armnn/LstmParams.hpp
215 include/armnn/NetworkFwd.hpp
David Beck5eec11d2018-10-04 15:43:17 +0100216 include/armnn/Optional.hpp
telsoa014fcda012018-03-09 14:13:49 +0000217 include/armnn/Tensor.hpp
218 include/armnn/TensorFwd.hpp
219 include/armnn/Types.hpp
220 include/armnn/TypesUtils.hpp
221 include/armnn/Utils.hpp
telsoa014fcda012018-03-09 14:13:49 +0000222 include/armnn/Version.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100223 src/armnn/layers/LayerCloneBase.hpp
224 src/armnn/layers/LayerWithParameters.hpp
225 src/armnn/layers/ActivationLayer.hpp
226 src/armnn/layers/ActivationLayer.cpp
227 src/armnn/layers/AdditionLayer.hpp
228 src/armnn/layers/AdditionLayer.cpp
229 src/armnn/layers/BatchNormalizationLayer.hpp
230 src/armnn/layers/BatchNormalizationLayer.cpp
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +0000231 src/armnn/layers/BatchToSpaceNdLayer.hpp
232 src/armnn/layers/BatchToSpaceNdLayer.cpp
Jim Flynne242f2d2019-05-22 14:24:13 +0100233 src/armnn/layers/ConcatLayer.hpp
234 src/armnn/layers/ConcatLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100235 src/armnn/layers/ConstantLayer.hpp
236 src/armnn/layers/ConstantLayer.cpp
237 src/armnn/layers/Convolution2dLayer.hpp
238 src/armnn/layers/Convolution2dLayer.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100239 src/armnn/layers/ConvertFp16ToFp32Layer.hpp
240 src/armnn/layers/ConvertFp16ToFp32Layer.cpp
241 src/armnn/layers/ConvertFp32ToFp16Layer.hpp
242 src/armnn/layers/ConvertFp32ToFp16Layer.cpp
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000243 src/armnn/layers/DebugLayer.hpp
244 src/armnn/layers/DebugLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100245 src/armnn/layers/DepthwiseConvolution2dLayer.hpp
246 src/armnn/layers/DepthwiseConvolution2dLayer.cpp
Nattapat Chaimanowonge4294fd2019-03-28 09:56:53 +0000247 src/armnn/layers/DequantizeLayer.hpp
248 src/armnn/layers/DequantizeLayer.cpp
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000249 src/armnn/layers/DetectionPostProcessLayer.hpp
250 src/armnn/layers/DetectionPostProcessLayer.cpp
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000251 src/armnn/layers/ElementwiseBaseLayer.hpp
252 src/armnn/layers/ElementwiseBaseLayer.cpp
FrancisMurtagh20995952018-12-17 12:11:36 +0000253 src/armnn/layers/EqualLayer.hpp
254 src/armnn/layers/EqualLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100255 src/armnn/layers/FakeQuantizationLayer.hpp
256 src/armnn/layers/FakeQuantizationLayer.cpp
257 src/armnn/layers/FloorLayer.hpp
258 src/armnn/layers/FloorLayer.cpp
259 src/armnn/layers/FullyConnectedLayer.hpp
260 src/armnn/layers/FullyConnectedLayer.cpp
narpra01b89b05f2019-01-16 09:53:09 +0000261 src/armnn/layers/GatherLayer.cpp
262 src/armnn/layers/GatherLayer.hpp
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000263 src/armnn/layers/GreaterLayer.cpp
264 src/armnn/layers/GreaterLayer.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100265 src/armnn/layers/InputLayer.hpp
266 src/armnn/layers/InputLayer.cpp
267 src/armnn/layers/L2NormalizationLayer.hpp
268 src/armnn/layers/L2NormalizationLayer.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100269 src/armnn/layers/LstmLayer.cpp
270 src/armnn/layers/LstmLayer.hpp
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000271 src/armnn/layers/MaximumLayer.cpp
272 src/armnn/layers/MaximumLayer.hpp
narpra0132b90462018-09-13 11:07:48 +0100273 src/armnn/layers/MeanLayer.hpp
274 src/armnn/layers/MeanLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100275 src/armnn/layers/MemCopyLayer.hpp
276 src/armnn/layers/MemCopyLayer.cpp
Nattapat Chaimanowong1f886302019-04-05 13:37:19 +0100277 src/armnn/layers/MergeLayer.hpp
278 src/armnn/layers/MergeLayer.cpp
kevmay0190539692018-11-29 08:40:19 +0000279 src/armnn/layers/MinimumLayer.cpp
280 src/armnn/layers/MinimumLayer.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100281 src/armnn/layers/MultiplicationLayer.hpp
282 src/armnn/layers/MultiplicationLayer.cpp
283 src/armnn/layers/NormalizationLayer.hpp
284 src/armnn/layers/NormalizationLayer.cpp
285 src/armnn/layers/OutputLayer.hpp
286 src/armnn/layers/OutputLayer.cpp
Mohamed Nour Abouelseoud5662c202018-09-24 13:30:09 +0100287 src/armnn/layers/PadLayer.hpp
288 src/armnn/layers/PadLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100289 src/armnn/layers/PermuteLayer.hpp
290 src/armnn/layers/PermuteLayer.cpp
291 src/armnn/layers/Pooling2dLayer.hpp
292 src/armnn/layers/Pooling2dLayer.cpp
Derek Lambertia9cca6a2019-03-25 15:41:58 +0000293 src/armnn/layers/QuantizeLayer.cpp
294 src/armnn/layers/QuantizeLayer.hpp
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100295 src/armnn/layers/DivisionLayer.cpp
296 src/armnn/layers/DivisionLayer.hpp
Matteo Martincigh49124022019-01-11 13:25:59 +0000297 src/armnn/layers/PreCompiledLayer.hpp
298 src/armnn/layers/PreCompiledLayer.cpp
Matteo Martincigh0e406ee2019-06-12 15:42:18 +0100299 src/armnn/layers/PreluLayer.hpp
300 src/armnn/layers/PreluLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100301 src/armnn/layers/ReshapeLayer.hpp
302 src/armnn/layers/ReshapeLayer.cpp
303 src/armnn/layers/ResizeBilinearLayer.hpp
304 src/armnn/layers/ResizeBilinearLayer.cpp
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000305 src/armnn/layers/RsqrtLayer.cpp
306 src/armnn/layers/RsqrtLayer.hpp
surmeh013537c2c2018-05-18 16:31:43 +0100307 src/armnn/layers/SoftmaxLayer.hpp
308 src/armnn/layers/SoftmaxLayer.cpp
Matteo Martincigh0e406ee2019-06-12 15:42:18 +0100309 src/armnn/layers/SpaceToBatchNdLayer.hpp
310 src/armnn/layers/SpaceToBatchNdLayer.cpp
311 src/armnn/layers/SpaceToDepthLayer.hpp
312 src/armnn/layers/SpaceToDepthLayer.cpp
surmeh013537c2c2018-05-18 16:31:43 +0100313 src/armnn/layers/SplitterLayer.hpp
314 src/armnn/layers/SplitterLayer.cpp
Conor Kennedy430b5d82018-11-14 15:28:28 +0000315 src/armnn/layers/StridedSliceLayer.cpp
316 src/armnn/layers/StridedSliceLayer.hpp
David Beckc2044fe2018-09-05 15:00:38 +0100317 src/armnn/layers/SubtractionLayer.cpp
318 src/armnn/layers/SubtractionLayer.hpp
Sadik Armaganeff363d2019-04-05 15:25:46 +0100319 src/armnn/layers/SwitchLayer.cpp
320 src/armnn/layers/SwitchLayer.hpp
Aron Virginas-Tar639fb042019-06-20 14:28:19 +0100321 src/armnn/layers/TransposeConvolution2dLayer.cpp
322 src/armnn/layers/TransposeConvolution2dLayer.hpp
Matteo Martincigh49124022019-01-11 13:25:59 +0000323 src/armnn/BackendSettings.hpp
Nattapat Chaimanowong649dd952019-01-22 16:10:44 +0000324 src/armnn/CompatibleTypes.hpp
telsoa014fcda012018-03-09 14:13:49 +0000325 src/armnn/Descriptors.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100326 src/armnn/DeviceSpec.hpp
Jim Flynnf92dfce2019-05-02 11:33:25 +0100327 src/armnn/DynamicQuantizationVisitor.cpp
328 src/armnn/DynamicQuantizationVisitor.hpp
telsoa014fcda012018-03-09 14:13:49 +0000329 src/armnn/Exceptions.cpp
Teresa Charlin4de9f672019-04-10 13:59:49 +0100330 src/armnn/ExecutionFrame.cpp
331 src/armnn/ExecutionFrame.hpp
telsoa014fcda012018-03-09 14:13:49 +0000332 src/armnn/Graph.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100333 src/armnn/Graph.hpp
334 src/armnn/IGraphObservable.hpp
335 src/armnn/Instrument.hpp
336 src/armnn/InternalTypes.cpp
337 src/armnn/InternalTypes.hpp
Derek Lambertiff05cc52019-04-26 13:05:17 +0100338 src/armnn/ISubgraphViewConverter.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100339 src/armnn/JsonPrinter.cpp
340 src/armnn/JsonPrinter.hpp
341 src/armnn/Layer.cpp
342 src/armnn/LayerFwd.hpp
343 src/armnn/Layer.hpp
344 src/armnn/LayersFwd.hpp
345 src/armnn/LayerSupportCommon.hpp
346 src/armnn/LayerSupport.cpp
347 src/armnn/LoadedNetwork.cpp
348 src/armnn/LoadedNetwork.hpp
telsoa014fcda012018-03-09 14:13:49 +0000349 src/armnn/Network.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100350 src/armnn/Network.hpp
Nattapat Chaimanowong7ac07f32019-03-20 11:51:14 +0000351 src/armnn/NetworkQuantizationScheme.hpp
Derek Lamberti27d83072019-02-05 16:00:08 +0000352 src/armnn/NetworkQuantizer.cpp
353 src/armnn/NetworkQuantizer.hpp
Matteo Martincigha8d572d2019-02-07 17:51:09 +0000354 src/armnn/NetworkQuantizerUtils.cpp
355 src/armnn/NetworkQuantizerUtils.hpp
Aron Virginas-Tar5fdfe822018-11-21 13:14:42 +0000356 src/armnn/NetworkUtils.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100357 src/armnn/NetworkUtils.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100358 src/armnn/Observable.cpp
359 src/armnn/Observable.hpp
360 src/armnn/Optimizer.cpp
361 src/armnn/Optimizer.hpp
Matteo Martincigha8d572d2019-02-07 17:51:09 +0000362 src/armnn/OverrideInputRangeVisitor.cpp
363 src/armnn/OverrideInputRangeVisitor.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100364 src/armnn/Profiling.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100365 src/armnn/ProfilingEvent.cpp
366 src/armnn/ProfilingEvent.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100367 src/armnn/Profiling.hpp
Derek Lamberti27d83072019-02-05 16:00:08 +0000368 src/armnn/QuantizerVisitor.cpp
369 src/armnn/QuantizerVisitor.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100370 src/armnn/Runtime.cpp
371 src/armnn/Runtime.hpp
Derek Lamberti8a4ca102019-02-08 17:54:20 +0000372 src/armnn/RangeTracker.cpp
373 src/armnn/RangeTracker.hpp
Aron Virginas-Tard4f0fea2019-04-09 14:08:06 +0100374 src/armnn/ResolveType.hpp
David Beckf98d21a2018-10-26 16:03:03 +0100375 src/armnn/SerializeLayerParameters.cpp
376 src/armnn/SerializeLayerParameters.hpp
Derek Lamberti27d83072019-02-05 16:00:08 +0000377 src/armnn/StaticRangeVisitor.cpp
378 src/armnn/StaticRangeVisitor.hpp
Derek Lambertiff05cc52019-04-26 13:05:17 +0100379 src/armnn/SubgraphView.cpp
380 src/armnn/SubgraphView.hpp
381 src/armnn/SubgraphViewSelector.cpp
382 src/armnn/SubgraphViewSelector.hpp
telsoa014fcda012018-03-09 14:13:49 +0000383 src/armnn/Tensor.cpp
Aron Virginas-Tard4f0fea2019-04-09 14:08:06 +0100384 src/armnn/TypesUtils.cpp
telsoa014fcda012018-03-09 14:13:49 +0000385 src/armnn/Utils.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100386 src/armnn/WallClockTimer.cpp
387 src/armnn/WallClockTimer.hpp
Nina Drozd861985f2019-04-18 14:48:51 +0100388 src/armnn/optimizations/AddDebug.hpp
telsoa014fcda012018-03-09 14:13:49 +0000389 src/armnn/optimizations/All.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100390 src/armnn/optimizations/ConvertConstants.hpp
Nina Drozd861985f2019-04-18 14:48:51 +0100391 src/armnn/optimizations/ConvertFp32NetworkToFp16.hpp
392 src/armnn/optimizations/FoldPadIntoConvolution2d.hpp
telsoa014fcda012018-03-09 14:13:49 +0000393 src/armnn/optimizations/MovePermuteUp.hpp
394 src/armnn/optimizations/Optimization.hpp
395 src/armnn/optimizations/OptimizeConsecutiveReshapes.hpp
Nina Drozd861985f2019-04-18 14:48:51 +0100396 src/armnn/optimizations/OptimizeInverseConversions.hpp
telsoa014fcda012018-03-09 14:13:49 +0000397 src/armnn/optimizations/OptimizeInversePermutes.hpp
398 src/armnn/optimizations/PermuteAsReshape.hpp
399 src/armnn/optimizations/SquashEqualSiblings.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100400 third-party/half/half.hpp
telsoa014fcda012018-03-09 14:13:49 +0000401 )
402
telsoa014fcda012018-03-09 14:13:49 +0000403# Files used for Streamline-based profiling backend
404if(PROFILING_BACKEND_STREAMLINE)
405 list(APPEND armnn_sources
406 ${GATOR_ROOT}/annotate/streamline_annotate.h
407 ${GATOR_ROOT}/annotate/streamline_annotate.c)
408endif()
409
David Beck10b4dfd2018-09-19 12:03:20 +0100410# the backends under src/backends extend the list of
David Beck3cc9a622018-10-12 10:38:31 +0100411# object libs armnn to include in the build
David Beck10b4dfd2018-09-19 12:03:20 +0100412include(src/backends/backends.cmake)
David Beck3cc9a622018-10-12 10:38:31 +0100413foreach(lib ${armnnLibraries})
414 message("Adding object library dependency to armnn: ${lib}")
415 list(APPEND armnn_sources $<TARGET_OBJECTS:${lib}>)
416endforeach()
417
418add_library_ex(armnn SHARED ${armnn_sources})
David Beck10b4dfd2018-09-19 12:03:20 +0100419
telsoa014fcda012018-03-09 14:13:49 +0000420target_include_directories(armnn PRIVATE src/armnn)
421target_include_directories(armnn PRIVATE src/armnnUtils)
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +0000422target_include_directories(armnn PRIVATE src/backends)
David Beck3cc9a622018-10-12 10:38:31 +0100423
424target_link_libraries(armnn armnnUtils)
425
telsoa014fcda012018-03-09 14:13:49 +0000426target_link_libraries(armnn ${CMAKE_DL_LIBS})
427
Matthew Benthama7b79282019-06-03 13:00:50 +0100428install(TARGETS armnn
429 LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR})
telsoa014fcda012018-03-09 14:13:49 +0000430if(BUILD_CAFFE_PARSER)
Matthew Benthama7b79282019-06-03 13:00:50 +0100431 install(TARGETS armnnCaffeParser
432 LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR})
telsoa014fcda012018-03-09 14:13:49 +0000433endif()
telsoa01c577f2c2018-08-31 09:22:23 +0100434if(BUILD_ONNX_PARSER)
Matthew Benthama7b79282019-06-03 13:00:50 +0100435 install(TARGETS armnnOnnxParser
436 LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR})
telsoa01c577f2c2018-08-31 09:22:23 +0100437endif()
surmeh01bceff2f2018-03-29 16:29:27 +0100438if(BUILD_TF_PARSER)
Matthew Benthama7b79282019-06-03 13:00:50 +0100439 install(TARGETS armnnTfParser
440 LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR})
surmeh01bceff2f2018-03-29 16:29:27 +0100441endif()
Ruomei Yandb7c3912019-03-08 17:50:25 +0000442
Matthew Benthama7b79282019-06-03 13:00:50 +0100443install(DIRECTORY include/ DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
telsoa014fcda012018-03-09 14:13:49 +0000444
445target_link_libraries(armnn ${Boost_LOG_LIBRARY} ${Boost_THREAD_LIBRARY} ${Boost_SYSTEM_LIBRARY})
446
447if(ARMCOMPUTENEON OR ARMCOMPUTECL)
448 target_link_libraries(armnn ${ARMCOMPUTE_LIBRARIES})
449endif()
450if(ARMCOMPUTECL)
451 target_link_libraries(armnn ${OPENCL_LIBRARIES})
452endif()
453
454if(PROFILING_BACKEND_STREAMLINE)
455 target_link_libraries(armnn pthread)
456endif()
457
telsoa014fcda012018-03-09 14:13:49 +0000458if(BUILD_UNIT_TESTS)
459 set(unittest_sources)
460 list(APPEND unittest_sources
jimfly01aebf2e72019-02-05 09:20:11 +0000461 src/armnn/test/ConstTensorLayerVisitor.hpp
462 src/armnn/test/ConstTensorLayerVisitor.cpp
telsoa014fcda012018-03-09 14:13:49 +0000463 src/armnn/test/CreateWorkload.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100464 src/armnn/test/CsvReaderTest.cpp
Nattapat Chaimanowong317cae52019-03-28 10:29:12 +0000465 src/armnn/test/DebugCallbackTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100466 src/armnn/test/EndToEndTest.cpp
Teresa Charlin4de9f672019-04-10 13:59:49 +0100467 src/armnn/test/ExecutionFrameTest.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100468 src/armnn/test/FloatingPointConverterTest.cpp
Matthew Benthamd78b891d2019-04-30 10:17:40 +0100469 src/armnn/test/FlowControl.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100470 src/armnn/test/GraphTests.cpp
narpra016f37f832018-12-21 18:30:00 +0000471 src/armnn/test/GraphUtils.cpp
telsoa014fcda012018-03-09 14:13:49 +0000472 src/armnn/test/GraphUtils.hpp
telsoa01c577f2c2018-08-31 09:22:23 +0100473 src/armnn/test/InstrumentTests.cpp
Éanna Ó Catháin262553e2018-11-14 11:26:23 +0000474 src/armnn/test/LayerValidateOutputTest.cpp
Éanna Ó Catháina4247d52019-05-08 14:00:45 +0100475 src/armnn/test/ModelAccuracyCheckerTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100476 src/armnn/test/NetworkTests.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100477 src/armnn/test/ObservableTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100478 src/armnn/test/OptimizerTests.cpp
479 src/armnn/test/OptionalTest.cpp
480 src/armnn/test/ProfilerTests.cpp
481 src/armnn/test/ProfilingEventTest.cpp
Derek Lamberti7205fed2019-02-06 16:20:46 +0000482 src/armnn/test/QuantizerTest.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100483 src/armnn/test/RuntimeTests.cpp
484 src/armnn/test/RuntimeTests.hpp
Derek Lambertiff05cc52019-04-26 13:05:17 +0100485 src/armnn/test/SubgraphViewTests.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100486 src/armnn/test/TensorHelpers.hpp
487 src/armnn/test/TensorTest.cpp
FrancisMurtagh531ef942019-02-01 11:48:58 +0000488 src/armnn/test/TestInputOutputLayerVisitor.cpp
489 src/armnn/test/TestInputOutputLayerVisitor.hpp
FrancisMurtagh1306b192019-01-28 14:03:21 +0000490 src/armnn/test/TestLayerVisitor.cpp
491 src/armnn/test/TestLayerVisitor.hpp
FrancisMurtagh28d3d632019-01-29 12:15:23 +0000492 src/armnn/test/TestNameOnlyLayerVisitor.cpp
493 src/armnn/test/TestNameOnlyLayerVisitor.hpp
FrancisMurtaghf08876f2019-02-04 15:41:17 +0000494 src/armnn/test/TestNameAndDescriptorLayerVisitor.hpp
495 src/armnn/test/TestNameAndDescriptorLayerVisitor.cpp
David Beckf98d21a2018-10-26 16:03:03 +0100496 src/armnn/test/UnitTests.cpp
497 src/armnn/test/UnitTests.hpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000498 src/armnn/test/UtilsTests.cpp
Matthew Bentham4057d912019-01-21 15:45:51 +0000499 src/armnnUtils/test/PrototxtConversionsTest.cpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000500 src/armnnUtils/test/ParserHelperTest.cpp
501 )
telsoa014fcda012018-03-09 14:13:49 +0000502
surmeh01bceff2f2018-03-29 16:29:27 +0100503 if(BUILD_TF_PARSER)
504 list(APPEND unittest_sources
505 src/armnnTfParser/test/Activations.cpp
506 src/armnnTfParser/test/Addition.cpp
Ferran Balaguerfbdad032018-12-28 18:15:24 +0000507 src/armnnTfParser/test/AddN.cpp
narpra016f37f832018-12-21 18:30:00 +0000508 src/armnnTfParser/test/Assert.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100509 src/armnnTfParser/test/BiasAdd.cpp
510 src/armnnTfParser/test/BroadcastForAdd.cpp
511 src/armnnTfParser/test/Convolution2d.cpp
512 src/armnnTfParser/test/Concat.cpp
513 src/armnnTfParser/test/ConcatOfConcats.cpp
514 src/armnnTfParser/test/DepthwiseConvolution2d.cpp
jimfly0184c70e62018-12-19 13:14:46 +0000515 src/armnnTfParser/test/Equal.cpp
Conor Kennedyc2130a02018-12-05 11:05:54 +0000516 src/armnnTfParser/test/ExpandDims.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100517 src/armnnTfParser/test/FusedBatchNorm.cpp
FrancisMurtagh94412af2019-01-24 10:53:39 +0000518 src/armnnTfParser/test/Gather.cpp
jimfly01a06bf312018-12-18 16:24:51 +0000519 src/armnnTfParser/test/Greater.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100520 src/armnnTfParser/test/Identity.cpp
521 src/armnnTfParser/test/LocalResponseNormalization.cpp
Sadik Armagan975c09a2018-12-04 10:02:08 +0000522 src/armnnTfParser/test/Maximum.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100523 src/armnnTfParser/test/MaximumForLeakyRelu.cpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000524 src/armnnTfParser/test/Mean.cpp
Nattapat Chaimanowong24df8222018-12-04 13:47:02 +0000525 src/armnnTfParser/test/Minimum.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100526 src/armnnTfParser/test/Multiplication.cpp
jimfly01f6ba7472018-12-04 10:09:52 +0000527 src/armnnTfParser/test/Pad.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100528 src/armnnTfParser/test/MultiOutput.cpp
529 src/armnnTfParser/test/PassThru.cpp
530 src/armnnTfParser/test/Pooling.cpp
saoste01bbd40612018-08-28 15:41:51 +0100531 src/armnnTfParser/test/RealDiv.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100532 src/armnnTfParser/test/Reshape.cpp
533 src/armnnTfParser/test/ResizeBilinear.cpp
Mohamed Nour Abouelseoud7a8892f2019-01-09 14:19:58 +0000534 src/armnnTfParser/test/Rsqrt.cpp
surmeh01bceff2f2018-03-29 16:29:27 +0100535 src/armnnTfParser/test/Shape.cpp
536 src/armnnTfParser/test/Softmax.cpp
537 src/armnnTfParser/test/TestDependencies.cpp
538 src/armnnTfParser/test/FullyConnected.cpp
539 src/armnnTfParser/test/Constant.cpp
540 src/armnnTfParser/test/TestMultiInputsOutputs.cpp
Sadik Armagan2ad6cb42018-12-27 11:23:44 +0000541 src/armnnTfParser/test/Split.cpp
jimfly0123be07e2018-12-04 17:47:22 +0000542 src/armnnTfParser/test/Squeeze.cpp
Ferran Balaguer51dd62f2019-01-11 19:29:18 +0000543 src/armnnTfParser/test/Sub.cpp
544 )
surmeh01bceff2f2018-03-29 16:29:27 +0100545 endif()
546
telsoa01c577f2c2018-08-31 09:22:23 +0100547 if(BUILD_TF_LITE_PARSER)
Matthew Bentham6c8e8e72019-01-15 17:57:00 +0000548 enable_language(ASM)
telsoa01c577f2c2018-08-31 09:22:23 +0100549 list(APPEND unittest_sources
550 src/armnnTfLiteParser/test/ParserFlatbuffersFixture.hpp
Sadik Armagan479045b2018-10-01 11:51:37 +0100551 src/armnnTfLiteParser/test/Activations.cpp
Bruno Goncalvesd4ac6a42018-12-18 12:56:22 -0200552 src/armnnTfLiteParser/test/Addition.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100553 src/armnnTfLiteParser/test/AvgPool2D.cpp
Bruno Goncalvesdb947e22019-02-08 18:52:21 -0200554 src/armnnTfLiteParser/test/BatchToSpaceND.cpp
Sadik Armagan479045b2018-10-01 11:51:37 +0100555 src/armnnTfLiteParser/test/Concatenation.cpp
Bruno Goncalves3d7efe92018-12-27 14:21:43 -0200556 src/armnnTfLiteParser/test/Constant.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100557 src/armnnTfLiteParser/test/Conv2D.cpp
558 src/armnnTfLiteParser/test/DepthwiseConvolution2D.cpp
keidav011b3e2ea2019-02-21 10:07:37 +0000559 src/armnnTfLiteParser/test/DetectionPostProcess.cpp
Sadik Armagan8853c1f2018-10-22 09:04:18 +0100560 src/armnnTfLiteParser/test/FullyConnected.cpp
Bruno Goncalvesb8d805e2019-02-12 22:57:13 -0200561 src/armnnTfLiteParser/test/Maximum.cpp
Nattapat Chaimanowongb66504b2018-10-17 15:19:14 +0100562 src/armnnTfLiteParser/test/MaxPool2D.cpp
Bruno Goncalves2235cee2018-12-19 12:51:45 -0200563 src/armnnTfLiteParser/test/Mean.cpp
Bruno Goncalves8f6d7a72019-02-12 22:58:18 -0200564 src/armnnTfLiteParser/test/Minimum.cpp
Bruno Goncalvesf803f782018-12-18 13:40:30 -0200565 src/armnnTfLiteParser/test/Multiplication.cpp
Bruno Goncalves6c2355b2018-12-19 12:52:01 -0200566 src/armnnTfLiteParser/test/Pad.cpp
Sadik Armagan479045b2018-10-01 11:51:37 +0100567 src/armnnTfLiteParser/test/Reshape.cpp
Bruno Goncalves3f58ddb2019-02-07 18:40:11 -0200568 src/armnnTfLiteParser/test/ResizeBilinear.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100569 src/armnnTfLiteParser/test/Softmax.cpp
Bruno Goncalvesbaded142019-02-08 19:02:48 -0200570 src/armnnTfLiteParser/test/SpaceToBatchND.cpp
Nina Drozd0324f482019-04-08 10:52:10 +0100571 src/armnnTfLiteParser/test/Split.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100572 src/armnnTfLiteParser/test/Squeeze.cpp
Bruno Goncalves451d95b2019-02-12 22:59:22 -0200573 src/armnnTfLiteParser/test/StridedSlice.cpp
Nina Drozd0324f482019-04-08 10:52:10 +0100574 src/armnnTfLiteParser/test/Sub.cpp
Nina Drozd200e3802019-04-15 09:47:39 +0100575 src/armnnTfLiteParser/test/Unpack.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100576 src/armnnTfLiteParser/test/LoadModel.cpp
577 src/armnnTfLiteParser/test/GetBuffer.cpp
578 src/armnnTfLiteParser/test/OutputShapeOfSqueeze.cpp
579 src/armnnTfLiteParser/test/InputOutputTensorNames.cpp
580 src/armnnTfLiteParser/test/GetTensorIds.cpp
581 src/armnnTfLiteParser/test/GetSubgraphInputsOutputs.cpp
582 src/armnnTfLiteParser/test/GetInputsOutputs.cpp
Matthew Bentham6c8e8e72019-01-15 17:57:00 +0000583 src/armnnTfLiteParser/test/Schema.s
telsoa01c577f2c2018-08-31 09:22:23 +0100584 )
Matthew Bentham6c8e8e72019-01-15 17:57:00 +0000585 set_source_files_properties(src/armnnTfLiteParser/test/Schema.s PROPERTIES COMPILE_FLAGS "-x assembler-with-cpp")
telsoa01c577f2c2018-08-31 09:22:23 +0100586 endif()
587
telsoa014fcda012018-03-09 14:13:49 +0000588 if(BUILD_CAFFE_PARSER)
589 list(APPEND unittest_sources
590 src/armnnCaffeParser/test/TestAdd.cpp
591 src/armnnCaffeParser/test/TestConcat.cpp
telsoa01c577f2c2018-08-31 09:22:23 +0100592 src/armnnCaffeParser/test/TestConvolution.cpp
telsoa014fcda012018-03-09 14:13:49 +0000593 src/armnnCaffeParser/test/TestDropout.cpp
594 src/armnnCaffeParser/test/TestInputs.cpp
595 src/armnnCaffeParser/test/TestMul.cpp
596 src/armnnCaffeParser/test/TestPooling2d.cpp
597 src/armnnCaffeParser/test/TestInPlace.cpp
598 src/armnnCaffeParser/test/TestMultiInputsOutputs.cpp
599 src/armnnCaffeParser/test/TestSplit.cpp
600 )
601 endif()
602
Nina Drozd59e15b02019-04-25 15:45:20 +0100603 if(BUILD_ARMNN_QUANTIZER)
604 list(APPEND unittest_sources
605 src/armnnQuantizer/test/QuantizationDataSetTests.cpp
606 )
607 endif()
608
Kevin May43a799c2019-02-08 16:31:42 +0000609 if(BUILD_ARMNN_SERIALIZER)
610 enable_language(ASM)
611 list(APPEND unittest_sources
Ruomei Yandb7c3912019-03-08 17:50:25 +0000612 src/armnnSerializer/test/ActivationSerializationTests.cpp
613 src/armnnSerializer/test/SerializerTests.cpp
614 src/armnnDeserializer/test/DeserializeActivation.cpp
615 src/armnnDeserializer/test/DeserializeAdd.cpp
616 src/armnnDeserializer/test/DeserializeBatchToSpaceNd.cpp
617 src/armnnDeserializer/test/DeserializeBatchNormalization.cpp
618 src/armnnDeserializer/test/DeserializeConstant.cpp
619 src/armnnDeserializer/test/DeserializeConvolution2d.cpp
620 src/armnnDeserializer/test/DeserializeDivision.cpp
621 src/armnnDeserializer/test/DeserializeEqual.cpp
622 src/armnnDeserializer/test/DeserializeFloor.cpp
623 src/armnnDeserializer/test/DeserializeFullyConnected.cpp
624 src/armnnDeserializer/test/DeserializeGather.cpp
625 src/armnnDeserializer/test/DeserializeGreater.cpp
Ferran Balaguer0dcffec2019-06-18 16:25:06 +0100626 src/armnnDeserializer/test/DeserializeL2Normalization.cpp
Ruomei Yandb7c3912019-03-08 17:50:25 +0000627 src/armnnDeserializer/test/DeserializeMean.cpp
628 src/armnnDeserializer/test/DeserializeMultiplication.cpp
629 src/armnnDeserializer/test/DeserializeNormalization.cpp
630 src/armnnDeserializer/test/DeserializePad.cpp
631 src/armnnDeserializer/test/DeserializePermute.cpp
632 src/armnnDeserializer/test/DeserializePooling2d.cpp
633 src/armnnDeserializer/test/DeserializeReshape.cpp
634 src/armnnDeserializer/test/DeserializeResizeBilinear.cpp
635 src/armnnDeserializer/test/DeserializeRsqrt.cpp
636 src/armnnDeserializer/test/DeserializeSpaceToBatchNd.cpp
637 src/armnnDeserializer/test/DeserializeStridedSlice.cpp
638 src/armnnDeserializer/test/DeserializeSubtraction.cpp
639 src/armnnDeserializer/test/ParserFlatbuffersSerializeFixture.hpp
640 src/armnnDeserializer/test/SchemaSerialize.s
641 )
Derek Lamberti0028d1b2019-02-20 13:57:42 +0000642 set_source_files_properties(src/armnnDeserializer/test/SchemaSerialize.s PROPERTIES COMPILE_FLAGS "-x assembler-with-cpp")
Kevin May43a799c2019-02-08 16:31:42 +0000643 endif()
644
telsoa01c577f2c2018-08-31 09:22:23 +0100645 if(BUILD_ONNX_PARSER)
646 list(APPEND unittest_sources
647 src/armnnOnnxParser/test/Constructor.cpp
648 src/armnnOnnxParser/test/CreateNetwork.cpp
649 src/armnnOnnxParser/test/ProtoxtFixture.cpp
650 src/armnnOnnxParser/test/Const.cpp
651 src/armnnOnnxParser/test/Pooling.cpp
652 src/armnnOnnxParser/test/Reshape.cpp
653 src/armnnOnnxParser/test/Relu.cpp
654 src/armnnOnnxParser/test/Conv2D.cpp
655 src/armnnOnnxParser/test/Addition.cpp
656 src/armnnOnnxParser/test/FullyConnected.cpp
657 src/armnnOnnxParser/test/GetInputsOutputs.cpp
658 src/armnnOnnxParser/test/BatchNorm.cpp
659 src/armnnOnnxParser/test/DepthConv.cpp
660 )
661 endif()
662
Matteo Martincigh4423ac72018-10-11 17:39:30 +0100663 foreach(lib ${armnnUnitTestLibraries})
David Beck3cc9a622018-10-12 10:38:31 +0100664 message("Adding object library dependency to UnitTests: ${lib}")
Matteo Martincigh4423ac72018-10-11 17:39:30 +0100665 list(APPEND unittest_sources $<TARGET_OBJECTS:${lib}>)
666 endforeach()
667
668 add_executable(UnitTests ${unittest_sources})
telsoa014fcda012018-03-09 14:13:49 +0000669 target_include_directories(UnitTests PRIVATE src/armnn)
670 target_include_directories(UnitTests PRIVATE src/armnnUtils)
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +0000671 target_include_directories(UnitTests PRIVATE src/backends)
telsoa014fcda012018-03-09 14:13:49 +0000672
telsoa01c577f2c2018-08-31 09:22:23 +0100673 if(VALGRIND_FOUND)
674 if(HEAP_PROFILING OR LEAK_CHECKING)
675 message("Valgrind is disabled for heap profiling and leak checking builds.")
676 else()
677 # Valgrind works with gperftools version number <= 2.4
678 target_compile_definitions(UnitTests PRIVATE "WITH_VALGRIND=1")
679 endif()
telsoa014fcda012018-03-09 14:13:49 +0000680 endif()
681
telsoa014fcda012018-03-09 14:13:49 +0000682 target_link_libraries(UnitTests ${CMAKE_THREAD_LIBS_INIT})
telsoa01c577f2c2018-08-31 09:22:23 +0100683 target_link_libraries(UnitTests ${Boost_UNIT_TEST_FRAMEWORK_LIBRARY} ${Boost_SYSTEM_LIBRARY} ${Boost_FILESYSTEM_LIBRARY})
telsoa014fcda012018-03-09 14:13:49 +0000684
Matteo Martincigh4423ac72018-10-11 17:39:30 +0100685 target_link_libraries(UnitTests armnn)
686 target_link_libraries(UnitTests armnnUtils)
687
surmeh01bceff2f2018-03-29 16:29:27 +0100688 if(BUILD_TF_PARSER)
689 target_link_libraries(UnitTests armnnTfParser)
690 endif()
691
Ruomei Yandb7c3912019-03-08 17:50:25 +0000692 if(BUILD_TF_LITE_PARSER)
693 target_include_directories(UnitTests SYSTEM PRIVATE "${TF_LITE_SCHEMA_INCLUDE_PATH}")
694 target_include_directories(UnitTests SYSTEM PRIVATE "${FLATBUFFERS_INCLUDE_PATH}")
695 target_link_libraries(UnitTests armnnTfLiteParser)
696 endif()
697
telsoa014fcda012018-03-09 14:13:49 +0000698 if(BUILD_CAFFE_PARSER)
699 target_link_libraries(UnitTests armnnCaffeParser)
700 endif()
701
Kevin May43a799c2019-02-08 16:31:42 +0000702 if(BUILD_ARMNN_SERIALIZER)
Mike Kelly8c1701a2019-02-11 17:01:27 +0000703 target_include_directories(UnitTests SYSTEM PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/src/armnnSerializer)
Ruomei Yandb7c3912019-03-08 17:50:25 +0000704 target_include_directories(UnitTests SYSTEM PRIVATE "${FLATBUFFERS_INCLUDE_PATH}")
Kevin May43a799c2019-02-08 16:31:42 +0000705 target_link_libraries(UnitTests armnnSerializer)
706 endif()
707
Nina Drozd59e15b02019-04-25 15:45:20 +0100708 if(BUILD_ARMNN_QUANTIZER)
709 target_include_directories(UnitTests SYSTEM PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/src/armnnQuantizer)
710 target_include_directories(UnitTests SYSTEM PRIVATE "${FLATBUFFERS_INCLUDE_PATH}")
711 target_link_libraries(UnitTests armnnQuantizer armnnSerializer)
712 endif()
713
telsoa01c577f2c2018-08-31 09:22:23 +0100714 if(BUILD_ONNX_PARSER)
715 target_link_libraries(UnitTests armnnOnnxParser)
716 endif()
717
telsoa014fcda012018-03-09 14:13:49 +0000718 addDllCopyCommands(UnitTests)
719endif()
Nattapat Chaimanowong4fbae332019-02-14 15:28:02 +0000720
Sadik Armagan232cfc22019-03-13 18:33:10 +0000721if (BUILD_ARMNN_SERIALIZER AND (BUILD_TF_PARSER OR BUILD_TF_LITE_PARSER OR BUILD_ONNX_PARSER OR BUILD_CAFFE_PARSER))
Nattapat Chaimanowong4fbae332019-02-14 15:28:02 +0000722 set(ArmnnConverter_sources
723 src/armnnConverter/ArmnnConverter.cpp)
724
725 add_executable_ex(ArmnnConverter ${ArmnnConverter_sources})
726 target_include_directories(ArmnnConverter PRIVATE src/armnn)
727 target_include_directories(ArmnnConverter PRIVATE src/armnnUtils)
728
Sadik Armagan232cfc22019-03-13 18:33:10 +0000729 if(BUILD_CAFFE_PARSER)
730 target_link_libraries(ArmnnConverter armnnCaffeParser)
731 endif()
732
733 if(BUILD_ONNX_PARSER)
734 target_link_libraries(ArmnnConverter armnnOnnxParser)
735 endif()
736
737 if(BUILD_TF_PARSER)
738 target_link_libraries(ArmnnConverter armnnTfParser)
739 endif()
740
741 if(BUILD_TF_LITE_PARSER)
742 target_link_libraries(ArmnnConverter armnnTfLiteParser)
743 endif()
744
Nattapat Chaimanowong4fbae332019-02-14 15:28:02 +0000745 target_link_libraries(ArmnnConverter armnnSerializer)
746
747 target_link_libraries(ArmnnConverter armnn)
748 target_link_libraries(ArmnnConverter ${CMAKE_THREAD_LIBS_INIT})
749 target_link_libraries(ArmnnConverter
750 ${Boost_SYSTEM_LIBRARY}
751 ${Boost_FILESYSTEM_LIBRARY}
752 ${Boost_PROGRAM_OPTIONS_LIBRARY})
753 addDllCopyCommands(ArmnnConverter)
754endif()