2024-08-23 21:06:08 +00:00
|
|
|
{
|
|
|
|
config,
|
|
|
|
callPackages,
|
|
|
|
stdenv,
|
|
|
|
lib,
|
|
|
|
addDriverRunpath,
|
|
|
|
fetchFromGitHub,
|
|
|
|
protobuf,
|
|
|
|
protoc-gen-go,
|
|
|
|
protoc-gen-go-grpc,
|
|
|
|
grpc,
|
|
|
|
openssl,
|
|
|
|
llama-cpp,
|
2024-03-02 14:59:03 +00:00
|
|
|
# needed for audio-to-text
|
2024-08-23 21:06:08 +00:00
|
|
|
ffmpeg,
|
|
|
|
cmake,
|
|
|
|
pkg-config,
|
2024-10-03 05:48:55 +00:00
|
|
|
buildGo123Module,
|
2024-08-23 21:06:08 +00:00
|
|
|
makeWrapper,
|
|
|
|
ncurses,
|
|
|
|
which,
|
2024-07-26 21:02:28 +00:00
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
enable_upx ? true,
|
|
|
|
upx,
|
2024-03-02 14:59:03 +00:00
|
|
|
|
|
|
|
# apply feature parameter names according to
|
|
|
|
# https://github.com/NixOS/rfcs/pull/169
|
|
|
|
|
2024-03-23 18:22:17 +00:00
|
|
|
# CPU extensions
|
2024-08-23 21:06:08 +00:00
|
|
|
enable_avx ? true,
|
|
|
|
enable_avx2 ? true,
|
|
|
|
enable_avx512 ? stdenv.hostPlatform.avx512Support,
|
|
|
|
enable_f16c ? true,
|
|
|
|
enable_fma ? true,
|
|
|
|
|
|
|
|
with_openblas ? false,
|
|
|
|
openblas,
|
|
|
|
|
|
|
|
with_cublas ? config.cudaSupport,
|
|
|
|
cudaPackages,
|
|
|
|
|
|
|
|
with_clblas ? false,
|
|
|
|
clblast,
|
|
|
|
ocl-icd,
|
|
|
|
opencl-headers,
|
|
|
|
|
|
|
|
with_tinydream ? false, # do not compile with cublas
|
|
|
|
ncnn,
|
|
|
|
|
|
|
|
with_stablediffusion ? true,
|
|
|
|
opencv,
|
|
|
|
|
|
|
|
with_tts ? true,
|
|
|
|
onnxruntime,
|
|
|
|
sonic,
|
|
|
|
spdlog,
|
|
|
|
fmt,
|
|
|
|
espeak-ng,
|
|
|
|
piper-tts,
|
2024-03-02 14:59:03 +00:00
|
|
|
}:
|
|
|
|
let
|
2024-03-22 16:55:11 +00:00
|
|
|
BUILD_TYPE =
|
2024-08-23 21:06:08 +00:00
|
|
|
assert
|
|
|
|
(lib.count lib.id [
|
|
|
|
with_openblas
|
|
|
|
with_cublas
|
|
|
|
with_clblas
|
|
|
|
]) <= 1;
|
|
|
|
if with_openblas then
|
|
|
|
"openblas"
|
|
|
|
else if with_cublas then
|
|
|
|
"cublas"
|
|
|
|
else if with_clblas then
|
|
|
|
"clblas"
|
|
|
|
else
|
|
|
|
"";
|
2024-03-22 16:55:11 +00:00
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
inherit (cudaPackages)
|
|
|
|
libcublas
|
|
|
|
cuda_nvcc
|
|
|
|
cuda_cccl
|
|
|
|
cuda_cudart
|
|
|
|
libcufft
|
|
|
|
;
|
2024-03-22 16:55:11 +00:00
|
|
|
|
2024-04-26 17:40:55 +00:00
|
|
|
go-llama = effectiveStdenv.mkDerivation {
|
|
|
|
name = "go-llama";
|
2024-03-22 16:55:11 +00:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "go-skynet";
|
|
|
|
repo = "go-llama.cpp";
|
|
|
|
rev = "2b57a8ae43e4699d3dc5d1496a1ccd42922993be";
|
|
|
|
hash = "sha256-D6SEg5pPcswGyKAmF4QTJP6/Y1vjRr7m7REguag+too=";
|
|
|
|
fetchSubmodules = true;
|
|
|
|
};
|
|
|
|
buildFlags = [
|
|
|
|
"libbinding.a"
|
|
|
|
"BUILD_TYPE=${BUILD_TYPE}"
|
|
|
|
];
|
2024-04-09 19:34:01 +00:00
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
buildInputs =
|
|
|
|
[ ]
|
|
|
|
++ lib.optionals with_cublas [
|
|
|
|
cuda_cccl
|
|
|
|
cuda_cudart
|
|
|
|
libcublas
|
|
|
|
]
|
|
|
|
++ lib.optionals with_clblas [
|
|
|
|
clblast
|
|
|
|
ocl-icd
|
|
|
|
opencl-headers
|
|
|
|
]
|
2024-04-09 19:34:01 +00:00
|
|
|
++ lib.optionals with_openblas [ openblas.dev ];
|
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
nativeBuildInputs = [ cmake ] ++ lib.optionals with_cublas [ cuda_nvcc ];
|
2024-04-09 19:34:01 +00:00
|
|
|
|
2024-03-22 16:55:11 +00:00
|
|
|
dontUseCmakeConfigure = true;
|
2024-04-09 19:34:01 +00:00
|
|
|
|
2024-03-22 16:55:11 +00:00
|
|
|
installPhase = ''
|
|
|
|
mkdir $out
|
|
|
|
tar cf - --exclude=build --exclude=CMakeFiles --exclude="*.o" . \
|
|
|
|
| tar xf - -C $out
|
|
|
|
'';
|
2024-03-02 14:59:03 +00:00
|
|
|
};
|
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
llama-cpp-rpc =
|
|
|
|
(llama-cpp-grpc.overrideAttrs (prev: {
|
|
|
|
name = "llama-cpp-rpc";
|
|
|
|
cmakeFlags = prev.cmakeFlags ++ [
|
|
|
|
(lib.cmakeBool "GGML_AVX" false)
|
|
|
|
(lib.cmakeBool "GGML_AVX2" false)
|
|
|
|
(lib.cmakeBool "GGML_AVX512" false)
|
|
|
|
(lib.cmakeBool "GGML_FMA" false)
|
|
|
|
(lib.cmakeBool "GGML_F16C" false)
|
|
|
|
];
|
|
|
|
})).override
|
|
|
|
{
|
|
|
|
cudaSupport = false;
|
|
|
|
openclSupport = false;
|
|
|
|
blasSupport = false;
|
|
|
|
rpcSupport = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
llama-cpp-grpc =
|
|
|
|
(llama-cpp.overrideAttrs (
|
|
|
|
final: prev: {
|
|
|
|
name = "llama-cpp-grpc";
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "ggerganov";
|
|
|
|
repo = "llama.cpp";
|
2024-11-01 22:14:08 +00:00
|
|
|
rev = "45f097645efb11b6d09a5b4adbbfd7c312ac0126";
|
|
|
|
hash = "sha256-kZlH+Xpt38Ymc9TW7qRVyN7ISwed4ycA0M0808+UcXM=";
|
2024-08-23 21:06:08 +00:00
|
|
|
fetchSubmodules = true;
|
|
|
|
};
|
|
|
|
postPatch =
|
|
|
|
prev.postPatch
|
|
|
|
+ ''
|
|
|
|
cd examples
|
|
|
|
cp -r --no-preserve=mode ${src}/backend/cpp/llama grpc-server
|
|
|
|
cp llava/clip.* llava/llava.* grpc-server
|
|
|
|
printf "\nadd_subdirectory(grpc-server)" >> CMakeLists.txt
|
|
|
|
|
|
|
|
cp ${src}/backend/backend.proto grpc-server
|
|
|
|
sed -i grpc-server/CMakeLists.txt \
|
|
|
|
-e '/get_filename_component/ s;[.\/]*backend/;;' \
|
|
|
|
-e '$a\install(TARGETS ''${TARGET} RUNTIME)'
|
|
|
|
cd ..
|
|
|
|
'';
|
|
|
|
cmakeFlags = prev.cmakeFlags ++ [
|
|
|
|
(lib.cmakeBool "BUILD_SHARED_LIBS" false)
|
|
|
|
(lib.cmakeBool "GGML_AVX" enable_avx)
|
|
|
|
(lib.cmakeBool "GGML_AVX2" enable_avx2)
|
|
|
|
(lib.cmakeBool "GGML_AVX512" enable_avx512)
|
|
|
|
(lib.cmakeBool "GGML_FMA" enable_fma)
|
|
|
|
(lib.cmakeBool "GGML_F16C" enable_f16c)
|
|
|
|
];
|
|
|
|
buildInputs = prev.buildInputs ++ [
|
|
|
|
protobuf # provides also abseil_cpp as propagated build input
|
|
|
|
grpc
|
|
|
|
openssl
|
|
|
|
];
|
|
|
|
}
|
|
|
|
)).override
|
|
|
|
{
|
|
|
|
cudaSupport = with_cublas;
|
|
|
|
rocmSupport = false;
|
|
|
|
openclSupport = with_clblas;
|
|
|
|
blasSupport = with_openblas;
|
|
|
|
};
|
2024-03-02 14:59:03 +00:00
|
|
|
|
2024-04-01 11:32:21 +00:00
|
|
|
espeak-ng' = espeak-ng.overrideAttrs (self: {
|
|
|
|
name = "espeak-ng'";
|
|
|
|
inherit (go-piper) src;
|
2024-08-02 12:53:11 +00:00
|
|
|
sourceRoot = "${go-piper.src.name}/espeak";
|
2024-04-01 11:32:21 +00:00
|
|
|
patches = [ ];
|
|
|
|
nativeBuildInputs = [ cmake ];
|
|
|
|
cmakeFlags = (self.cmakeFlags or [ ]) ++ [
|
|
|
|
(lib.cmakeBool "BUILD_SHARED_LIBS" true)
|
|
|
|
(lib.cmakeBool "USE_ASYNC" false)
|
|
|
|
(lib.cmakeBool "USE_MBROLA" false)
|
|
|
|
(lib.cmakeBool "USE_LIBPCAUDIO" false)
|
|
|
|
(lib.cmakeBool "USE_KLATT" false)
|
|
|
|
(lib.cmakeBool "USE_SPEECHPLAYER" false)
|
|
|
|
(lib.cmakeBool "USE_LIBSONIC" false)
|
|
|
|
(lib.cmakeBool "CMAKE_POSITION_INDEPENDENT_CODE" true)
|
|
|
|
];
|
|
|
|
preConfigure = null;
|
|
|
|
postInstall = null;
|
|
|
|
});
|
|
|
|
|
|
|
|
piper-phonemize = stdenv.mkDerivation {
|
|
|
|
name = "piper-phonemize";
|
|
|
|
inherit (go-piper) src;
|
2024-08-02 12:53:11 +00:00
|
|
|
sourceRoot = "${go-piper.src.name}/piper-phonemize";
|
2024-08-23 21:06:08 +00:00
|
|
|
buildInputs = [
|
|
|
|
espeak-ng'
|
|
|
|
onnxruntime
|
|
|
|
];
|
|
|
|
nativeBuildInputs = [
|
|
|
|
cmake
|
|
|
|
pkg-config
|
|
|
|
];
|
2024-04-01 11:32:21 +00:00
|
|
|
cmakeFlags = [
|
|
|
|
(lib.cmakeFeature "ONNXRUNTIME_DIR" "${onnxruntime.dev}")
|
|
|
|
(lib.cmakeFeature "ESPEAK_NG_DIR" "${espeak-ng'}")
|
|
|
|
];
|
|
|
|
passthru.espeak-ng = espeak-ng';
|
|
|
|
};
|
|
|
|
|
|
|
|
piper-tts' = (piper-tts.override { inherit piper-phonemize; }).overrideAttrs (self: {
|
|
|
|
name = "piper-tts'";
|
|
|
|
inherit (go-piper) src;
|
2024-08-02 12:53:11 +00:00
|
|
|
sourceRoot = "${go-piper.src.name}/piper";
|
2024-04-01 11:32:21 +00:00
|
|
|
installPhase = null;
|
|
|
|
postInstall = ''
|
|
|
|
cp CMakeFiles/piper.dir/src/cpp/piper.cpp.o $out/piper.o
|
|
|
|
cd $out
|
|
|
|
mkdir bin lib
|
|
|
|
mv lib*so* lib/
|
|
|
|
mv piper piper_phonemize bin/
|
|
|
|
rm -rf cmake pkgconfig espeak-ng-data *.ort
|
|
|
|
'';
|
|
|
|
});
|
|
|
|
|
2024-03-22 16:55:11 +00:00
|
|
|
go-piper = stdenv.mkDerivation {
|
|
|
|
name = "go-piper";
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "mudler";
|
|
|
|
repo = "go-piper";
|
|
|
|
rev = "9d0100873a7dbb0824dfea40e8cec70a1b110759";
|
|
|
|
hash = "sha256-Yv9LQkWwGpYdOS0FvtP0vZ0tRyBAx27sdmziBR4U4n8=";
|
|
|
|
fetchSubmodules = true;
|
|
|
|
};
|
2024-04-01 11:32:21 +00:00
|
|
|
postUnpack = ''
|
|
|
|
cp -r --no-preserve=mode ${piper-tts'}/* source
|
|
|
|
'';
|
|
|
|
postPatch = ''
|
2024-03-22 16:55:11 +00:00
|
|
|
sed -i Makefile \
|
2024-04-01 11:32:21 +00:00
|
|
|
-e '/CXXFLAGS *= / s;$; -DSPDLOG_FMT_EXTERNAL=1;'
|
2024-03-22 16:55:11 +00:00
|
|
|
'';
|
|
|
|
buildFlags = [ "libpiper_binding.a" ];
|
2024-08-23 21:06:08 +00:00
|
|
|
buildInputs = [
|
|
|
|
piper-tts'
|
|
|
|
espeak-ng'
|
|
|
|
piper-phonemize
|
|
|
|
sonic
|
|
|
|
fmt
|
|
|
|
spdlog
|
|
|
|
onnxruntime
|
|
|
|
];
|
2024-03-22 16:55:11 +00:00
|
|
|
installPhase = ''
|
|
|
|
cp -r --no-preserve=mode $src $out
|
2024-04-01 11:32:21 +00:00
|
|
|
mkdir -p $out/piper-phonemize/pi
|
|
|
|
cp -r --no-preserve=mode ${piper-phonemize}/share $out/piper-phonemize/pi
|
|
|
|
cp *.a $out
|
2024-03-22 16:55:11 +00:00
|
|
|
'';
|
2024-03-02 14:59:03 +00:00
|
|
|
};
|
|
|
|
|
2024-03-22 16:55:11 +00:00
|
|
|
go-rwkv = stdenv.mkDerivation {
|
|
|
|
name = "go-rwkv";
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "donomii";
|
|
|
|
repo = "go-rwkv.cpp";
|
|
|
|
rev = "661e7ae26d442f5cfebd2a0881b44e8c55949ec6";
|
|
|
|
hash = "sha256-byTNZQSnt7qpBMng3ANJmpISh3GJiz+F15UqfXaz6nQ=";
|
|
|
|
fetchSubmodules = true;
|
|
|
|
};
|
|
|
|
buildFlags = [ "librwkv.a" ];
|
|
|
|
dontUseCmakeConfigure = true;
|
|
|
|
nativeBuildInputs = [ cmake ];
|
|
|
|
installPhase = ''
|
|
|
|
cp -r --no-preserve=mode $src $out
|
|
|
|
cp *.a $out
|
|
|
|
'';
|
2024-03-02 14:59:03 +00:00
|
|
|
};
|
|
|
|
|
2024-03-23 11:44:52 +00:00
|
|
|
# try to merge with openai-whisper-cpp in future
|
|
|
|
whisper-cpp = effectiveStdenv.mkDerivation {
|
|
|
|
name = "whisper-cpp";
|
2024-03-22 16:55:11 +00:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "ggerganov";
|
|
|
|
repo = "whisper.cpp";
|
2024-11-01 22:14:08 +00:00
|
|
|
rev = "a5abfe6a90495f7bf19fe70d016ecc255e97359c";
|
|
|
|
hash = "sha256-XSPO1Wtqlq1krwAH98jMIGWa1Npmnjd5oCJ0lc3D3H4=";
|
2024-03-22 16:55:11 +00:00
|
|
|
};
|
2024-04-09 19:34:01 +00:00
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
nativeBuildInputs = [
|
|
|
|
cmake
|
|
|
|
pkg-config
|
|
|
|
] ++ lib.optionals with_cublas [ cuda_nvcc ];
|
|
|
|
|
|
|
|
buildInputs =
|
|
|
|
[ ]
|
|
|
|
++ lib.optionals with_cublas [
|
|
|
|
cuda_cccl
|
|
|
|
cuda_cudart
|
|
|
|
libcublas
|
|
|
|
libcufft
|
|
|
|
]
|
|
|
|
++ lib.optionals with_clblas [
|
|
|
|
clblast
|
|
|
|
ocl-icd
|
|
|
|
opencl-headers
|
|
|
|
]
|
2024-04-09 19:34:01 +00:00
|
|
|
++ lib.optionals with_openblas [ openblas.dev ];
|
|
|
|
|
2024-03-23 11:44:52 +00:00
|
|
|
cmakeFlags = [
|
2024-04-09 19:34:01 +00:00
|
|
|
(lib.cmakeBool "WHISPER_CUDA" with_cublas)
|
2024-03-23 11:44:52 +00:00
|
|
|
(lib.cmakeBool "WHISPER_CLBLAST" with_clblas)
|
|
|
|
(lib.cmakeBool "WHISPER_OPENBLAS" with_openblas)
|
2024-03-23 18:22:17 +00:00
|
|
|
(lib.cmakeBool "WHISPER_NO_AVX" (!enable_avx))
|
|
|
|
(lib.cmakeBool "WHISPER_NO_AVX2" (!enable_avx2))
|
|
|
|
(lib.cmakeBool "WHISPER_NO_FMA" (!enable_fma))
|
|
|
|
(lib.cmakeBool "WHISPER_NO_F16C" (!enable_f16c))
|
2024-03-23 11:44:52 +00:00
|
|
|
(lib.cmakeBool "BUILD_SHARED_LIBS" false)
|
|
|
|
];
|
|
|
|
postInstall = ''
|
|
|
|
install -Dt $out/bin bin/*
|
2024-03-22 16:55:11 +00:00
|
|
|
'';
|
2024-03-02 14:59:03 +00:00
|
|
|
};
|
|
|
|
|
2024-03-22 16:55:11 +00:00
|
|
|
go-bert = stdenv.mkDerivation {
|
|
|
|
name = "go-bert";
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "go-skynet";
|
|
|
|
repo = "go-bert.cpp";
|
2024-06-14 19:20:37 +00:00
|
|
|
rev = "710044b124545415f555e4260d16b146c725a6e4";
|
|
|
|
hash = "sha256-UNrs3unYjvSzCVaVISFFBDD+s37lmN6/7ajmGNcYgrU=";
|
2024-03-22 16:55:11 +00:00
|
|
|
fetchSubmodules = true;
|
|
|
|
};
|
|
|
|
buildFlags = [ "libgobert.a" ];
|
|
|
|
dontUseCmakeConfigure = true;
|
|
|
|
nativeBuildInputs = [ cmake ];
|
|
|
|
env.NIX_CFLAGS_COMPILE = "-Wformat";
|
|
|
|
installPhase = ''
|
|
|
|
cp -r --no-preserve=mode $src $out
|
|
|
|
cp *.a $out
|
|
|
|
'';
|
2024-03-02 14:59:03 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
go-stable-diffusion = stdenv.mkDerivation {
|
2024-03-22 16:55:11 +00:00
|
|
|
name = "go-stable-diffusion";
|
2024-03-02 14:59:03 +00:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "mudler";
|
|
|
|
repo = "go-stable-diffusion";
|
2024-05-06 05:46:03 +00:00
|
|
|
rev = "4a3cd6aeae6f66ee57eae9a0075f8c58c3a6a38f";
|
|
|
|
hash = "sha256-KXUvMP6cDyWib4rG0RmVRm3pgrdsfKXaH3k0v5/mTe8=";
|
2024-03-02 14:59:03 +00:00
|
|
|
fetchSubmodules = true;
|
|
|
|
};
|
|
|
|
buildFlags = [ "libstablediffusion.a" ];
|
|
|
|
dontUseCmakeConfigure = true;
|
|
|
|
nativeBuildInputs = [ cmake ];
|
|
|
|
buildInputs = [ opencv ];
|
|
|
|
env.NIX_CFLAGS_COMPILE = " -isystem ${opencv}/include/opencv4";
|
|
|
|
installPhase = ''
|
2024-03-22 16:55:11 +00:00
|
|
|
mkdir $out
|
|
|
|
tar cf - --exclude=CMakeFiles --exclude="*.o" --exclude="*.so" --exclude="*.so.*" . \
|
|
|
|
| tar xf - -C $out
|
2024-03-02 14:59:03 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-03-23 19:24:55 +00:00
|
|
|
go-tiny-dream-ncnn = ncnn.overrideAttrs (self: {
|
|
|
|
name = "go-tiny-dream-ncnn";
|
|
|
|
inherit (go-tiny-dream) src;
|
2024-08-02 12:53:11 +00:00
|
|
|
sourceRoot = "${go-tiny-dream.src.name}/ncnn";
|
2024-03-23 19:24:55 +00:00
|
|
|
cmakeFlags = self.cmakeFlags ++ [
|
|
|
|
(lib.cmakeBool "NCNN_SHARED_LIB" false)
|
|
|
|
(lib.cmakeBool "NCNN_OPENMP" false)
|
|
|
|
(lib.cmakeBool "NCNN_VULKAN" false)
|
|
|
|
(lib.cmakeBool "NCNN_AVX" enable_avx)
|
|
|
|
(lib.cmakeBool "NCNN_AVX2" enable_avx2)
|
|
|
|
(lib.cmakeBool "NCNN_AVX512" enable_avx512)
|
|
|
|
(lib.cmakeBool "NCNN_FMA" enable_fma)
|
|
|
|
(lib.cmakeBool "NCNN_F16C" enable_f16c)
|
|
|
|
];
|
|
|
|
});
|
|
|
|
|
2024-04-09 19:34:01 +00:00
|
|
|
go-tiny-dream = effectiveStdenv.mkDerivation {
|
2024-03-22 16:55:11 +00:00
|
|
|
name = "go-tiny-dream";
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "M0Rf30";
|
|
|
|
repo = "go-tiny-dream";
|
2024-05-06 05:46:03 +00:00
|
|
|
rev = "c04fa463ace9d9a6464313aa5f9cd0f953b6c057";
|
|
|
|
hash = "sha256-uow3vbAI4F/fTGjYOKOLqTpKq7NgGYSZhGlEhn7h6s0=";
|
2024-03-22 16:55:11 +00:00
|
|
|
fetchSubmodules = true;
|
|
|
|
};
|
2024-03-23 19:24:55 +00:00
|
|
|
postUnpack = ''
|
|
|
|
rm -rf source/ncnn
|
2024-04-09 19:34:01 +00:00
|
|
|
mkdir -p source/ncnn/build/src
|
|
|
|
cp -r --no-preserve=mode ${go-tiny-dream-ncnn}/lib/. ${go-tiny-dream-ncnn}/include/. source/ncnn/build/src
|
2024-03-22 16:55:11 +00:00
|
|
|
'';
|
|
|
|
buildFlags = [ "libtinydream.a" ];
|
|
|
|
installPhase = ''
|
|
|
|
mkdir $out
|
2024-03-23 19:24:55 +00:00
|
|
|
tar cf - --exclude="*.o" . \
|
2024-03-22 16:55:11 +00:00
|
|
|
| tar xf - -C $out
|
|
|
|
'';
|
|
|
|
meta.broken = lib.versionOlder go-tiny-dream.stdenv.cc.version "13";
|
2024-03-02 14:59:03 +00:00
|
|
|
};
|
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
GO_TAGS =
|
|
|
|
lib.optional with_tinydream "tinydream"
|
2024-03-02 14:59:03 +00:00
|
|
|
++ lib.optional with_tts "tts"
|
|
|
|
++ lib.optional with_stablediffusion "stablediffusion";
|
|
|
|
|
2024-03-22 16:55:11 +00:00
|
|
|
effectiveStdenv =
|
2024-03-02 14:59:03 +00:00
|
|
|
if with_cublas then
|
2024-08-23 21:06:08 +00:00
|
|
|
# It's necessary to consistently use backendStdenv when building with CUDA support,
|
|
|
|
# otherwise we get libstdc++ errors downstream.
|
2024-03-22 16:55:11 +00:00
|
|
|
cudaPackages.backendStdenv
|
2024-03-02 14:59:03 +00:00
|
|
|
else
|
2024-03-22 16:55:11 +00:00
|
|
|
stdenv;
|
2024-03-02 14:59:03 +00:00
|
|
|
|
2024-03-22 16:55:11 +00:00
|
|
|
pname = "local-ai";
|
2024-11-01 22:14:08 +00:00
|
|
|
version = "2.22.1";
|
2024-03-22 16:55:11 +00:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "go-skynet";
|
|
|
|
repo = "LocalAI";
|
|
|
|
rev = "v${version}";
|
2024-11-01 22:14:08 +00:00
|
|
|
hash = "sha256-vIjjGs3IIxnWlLsybQNWJHbWNnoInVh+otJ7vNODcik=";
|
2024-03-22 16:55:11 +00:00
|
|
|
};
|
2024-03-02 14:59:03 +00:00
|
|
|
|
2024-07-26 21:02:28 +00:00
|
|
|
prepare-sources =
|
|
|
|
let
|
|
|
|
cp = "cp -r --no-preserve=mode,ownership";
|
|
|
|
in
|
|
|
|
''
|
|
|
|
mkdir sources
|
|
|
|
${cp} ${go-llama} sources/go-llama.cpp
|
|
|
|
${cp} ${if with_tts then go-piper else go-piper.src} sources/go-piper
|
|
|
|
${cp} ${go-rwkv} sources/go-rwkv.cpp
|
|
|
|
${cp} ${whisper-cpp.src} sources/whisper.cpp
|
|
|
|
cp ${whisper-cpp}/lib/lib*.a sources/whisper.cpp
|
|
|
|
${cp} ${go-bert} sources/go-bert.cpp
|
2024-08-23 21:06:08 +00:00
|
|
|
${cp} ${
|
|
|
|
if with_stablediffusion then go-stable-diffusion else go-stable-diffusion.src
|
|
|
|
} sources/go-stable-diffusion
|
2024-07-26 21:02:28 +00:00
|
|
|
${cp} ${if with_tinydream then go-tiny-dream else go-tiny-dream.src} sources/go-tiny-dream
|
|
|
|
'';
|
|
|
|
|
2024-10-03 05:48:55 +00:00
|
|
|
self = buildGo123Module.override { stdenv = effectiveStdenv; } {
|
2024-03-22 16:55:11 +00:00
|
|
|
inherit pname version src;
|
2024-03-02 14:59:03 +00:00
|
|
|
|
2024-10-03 05:48:55 +00:00
|
|
|
vendorHash = "sha256-tb2nVUCUdaOWHpJz4zMqgfJ4PYUqGwV/0lj76n36sUg=";
|
2024-03-02 14:59:03 +00:00
|
|
|
|
2024-03-22 16:55:11 +00:00
|
|
|
env.NIX_CFLAGS_COMPILE = lib.optionalString with_stablediffusion " -isystem ${opencv}/include/opencv4";
|
2024-03-02 14:59:03 +00:00
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
postPatch =
|
|
|
|
''
|
|
|
|
sed -i Makefile \
|
|
|
|
-e '/mod download/ d' \
|
|
|
|
-e '/^ALL_GRPC_BACKENDS+=backend-assets\/grpc\/llama-cpp-fallback/ d' \
|
|
|
|
-e '/^ALL_GRPC_BACKENDS+=backend-assets\/grpc\/llama-cpp-avx/ d' \
|
|
|
|
-e '/^ALL_GRPC_BACKENDS+=backend-assets\/grpc\/llama-cpp-cuda/ d' \
|
2024-03-02 14:59:03 +00:00
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
''
|
|
|
|
+ lib.optionalString with_cublas ''
|
|
|
|
sed -i Makefile \
|
|
|
|
-e '/^CGO_LDFLAGS_WHISPER?=/ s;$;-L${libcufft}/lib -L${cuda_cudart}/lib;'
|
|
|
|
'';
|
2024-07-26 21:02:28 +00:00
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
postConfigure =
|
|
|
|
prepare-sources
|
|
|
|
+ ''
|
|
|
|
shopt -s extglob
|
|
|
|
mkdir -p backend-assets/grpc
|
|
|
|
cp ${llama-cpp-grpc}/bin/grpc-server backend-assets/grpc/llama-cpp-avx2
|
|
|
|
cp ${llama-cpp-rpc}/bin/grpc-server backend-assets/grpc/llama-cpp-grpc
|
2024-06-14 19:20:37 +00:00
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
mkdir -p backend/cpp/llama/llama.cpp
|
2024-07-26 21:02:28 +00:00
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
mkdir -p backend-assets/util
|
|
|
|
cp ${llama-cpp-rpc}/bin/llama-rpc-server backend-assets/util/llama-cpp-rpc-server
|
2024-07-26 21:02:28 +00:00
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
# avoid rebuild of prebuilt make targets
|
|
|
|
touch backend-assets/grpc/* backend-assets/util/* sources/**/lib*.a
|
|
|
|
'';
|
2024-03-02 14:59:03 +00:00
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
buildInputs =
|
|
|
|
[ ]
|
|
|
|
++ lib.optionals with_cublas [
|
|
|
|
cuda_cudart
|
|
|
|
libcublas
|
|
|
|
libcufft
|
|
|
|
]
|
|
|
|
++ lib.optionals with_clblas [
|
|
|
|
clblast
|
|
|
|
ocl-icd
|
|
|
|
opencl-headers
|
|
|
|
]
|
2024-04-09 19:34:01 +00:00
|
|
|
++ lib.optionals with_openblas [ openblas.dev ]
|
|
|
|
++ lib.optionals with_stablediffusion go-stable-diffusion.buildInputs
|
|
|
|
++ lib.optionals with_tts go-piper.buildInputs;
|
2024-03-22 16:55:11 +00:00
|
|
|
|
2024-04-26 17:40:55 +00:00
|
|
|
nativeBuildInputs = [
|
|
|
|
protobuf
|
|
|
|
protoc-gen-go
|
|
|
|
protoc-gen-go-grpc
|
|
|
|
makeWrapper
|
2024-06-22 08:09:54 +00:00
|
|
|
ncurses # tput
|
2024-07-26 21:02:28 +00:00
|
|
|
which
|
2024-08-23 21:06:08 +00:00
|
|
|
] ++ lib.optional enable_upx upx ++ lib.optionals with_cublas [ cuda_nvcc ];
|
2024-03-22 16:55:11 +00:00
|
|
|
|
|
|
|
enableParallelBuilding = false;
|
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
modBuildPhase =
|
|
|
|
prepare-sources
|
|
|
|
+ ''
|
|
|
|
make protogen-go
|
|
|
|
go mod tidy -v
|
|
|
|
'';
|
2024-03-02 14:59:03 +00:00
|
|
|
|
|
|
|
proxyVendor = true;
|
|
|
|
|
2024-03-24 07:09:16 +00:00
|
|
|
# should be passed as makeFlags, but build system failes with strings
|
|
|
|
# containing spaces
|
2024-03-22 16:55:11 +00:00
|
|
|
env.GO_TAGS = builtins.concatStringsSep " " GO_TAGS;
|
|
|
|
|
2024-08-23 21:06:08 +00:00
|
|
|
makeFlags =
|
|
|
|
[
|
|
|
|
"VERSION=v${version}"
|
|
|
|
"BUILD_TYPE=${BUILD_TYPE}"
|
|
|
|
]
|
|
|
|
++ lib.optional with_cublas "CUDA_LIBPATH=${cuda_cudart}/lib"
|
|
|
|
++ lib.optional with_tts "PIPER_CGO_CXXFLAGS=-DSPDLOG_FMT_EXTERNAL=1";
|
2024-03-22 16:55:11 +00:00
|
|
|
|
|
|
|
buildPhase = ''
|
|
|
|
runHook preBuild
|
|
|
|
|
|
|
|
local flagsArray=(
|
|
|
|
''${enableParallelBuilding:+-j''${NIX_BUILD_CORES}}
|
|
|
|
SHELL=$SHELL
|
|
|
|
)
|
2024-06-09 10:24:21 +00:00
|
|
|
concatTo flagsArray makeFlags makeFlagsArray buildFlags buildFlagsArray
|
2024-03-22 16:55:11 +00:00
|
|
|
echoCmd 'build flags' "''${flagsArray[@]}"
|
|
|
|
make build "''${flagsArray[@]}"
|
|
|
|
unset flagsArray
|
|
|
|
|
|
|
|
runHook postBuild
|
|
|
|
'';
|
2024-03-02 14:59:03 +00:00
|
|
|
|
|
|
|
installPhase = ''
|
2024-03-22 16:55:11 +00:00
|
|
|
runHook preInstall
|
|
|
|
|
2024-03-02 14:59:03 +00:00
|
|
|
install -Dt $out/bin ${pname}
|
|
|
|
|
2024-03-22 16:55:11 +00:00
|
|
|
runHook postInstall
|
|
|
|
'';
|
2024-03-02 14:59:03 +00:00
|
|
|
|
|
|
|
# patching rpath with patchelf doens't work. The execuable
|
|
|
|
# raises an segmentation fault
|
2024-04-07 19:52:54 +00:00
|
|
|
postFixup =
|
|
|
|
let
|
2024-08-23 21:06:08 +00:00
|
|
|
LD_LIBRARY_PATH =
|
|
|
|
[ ]
|
2024-07-03 18:14:35 +00:00
|
|
|
++ lib.optionals with_cublas [
|
2024-08-23 21:06:08 +00:00
|
|
|
# driverLink has to be first to avoid loading the stub version of libcuda.so
|
|
|
|
# https://github.com/NixOS/nixpkgs/issues/320145#issuecomment-2190319327
|
|
|
|
addDriverRunpath.driverLink
|
|
|
|
(lib.getLib libcublas)
|
|
|
|
cuda_cudart
|
|
|
|
]
|
|
|
|
++ lib.optionals with_clblas [
|
|
|
|
clblast
|
|
|
|
ocl-icd
|
|
|
|
]
|
2024-04-07 19:52:54 +00:00
|
|
|
++ lib.optionals with_openblas [ openblas ]
|
2024-07-26 21:02:28 +00:00
|
|
|
++ lib.optionals with_tts [ piper-phonemize ]
|
2024-08-23 21:06:08 +00:00
|
|
|
++ lib.optionals (with_tts && enable_upx) [
|
|
|
|
fmt
|
|
|
|
spdlog
|
|
|
|
];
|
2024-04-07 19:52:54 +00:00
|
|
|
in
|
|
|
|
''
|
|
|
|
wrapProgram $out/bin/${pname} \
|
|
|
|
--prefix LD_LIBRARY_PATH : "${lib.makeLibraryPath LD_LIBRARY_PATH}" \
|
|
|
|
--prefix PATH : "${ffmpeg}/bin"
|
|
|
|
'';
|
2024-03-02 14:59:03 +00:00
|
|
|
|
2024-03-22 16:55:11 +00:00
|
|
|
passthru.local-packages = {
|
|
|
|
inherit
|
2024-08-23 21:06:08 +00:00
|
|
|
go-tiny-dream
|
|
|
|
go-rwkv
|
|
|
|
go-bert
|
|
|
|
go-llama
|
|
|
|
go-piper
|
|
|
|
llama-cpp-grpc
|
|
|
|
whisper-cpp
|
|
|
|
go-tiny-dream-ncnn
|
|
|
|
espeak-ng'
|
|
|
|
piper-phonemize
|
|
|
|
piper-tts'
|
|
|
|
llama-cpp-rpc
|
|
|
|
;
|
2024-03-22 16:55:11 +00:00
|
|
|
};
|
2024-03-02 14:59:03 +00:00
|
|
|
|
|
|
|
passthru.features = {
|
|
|
|
inherit
|
2024-08-23 21:06:08 +00:00
|
|
|
with_cublas
|
|
|
|
with_openblas
|
|
|
|
with_tts
|
|
|
|
with_stablediffusion
|
|
|
|
with_tinydream
|
|
|
|
with_clblas
|
|
|
|
;
|
2024-03-02 14:59:03 +00:00
|
|
|
};
|
|
|
|
|
2024-04-09 19:34:01 +00:00
|
|
|
passthru.tests = callPackages ./tests.nix { inherit self; };
|
2024-04-26 17:40:55 +00:00
|
|
|
passthru.lib = callPackages ./lib.nix { };
|
2024-03-02 14:59:03 +00:00
|
|
|
|
|
|
|
meta = with lib; {
|
|
|
|
description = "OpenAI alternative to run local LLMs, image and audio generation";
|
|
|
|
homepage = "https://localai.io";
|
|
|
|
license = licenses.mit;
|
2024-08-23 21:06:08 +00:00
|
|
|
maintainers = with maintainers; [
|
|
|
|
onny
|
|
|
|
ck3d
|
|
|
|
];
|
2024-03-02 14:59:03 +00:00
|
|
|
platforms = platforms.linux;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
in
|
|
|
|
self
|