2023-04-25 23:16:45 +00:00
|
|
|
cmake_minimum_required(VERSION 3.16)
|
|
|
|
|
|
|
|
if(APPLE)
|
|
|
|
option(BUILD_UNIVERSAL "Build a Universal binary on macOS" OFF)
|
|
|
|
if(BUILD_UNIVERSAL)
|
|
|
|
# Build a Universal binary on macOS
|
|
|
|
# This requires that the found Qt library is compiled as Universal binaries.
|
|
|
|
set(CMAKE_OSX_ARCHITECTURES "arm64;x86_64" CACHE STRING "" FORCE)
|
|
|
|
else()
|
|
|
|
# Build for the host architecture on macOS
|
|
|
|
set(CMAKE_OSX_ARCHITECTURES "${CMAKE_HOST_SYSTEM_PROCESSOR}" CACHE STRING "" FORCE)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# Include the binary directory for the generated header file
|
|
|
|
include_directories("${CMAKE_CURRENT_BINARY_DIR}")
|
|
|
|
|
|
|
|
project(llmodel VERSION ${APP_VERSION} LANGUAGES CXX C)
|
|
|
|
|
|
|
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
|
|
|
|
|
|
|
set(LLAMA_BUILD_EXAMPLES ON CACHE BOOL "llama: build examples" FORCE)
|
|
|
|
set(BUILD_SHARED_LIBS ON FORCE)
|
|
|
|
|
|
|
|
set(CMAKE_VERBOSE_MAKEFILE ON)
|
|
|
|
if (GPT4ALL_AVX_ONLY)
|
|
|
|
set(LLAMA_AVX2 OFF CACHE BOOL "llama: enable AVX2" FORCE)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
add_subdirectory(llama.cpp)
|
|
|
|
|
|
|
|
add_library(llmodel
|
|
|
|
gptj.h gptj.cpp
|
|
|
|
llamamodel.h llamamodel.cpp
|
|
|
|
llama.cpp/examples/common.cpp
|
2023-04-27 02:05:56 +00:00
|
|
|
llmodel.h llmodel_c.h llmodel_c.cpp
|
2023-04-25 23:16:45 +00:00
|
|
|
utils.h utils.cpp
|
|
|
|
)
|
|
|
|
|
|
|
|
target_link_libraries(llmodel
|
|
|
|
PRIVATE llama)
|
|
|
|
|
|
|
|
set(COMPONENT_NAME_MAIN ${PROJECT_NAME})
|
|
|
|
set(CMAKE_INSTALL_PREFIX ${CMAKE_BINARY_DIR}/install)
|