2023-10-31 09:12:39 -07:00
|
|
|
#! /usr/bin/env bash
|
2023-10-31 12:40:46 -07:00
|
|
|
# Compare multiple models by running them with the same questions
|
|
|
|
|
2023-10-31 09:12:39 -07:00
|
|
|
NUMBEROFCHOICES=4
|
|
|
|
SELECTIONS=()
|
|
|
|
declare -a SUMS=()
|
|
|
|
|
2023-10-31 12:40:46 -07:00
|
|
|
# Get the list of models
|
|
|
|
CHOICES=$(ollama list | awk '{print $1}')
|
|
|
|
|
|
|
|
# Select which models to run as a comparison
|
2023-10-31 09:12:39 -07:00
|
|
|
echo "Select $NUMBEROFCHOICES models to compare:"
|
|
|
|
select ITEM in $CHOICES; do
|
|
|
|
if [[ -n $ITEM ]]; then
|
|
|
|
echo "You have selected $ITEM"
|
|
|
|
SELECTIONS+=("$ITEM")
|
|
|
|
((COUNT++))
|
|
|
|
if [[ $COUNT -eq $NUMBEROFCHOICES ]]; then
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo "Invalid selection"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2023-10-31 12:40:46 -07:00
|
|
|
# Loop through each of the selected models
|
2023-10-31 09:12:39 -07:00
|
|
|
for ITEM in "${SELECTIONS[@]}"; do
|
|
|
|
echo "--------------------------------------------------------------"
|
|
|
|
echo "Loading the model $ITEM into memory"
|
|
|
|
ollama run "$ITEM" ""
|
|
|
|
echo "--------------------------------------------------------------"
|
|
|
|
echo "Running the questions through the model $ITEM"
|
2023-11-08 18:09:05 -06:00
|
|
|
COMMAND_OUTPUT=$(ollama run "$ITEM" --verbose < sourcequestions.txt 2>&1| tee /dev/stderr)
|
2023-10-31 09:12:39 -07:00
|
|
|
|
2023-10-31 12:40:46 -07:00
|
|
|
# eval duration is sometimes listed in seconds and sometimes in milliseconds.
|
|
|
|
# Add up the values for each model
|
2023-10-31 09:12:39 -07:00
|
|
|
SUM=$(echo "$COMMAND_OUTPUT" | awk '
|
|
|
|
/eval duration:/ {
|
|
|
|
value = $3
|
|
|
|
if (index(value, "ms") > 0) {
|
|
|
|
gsub("ms", "", value)
|
|
|
|
value /= 1000
|
|
|
|
} else {
|
|
|
|
gsub("s", "", value)
|
|
|
|
}
|
|
|
|
sum += value
|
|
|
|
}
|
|
|
|
END { print sum }')
|
|
|
|
|
|
|
|
|
|
|
|
SUMS+=("All questions for $ITEM completed in $SUM seconds")
|
|
|
|
done
|
|
|
|
|
|
|
|
echo ""
|
|
|
|
echo "--------------------------------------------------------------"
|
|
|
|
echo -e "Sums of eval durations for each run:"
|
|
|
|
for val in "${SUMS[@]}"; do
|
|
|
|
echo "$val"
|
|
|
|
done
|
|
|
|
|
|
|
|
echo "--------------------------------------------------------------"
|
|
|
|
echo "Comparison complete. Now you can decide"
|
|
|
|
echo "which model is best."
|
|
|
|
echo "--------------------------------------------------------------"
|