You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

FindModule.cmake 902 B

4 years ago
4 years ago
4 years ago
1234567891011121314151617181920212223242526272829
  1. #[[
  2. module - the name of export imported target
  3. name - find the library name
  4. path - find the library path
  5. #]]
  6. function(find_module module name)
  7. if (TARGET ${module})
  8. return()
  9. endif()
  10. set(options)
  11. set(oneValueArgs)
  12. set(multiValueArgs)
  13. cmake_parse_arguments(MODULE "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
  14. set(path ${MODULE_UNPARSED_ARGUMENTS})
  15. find_library(${module}_LIBRARY_DIR NAMES ${name} NAMES_PER_DIR PATHS ${path}
  16. PATH_SUFFIXES lib
  17. )
  18. message(STATUS "find ${name} location ${${module}_LIBRARY_DIR}")
  19. if ("${${module}_LIBRARY_DIR}" STREQUAL "${module}_LIBRARY_DIR-NOTFOUND")
  20. message(FATAL_ERROR "${name} not found in ${path}")
  21. endif()
  22. add_library(${module} SHARED IMPORTED)
  23. set_target_properties(${module} PROPERTIES
  24. IMPORTED_LOCATION ${${module}_LIBRARY_DIR}
  25. )
  26. endfunction()

图引擎模块(GE)是MindSpore的一个子模块,其代码由C++实现,位于前端模块ME和底层硬件之间,起到承接作用。图引擎模块以ME下发的图作为输入,然后进行一系列的深度图优化操作,最后输出一张可以在底层硬件上高效运行的图。GE针对昇腾AI处理器的硬件结构特点,做了特定的优化工作,以此来充分发挥出昇腾AI处理器的强大算力。在进行模型训练/推理时,GE会被自动调用而用户并不感知。GE主要由GE API和GE Core两部分组成,详细的架构图如下所示