|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [ -z "$2" ]; then |
|
echo "usage: $0 <output-dir> <mnt-dir>" |
|
exit 1 |
|
fi |
|
|
|
mkdir -p "$1" |
|
mkdir -p "$2" |
|
|
|
OUT=$(realpath "$1") |
|
MNT=$(realpath "$2") |
|
|
|
rm -v $OUT/*.log |
|
rm -v $OUT/*.exit |
|
rm -v $OUT/*.md |
|
|
|
sd=`dirname $0` |
|
cd $sd/../ |
|
SRC=`pwd` |
|
|
|
|
|
|
|
|
|
function gg_wget { |
|
local out=$1 |
|
local url=$2 |
|
|
|
local cwd=`pwd` |
|
|
|
mkdir -p $out |
|
cd $out |
|
|
|
|
|
wget -nv -N $url |
|
|
|
cd $cwd |
|
} |
|
|
|
function gg_printf { |
|
printf -- "$@" >> $OUT/README.md |
|
} |
|
|
|
function gg_run { |
|
ci=$1 |
|
|
|
set -o pipefail |
|
set -x |
|
|
|
gg_run_$ci | tee $OUT/$ci.log |
|
cur=$? |
|
echo "$cur" > $OUT/$ci.exit |
|
|
|
set +x |
|
set +o pipefail |
|
|
|
gg_sum_$ci |
|
|
|
ret=$((ret | cur)) |
|
} |
|
|
|
|
|
|
|
|
|
|
|
function gg_run_ctest_debug { |
|
cd ${SRC} |
|
|
|
rm -rf build-ci-debug && mkdir build-ci-debug && cd build-ci-debug |
|
|
|
set -e |
|
|
|
(time cmake -DCMAKE_BUILD_TYPE=Debug .. ) 2>&1 | tee -a $OUT/${ci}-cmake.log |
|
(time make -j ) 2>&1 | tee -a $OUT/${ci}-make.log |
|
|
|
(time ctest --output-on-failure -E test-opt ) 2>&1 | tee -a $OUT/${ci}-ctest.log |
|
|
|
set +e |
|
} |
|
|
|
function gg_sum_ctest_debug { |
|
gg_printf '### %s\n\n' "${ci}" |
|
|
|
gg_printf 'Runs ctest in debug mode\n' |
|
gg_printf '- status: %s\n' "$(cat $OUT/${ci}.exit)" |
|
gg_printf '```\n' |
|
gg_printf '%s\n' "$(cat $OUT/${ci}-ctest.log)" |
|
gg_printf '```\n' |
|
gg_printf '\n' |
|
} |
|
|
|
|
|
|
|
function gg_run_ctest_release { |
|
cd ${SRC} |
|
|
|
rm -rf build-ci-release && mkdir build-ci-release && cd build-ci-release |
|
|
|
set -e |
|
|
|
(time cmake -DCMAKE_BUILD_TYPE=Release .. ) 2>&1 | tee -a $OUT/${ci}-cmake.log |
|
(time make -j ) 2>&1 | tee -a $OUT/${ci}-make.log |
|
|
|
if [ -z $GG_BUILD_LOW_PERF ]; then |
|
(time ctest --output-on-failure ) 2>&1 | tee -a $OUT/${ci}-ctest.log |
|
else |
|
(time ctest --output-on-failure -E test-opt ) 2>&1 | tee -a $OUT/${ci}-ctest.log |
|
fi |
|
|
|
set +e |
|
} |
|
|
|
function gg_sum_ctest_release { |
|
gg_printf '### %s\n\n' "${ci}" |
|
|
|
gg_printf 'Runs ctest in release mode\n' |
|
gg_printf '- status: %s\n' "$(cat $OUT/${ci}.exit)" |
|
gg_printf '```\n' |
|
gg_printf '%s\n' "$(cat $OUT/${ci}-ctest.log)" |
|
gg_printf '```\n' |
|
} |
|
|
|
|
|
|
|
function gg_run_gpt_2 { |
|
cd ${SRC} |
|
|
|
gg_wget models-mnt/gpt-2 https://huggingface.co/ggerganov/ggml/resolve/main/ggml-model-gpt-2-117M.bin |
|
|
|
cd build-ci-release |
|
|
|
set -e |
|
|
|
model="../models-mnt/gpt-2/ggml-model-gpt-2-117M.bin" |
|
prompts="../examples/prompts/gpt-2.txt" |
|
|
|
(time ./bin/gpt-2 --model ${model} -s 1234 -n 64 -tt ${prompts} ) 2>&1 | tee -a $OUT/${ci}-tg.log |
|
(time ./bin/gpt-2 --model ${model} -s 1234 -n 64 -p "I believe the meaning of life is") 2>&1 | tee -a $OUT/${ci}-tg.log |
|
|
|
(time ./bin/gpt-2-batched --model ${model} -s 1234 -n 64 -np 8 -p "I believe the meaning of life is") 2>&1 | tee -a $OUT/${ci}-tg.log |
|
|
|
set +e |
|
} |
|
|
|
function gg_sum_gpt_2 { |
|
gg_printf '### %s\n\n' "${ci}" |
|
|
|
gg_printf 'Runs short GPT-2 text generation\n' |
|
gg_printf '- status: %s\n' "$(cat $OUT/${ci}.exit)" |
|
gg_printf '```\n' |
|
gg_printf '%s\n' "$(cat $OUT/${ci}-tg.log)" |
|
gg_printf '```\n' |
|
} |
|
|
|
|
|
|
|
function gg_run_mnist { |
|
cd ${SRC} |
|
|
|
cd build-ci-release |
|
|
|
set -e |
|
|
|
mkdir -p models/mnist |
|
python3 ../examples/mnist/convert-h5-to-ggml.py ../examples/mnist/models/mnist/mnist_model.state_dict |
|
|
|
model_f32="./models/mnist/ggml-model-f32.bin" |
|
samples="../examples/mnist/models/mnist/t10k-images.idx3-ubyte" |
|
|
|
|
|
|
|
(time ./bin/mnist ${model_f32} ${samples} ) 2>&1 | tee -a $OUT/${ci}-mnist.log |
|
(time ./bin/mnist-cpu ./mnist.ggml ${samples} ) 2>&1 | tee -a $OUT/${ci}-mnist.log |
|
|
|
set +e |
|
} |
|
|
|
function gg_sum_mnist { |
|
gg_printf '### %s\n\n' "${ci}" |
|
|
|
gg_printf 'MNIST\n' |
|
gg_printf '- status: %s\n' "$(cat $OUT/${ci}.exit)" |
|
gg_printf '```\n' |
|
gg_printf '%s\n' "$(cat $OUT/${ci}-mnist.log)" |
|
gg_printf '```\n' |
|
} |
|
|
|
|
|
|
|
function gg_run_whisper { |
|
cd ${SRC} |
|
|
|
gg_wget models-mnt/whisper/ https://huggingface.co/ggerganov/whisper.cpp/resolve/main/ggml-base.en.bin |
|
gg_wget models-mnt/whisper/ https://github.com/ggerganov/whisper.cpp/raw/master/samples/jfk.wav |
|
|
|
cd build-ci-release |
|
|
|
set -e |
|
|
|
path_models="../models-mnt/whisper/" |
|
model_f16="${path_models}/ggml-base.en.bin" |
|
audio_0="${path_models}/jfk.wav" |
|
|
|
(time ./bin/whisper -m ${model_f16} -f ${audio_0} ) 2>&1 | tee -a $OUT/${ci}-main.log |
|
|
|
grep -q "And so my fellow Americans" $OUT/${ci}-main.log |
|
|
|
set +e |
|
} |
|
|
|
function gg_sum_whisper { |
|
gg_printf '### %s\n\n' "${ci}" |
|
|
|
gg_printf 'Runs short Whisper transcription\n' |
|
gg_printf '- status: %s\n' "$(cat $OUT/${ci}.exit)" |
|
gg_printf '```\n' |
|
gg_printf '%s\n' "$(cat $OUT/${ci}-main.log)" |
|
gg_printf '```\n' |
|
} |
|
|
|
|
|
|
|
function gg_run_sam { |
|
cd ${SRC} |
|
|
|
gg_wget models-mnt/sam/ https://dl.fbaipublicfiles.com/segment_anything/sam_vit_b_01ec64.pth |
|
gg_wget models-mnt/sam/ https://raw.githubusercontent.com/YavorGIvanov/sam.cpp/ceafb7467bff7ec98e0c4f952e58a9eb8fd0238b/img.jpg |
|
|
|
cd build-ci-release |
|
|
|
set -e |
|
|
|
path_models="../models-mnt/sam/" |
|
model_f16="${path_models}/ggml-model-f16.bin" |
|
img_0="${path_models}/img.jpg" |
|
|
|
python3 ../examples/sam/convert-pth-to-ggml.py ${path_models}/sam_vit_b_01ec64.pth ${path_models}/ 1 |
|
|
|
(time ./bin/sam -m ${model_f16} -i ${img_0} ) 2>&1 | tee -a $OUT/${ci}-main.log |
|
|
|
grep -q "bbox (371, 436), (144, 168)" $OUT/${ci}-main.log |
|
|
|
set +e |
|
} |
|
|
|
function gg_sum_sam { |
|
gg_printf '### %s\n\n' "${ci}" |
|
|
|
gg_printf 'Run SAM\n' |
|
gg_printf '- status: %s\n' "$(cat $OUT/${ci}.exit)" |
|
gg_printf '```\n' |
|
gg_printf '%s\n' "$(cat $OUT/${ci}-main.log)" |
|
gg_printf '```\n' |
|
} |
|
|
|
|
|
|
|
function gg_run_mpt { |
|
cd ${SRC} |
|
|
|
gg_wget models-mnt/mpt/7B/ https://huggingface.co/mosaicml/mpt-7b/raw/main/config.json |
|
gg_wget models-mnt/mpt/7B/ https://huggingface.co/mosaicml/mpt-7b/raw/main/tokenizer.json |
|
gg_wget models-mnt/mpt/7B/ https://huggingface.co/mosaicml/mpt-7b/raw/main/tokenizer_config.json |
|
gg_wget models-mnt/mpt/7B/ https://huggingface.co/mosaicml/mpt-7b/raw/main/pytorch_model.bin.index.json |
|
gg_wget models-mnt/mpt/7B/ https://huggingface.co/mosaicml/mpt-7b/raw/main/configuration_mpt.py |
|
gg_wget models-mnt/mpt/7B/ https://huggingface.co/mosaicml/mpt-7b/resolve/main/pytorch_model-00001-of-00002.bin |
|
gg_wget models-mnt/mpt/7B/ https://huggingface.co/mosaicml/mpt-7b/resolve/main/pytorch_model-00002-of-00002.bin |
|
|
|
cd build-ci-release |
|
|
|
set -e |
|
|
|
path_models="../models-mnt/mpt/7B" |
|
model_f16="${path_models}/ggml-model-f16.bin" |
|
model_q4_0="${path_models}/ggml-model-q4_0.bin" |
|
|
|
python3 ../examples/mpt/convert-h5-to-ggml.py ${path_models} 1 |
|
./bin/mpt-quantize ${model_f16} ${model_q4_0} q4_0 |
|
|
|
(time ./bin/mpt --model ${model_f16} -s 1234 -n 64 -p "I believe the meaning of life is") 2>&1 | tee -a $OUT/${ci}-tg.log |
|
(time ./bin/mpt --model ${model_q4_0} -s 1234 -n 64 -p "I believe the meaning of life is") 2>&1 | tee -a $OUT/${ci}-tg.log |
|
|
|
set +e |
|
} |
|
|
|
function gg_sum_mpt { |
|
gg_printf '### %s\n\n' "${ci}" |
|
|
|
gg_printf 'Runs short MPT text generation\n' |
|
gg_printf '- status: %s\n' "$(cat $OUT/${ci}.exit)" |
|
gg_printf '```\n' |
|
gg_printf '%s\n' "$(cat $OUT/${ci}-tg.log)" |
|
gg_printf '```\n' |
|
} |
|
|
|
|
|
|
|
if [ -z $GG_BUILD_LOW_PERF ]; then |
|
rm -rf ${SRC}/models-mnt |
|
|
|
mnt_models=${MNT}/models |
|
mkdir -p ${mnt_models} |
|
ln -sfn ${mnt_models} ${SRC}/models-mnt |
|
fi |
|
|
|
python3 -m pip install -r ${SRC}/requirements.txt |
|
|
|
ret=0 |
|
|
|
test $ret -eq 0 && gg_run ctest_debug |
|
test $ret -eq 0 && gg_run ctest_release |
|
test $ret -eq 0 && gg_run gpt_2 |
|
test $ret -eq 0 && gg_run mnist |
|
test $ret -eq 0 && gg_run whisper |
|
test $ret -eq 0 && gg_run sam |
|
|
|
if [ -z $GG_BUILD_LOW_PERF ]; then |
|
if [ -z ${GG_BUILD_VRAM_GB} ] || [ ${GG_BUILD_VRAM_GB} -ge 16 ]; then |
|
test $ret -eq 0 && gg_run mpt |
|
fi |
|
fi |
|
|
|
exit $ret |
|
|