| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| | 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 |
| |
|