Results by Test Cases
We currently have only a few test cases across 2 categories: data_analysis
and utility_functions
(see folder code_generation/
).
In this note, we preview each test case and highlight the highest the best performing model for it.
Reminder: The below scores are on a scale 0-100, where 100 is the best possible score and 0 means the generated code was not even parseable.
# Imports
using JuliaLLMLeaderboard
using CairoMakie, AlgebraOfGraphics
using MarkdownTables, DataFramesMeta, Markdown
using Statistics: mean, median, quantile;
unscrub_string(s::AbstractString) = split(s, "_") .|> titlecase |> x -> join(x, " ");
# ! Configuration
SAVE_PLOTS = false
DIR_RESULTS = joinpath(pkgdir(JuliaLLMLeaderboard), "code_generation")
PAID_MODELS_DEFAULT = [
"gpt-3.5-turbo",
"gpt-3.5-turbo-1106",
"gpt-3.5-turbo-0125",
"gpt-4-1106-preview",
"gpt-4-0125-preview",
"gpt-4-turbo-2024-04-09",
"gpt-4o-2024-05-13",
"gpt-4o-mini-2024-07-18",
"gpt-4o-2024-08-06",
"mistral-tiny",
"mistral-small",
"mistral-medium",
"mistral-large",
"mistral-small-2402",
"mistral-medium-2312",
"mistral-large-2402",
"claude-3-opus-20240229",
"claude-3-sonnet-20240229",
"claude-3-haiku-20240307",
"claude-3-5-sonnet-20240620",
"gemini-1.0-pro-latest",
"deepseek-chat",
"deepseek-coder",
"codestral-2405",
"mistral-large-2407"
];
PROMPTS = [
"JuliaExpertCoTTask",
"JuliaExpertAsk",
"InJulia",
"JuliaRecapTask",
"JuliaRecapCoTTask",
"JuliaExpertAskXML",
"JuliaExpertCoTTaskXML"
];
Load Results
Use only the 5 most recent evaluations available for each definition/model/prompt
df = load_evals(DIR_RESULTS; max_history = 5);
fn_definitions = find_definitions(DIR_RESULTS);
There are currently 14 test cases.
Tabular Overview
Overview of all test cases, sorted by average score and with the winning model highlighted (separated by Paid vs Open-Source)
# Pre-aggregate winning models
top_model = @chain df begin
# remove qwen models as they are not correct!
@rsubset !occursin("qwen", :model)
@rsubset !endswith(:model, "--optim")
@by [:model, :name] :score=mean(:score)
@rtransform :is_paid = :model in PAID_MODELS_DEFAULT
@orderby -:score
combine(first, groupby(_, [:name, :is_paid]))
@rtransform :winner = "$(:model) ($(round(:score;digits=1)))"
select(Not(:model, :score))
end
# Aggregate by test case
@chain df begin
@rsubset :prompt_label in PROMPTS
@by :name begin
:average_score = mean(:score)
:average_elapsed = mean(:elapsed_seconds)
:count_zero_score = count(iszero, :score)
:count_full_score = count(==(100), :score)
:count_samples = $nrow
end
@rtransform :average_score=round(:average_score; digits = 1) :average_elapsed=round(
:average_elapsed;
digits = 1)
leftjoin(_,
@rsubset(top_model, :is_paid),
on = [:name],
validate = (true, true),
makeunique = true)
leftjoin(_,
@rsubset(top_model, :is_paid==false),
on = [:name],
validate = (true, true),
makeunique = true)
select(Not(:is_paid, :is_paid_1))
rename(:winner => :paid_winner, :winner_1 => :oss_winner)
rename(_, names(_) .|> unscrub_string)
end
Row | Name | Average Score | Average Elapsed | Count Zero Score | Count Full Score | Count Samples | Paid Winner | Oss Winner |
---|---|---|---|---|---|---|---|---|
String | Float64 | Float64 | Int64 | Int64 | Int64 | String? | String? | |
1 | count_model_rows | 58.2 | 11.7 | 247 | 389 | 1395 | claude-3-5-sonnet-20240620 (100.0) | meta-llama/Llama-3-70b-chat-hf (100.0) |
2 | FloatWithUnits | 74.1 | 10.5 | 272 | 949 | 1447 | claude-3-5-sonnet-20240620 (100.0) | meta-llama/Llama-3-70b-chat-hf (100.0) |
3 | clean_column | 68.6 | 9.1 | 229 | 538 | 1376 | claude-3-opus-20240229 (100.0) | claude-2.1 (100.0) |
4 | event_scheduler | 50.8 | 15.9 | 319 | 206 | 1394 | gpt-4-0125-preview (94.4) | meta-llama/Llama-3-70b-chat-hf (100.0) |
5 | keep_only_names | 66.2 | 9.7 | 213 | 427 | 1343 | mistral-large-2402 (97.6) | meta-llama/Llama-3-8b-chat-hf (100.0) |
6 | timezone_bumper | 72.5 | 12.2 | 167 | 739 | 1337 | claude-3-5-sonnet-20240620 (100.0) | deepseek-coder:33b-instruct-q4_K_M (100.0) |
7 | weather_data_analyzer | 61.8 | 16.3 | 256 | 98 | 1395 | deepseek-chat (93.0) | meta-llama/Llama-3-70b-chat-hf (95.0) |
8 | wrap_string | 63.2 | 14.0 | 232 | 210 | 1340 | gpt-4o-mini-2024-07-18 (95.2) | claude-2.1 (92.8) |
9 | add_yearmonth | 52.8 | 13.6 | 240 | 276 | 1400 | claude-3-haiku-20240307 (87.7) | mistralai/Mixtral-8x22B-Instruct-v0.1 (79.8) |
10 | q_and_a_extractor | 41.6 | 15.5 | 400 | 0 | 1365 | claude-3-opus-20240229 (67.3) | mistralai/Mixtral-8x22B-Instruct-v0.1 (73.7) |
11 | ispersonal | 46.8 | 12.8 | 274 | 344 | 1345 | codestral-2405 (90.0) | nous-hermes2:34b-yi-q4_K_M (68.0) |
12 | extract_julia_code | 40.8 | 12.1 | 358 | 0 | 1371 | claude-3-opus-20240229 (65.2) | meta-llama/Llama-3-70b-chat-hf (61.5) |
13 | audi_filter | 42.9 | 13.6 | 338 | 202 | 1394 | claude-3-5-sonnet-20240620 (96.0) | mistralai/Mixtral-8x22B-Instruct-v0.1 (61.0) |
14 | pig_latinify | 36.1 | 17.2 | 314 | 0 | 1341 | claude-3-5-sonnet-20240620 (79.7) | deepseek-coder:33b-instruct-q4_K_M (51.1) |
Individual Test Cases
io = IOBuffer()
for fn in fn_definitions
# fn = fn_definitions[1]
d = load_definition(fn)["code_generation"]
println(io, "### Test Case: $("`"*(d["name"])*"`")")
println(io)
println(io, "- Definition file: `$(relpath(fn,pkgdir(JuliaLLMLeaderboard)))`")
println(io, "- Prompt: \"$(d["prompt"])\"")
println(io, "- Evaluation criteria: $(join("`".*d["criteria"].*"`",", "))")
println(io, "- Allowed imports: $(join(d["imports"],", "))")
println(io, "- Defined examples: $(length(get(d,"examples",[])))")
println(io, "- Defined unit tests: $(length(get(d,"unit_tests",[])))")
println(io, "- Reference solution: \n\n`````julia\n$(d["reference_solution"])\n`````\n")
# Paid model winner
winner = @chain df begin
@rsubset :model in PAID_MODELS_DEFAULT && :prompt_label in PROMPTS
@rsubset :name == d["name"]
@by :model begin
:score = mean(:score)
:elapsed = mean(:elapsed_seconds)
:count_zero_score = count(iszero, :score)
:count_full_score = count(==(100), :score)
:cnt = $nrow
end
@orderby -:score
first
end
println(io,
"**Winning Paid Model:** \"$(winner.model)\" with average score $(round(winner.score;digits=1)) (Full score: $(winner.count_full_score)/$(winner.cnt), Zero score: $(winner.count_zero_score)/$(winner.cnt)) \n")
# OSS winner
winner = @chain df begin
@rsubset !any(startswith.(:model, PAID_MODELS_DEFAULT)) && :prompt_label in PROMPTS
@rsubset :name == d["name"]
@by :model begin
:score = mean(:score)
:elapsed = mean(:elapsed_seconds)
:count_zero_score = count(iszero, :score)
:count_full_score = count(==(100), :score)
:cnt = $nrow
end
@orderby -:score
first
end
println(io,
"**Winning Locally-hosted Model:** \"$(winner.model)\" with average score $(round(winner.score;digits=1)) (Full score: $(winner.count_full_score)/$(winner.cnt), Zero score: $(winner.count_zero_score)/$(winner.cnt)) \n")
println(io, "\n")
end
MD(String(take!(io)))
Test Case: add_yearmonth
- Definition file:
code_generation/data_analysis/add_yearmonth/definition.toml
- Prompt: "Given a DataFrame
df
with columndt
representing DateTimes. Write a functionadd_yearmonth
that creates a new columnym
by extracting year and month fromdt
and concatenating them together as an integer in format: “yyyymm”." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports: DataFrames, Dates
- Defined examples: 4
- Defined unit tests: 4
- Reference solution:
using DataFrames, Dates
function add_yearmonth(df::DataFrame)
return transform(df, :dt => ByRow(dt -> year(dt) * 100 + month(dt)) => :ym)
end
Winning Paid Model: "claude-3-haiku-20240307" with average score 87.7 (Full score: 28/35, Zero score: 3/35)
Winning Locally-hosted Model: "mistralai/Mixtral-8x22B-Instruct-v0.1" with average score 79.8 (Full score: 14/25, Zero score: 0/25)
Test Case: audi_filter
- Definition file:
code_generation/data_analysis/audi_filter/definition.toml
- Prompt: "You are given a DataFrame
df_cars
with car data with columnsmanufacturer
andmodel
. Write a function audifilter that filters down the dataset to only the rows with manufacturer “audi” and model being “a4 or “a4 quattro”, then it should create a new column `audia4_typethat equals
true` across all rows. Then return the resulting DataFrame." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports: DataFrames
- Defined examples: 2
- Defined unit tests: 5
- Reference solution:
using DataFrames
function audi_filter(df::DataFrame)
# Filter for Audi A4 and Audi A4 Quattro
filtered_df = filter(row -> row.manufacturer == "audi" && (row.model == "a4" || row.model == "a4 quattro"), eachrow(df)) |> DataFrame
# Add new column
filtered_df.audi_a4_type .= true
return filtered_df
end
Winning Paid Model: "claude-3-5-sonnet-20240620" with average score 96.0 (Full score: 23/25, Zero score: 0/25)
Winning Locally-hosted Model: "mistralai/Mixtral-8x22B-Instruct-v0.1" with average score 61.0 (Full score: 7/25, Zero score: 0/25)
Test Case: count_model_rows
- Definition file:
code_generation/data_analysis/count_model_rows/definition.toml
- Prompt: "Given a DataFrame dfcars with column
model
, write a function `countmodel_rows` that groups data by model and calculate how many rows there are for each." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports: DataFrames
- Defined examples: 2
- Defined unit tests: 5
- Reference solution:
using DataFrames
function count_model_rows(df::DataFrame)
grouped_df = groupby(df, :model)
return combine(grouped_df, nrow => :count)
end
Winning Paid Model: "claude-3-5-sonnet-20240620" with average score 100.0 (Full score: 25/25, Zero score: 0/25)
Winning Locally-hosted Model: "meta-llama/Llama-3-70b-chat-hf" with average score 100.0 (Full score: 25/25, Zero score: 0/25)
Test Case: weather_data_analyzer
- Definition file:
code_generation/data_analysis/weather_data_analyzer/definition.toml
- Prompt: "You are given a list of daily temperature data
temps
(numbers). Write a functionweather_data_analyzer
that performs statistical analyses on this data (useStatistics
package). The function should return results in named tuple (construct it with(; key1=value1,key2=value2)
syntax) containing theaverage
,max
,min
temperatures, and atrend
(can be only::increasing
,:decreasing
, or:stable
). If the list is empty, the function should return a named tuple with all values set tonothing
." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports: Statistics
- Defined examples: 5
- Defined unit tests: 5
- Reference solution:
using Statistics
function weather_data_analyzer(temps)
if isempty(temps)
return (; average=nothing, max=nothing, min=nothing, trend=nothing)
else
average = mean(temps)
max_temp = maximum(temps)
min_temp = minimum(temps)
trend = if all(diff(temps) .> 0)
:increasing
elseif all(diff(temps) .< 0)
:decreasing
else
:stable
end
return (; average=average, max=max_temp, min=min_temp, trend=trend)
end
end
Winning Paid Model: "deepseek-chat" with average score 93.0 (Full score: 5/25, Zero score: 0/25)
Winning Locally-hosted Model: "meta-llama/Llama-3-70b-chat-hf" with average score 95.0 (Full score: 10/25, Zero score: 0/25)
Test Case: FloatWithUnits
- Definition file:
code_generation/utility_functions/FloatWithUnits/definition.toml
- Prompt: "Given a struct
FloatWithUnits
with fieldsvalue
andunit
(make sure to define it!), write ashow
method for it that will concatenate the value and unit with a space like this "1.8 meters"." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports:
- Defined examples: 2
- Defined unit tests: 3
- Reference solution:
struct FloatWithUnits
value::Float64
unit::String
end
Base.show(io::IO, f::FloatWithUnits) = print(io, f.value, " ", f.unit)
Winning Paid Model: "claude-3-5-sonnet-20240620" with average score 100.0 (Full score: 25/25, Zero score: 0/25)
Winning Locally-hosted Model: "meta-llama/Llama-3-70b-chat-hf" with average score 100.0 (Full score: 25/25, Zero score: 0/25)
Test Case: clean_column
- Definition file:
code_generation/utility_functions/clean_column/definition.toml
- Prompt: "Write a function
clean_column
that cleans a column name (col
) by lowercasing it, stripping any leading or trailing whitespaces, and replacing any spaces and hyphens with an underscore, eg, "My Column" becomes "my_column"." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports:
- Defined examples: 3
- Defined unit tests: 5
- Reference solution:
function clean_column(col)
return lowercase(col) |> strip |> x -> replace(x, r"[\s-]" => "_")
end
Winning Paid Model: "claude-3-opus-20240229" with average score 100.0 (Full score: 25/25, Zero score: 0/25)
Winning Locally-hosted Model: "claude-2.1" with average score 100.0 (Full score: 25/25, Zero score: 0/25)
Test Case: event_scheduler
- Definition file:
code_generation/utility_functions/event_scheduler/definition.toml
- Prompt: "You are given a list of events where each event is a tuple with a start and a finish time (in the format 'YYYY-MM-DD HH:MM'). Write a function
event_scheduler
that checks for any scheduling conflicts among the events. The function should return "No conflicts" if there are no overlapping events and "Conflict" if any events overlap in time. If the list is empty, return "No events". Use package Dates for parsing." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports: Dates
- Defined examples: 5
- Defined unit tests: 5
- Reference solution:
using Dates
function event_scheduler(events)
if isempty(events)
return "No events"
end
# Sort the events based on the start time
sorted_events = sort(events, by = e -> Dates.DateTime(e[1], "yyyy-mm-dd HH:MM"))
# Check for conflicts
for i in 1:length(sorted_events)-1
if Dates.DateTime(sorted_events[i][2], "yyyy-mm-dd HH:MM") > Dates.DateTime(sorted_events[i+1][1], "yyyy-mm-dd HH:MM")
return "Conflict"
end
end
return "No conflicts"
end
Winning Paid Model: "gpt-4-0125-preview" with average score 94.4 (Full score: 15/25, Zero score: 0/25)
Winning Locally-hosted Model: "meta-llama/Llama-3-70b-chat-hf" with average score 100.0 (Full score: 25/25, Zero score: 0/25)
Test Case: extract_julia_code
- Definition file:
code_generation/utility_functions/extract_julia_code/definition.toml
- Prompt: "You are provided a markdown document
md
with julia language code blocks. Write a functionextract_julia_code
that extracts all the code blocks, removes code fences and joins the code blocks (if there are multiple) together with a newline. Return a String. Do not provide any examples." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports:
- Defined examples: 4
- Defined unit tests: 5
- Reference solution:
function extract_julia_code(md::AbstractString)
code_blocks = eachmatch(r"```julia
(.*?)
```"s, md)
join([code.captures[1] for code in code_blocks], "
")
end
Winning Paid Model: "claude-3-opus-20240229" with average score 65.2 (Full score: 0/25, Zero score: 0/25)
Winning Locally-hosted Model: "meta-llama/Llama-3-70b-chat-hf" with average score 61.5 (Full score: 0/25, Zero score: 0/25)
Test Case: ispersonal
- Definition file:
code_generation/utility_functions/ispersonal/definition.toml
- Prompt: "Write a function
ispersonal
that returns a trait if the provided Vehicle type is a personal vehicle for everyday driving. All vehicles are subtypes of AbstractVehicle. Function must work for types: Car, Motorcycle, Bus, Truck. The first two should return true, the latter two should return false . The function should default to false for any other subtype of AbstractVehicle. Provide an example." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports:
- Defined examples: 4
- Defined unit tests: 5
- Reference solution:
abstract type AbstractVehicle end
struct Car <: AbstractVehicle end
struct Motorcycle <: AbstractVehicle end
struct Bus <: AbstractVehicle end
struct Truck <: AbstractVehicle end
ispersonal(vehicle::AbstractVehicle) = false
ispersonal(vehicle::Union{Car,Motorcycle}) = true
Winning Paid Model: "codestral-2405" with average score 90.0 (Full score: 22/25, Zero score: 2/25)
Winning Locally-hosted Model: "nous-hermes2:34b-yi-q4KM" with average score 68.0 (Full score: 14/25, Zero score: 2/25)
Test Case: keep_only_names
- Definition file:
code_generation/utility_functions/keep_only_names/definition.toml
- Prompt: "Write a function
keep_only_names
which iterates over the provided list of words (words
) and removes all words that do not start with a capital letter (eg, remove "dog" but keep "Dog")." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports:
- Defined examples: 4
- Defined unit tests: 5
- Reference solution:
function keep_only_names(words)
return filter(word -> isuppercase(first(word)), words)
end
Winning Paid Model: "mistral-large-2402" with average score 97.6 (Full score: 22/25, Zero score: 0/25)
Winning Locally-hosted Model: "meta-llama/Llama-3-8b-chat-hf" with average score 100.0 (Full score: 25/25, Zero score: 0/25)
Test Case: pig_latinify
- Definition file:
code_generation/utility_functions/pig_latinify/definition.toml
- Prompt: "Write a pig latin transformer called
pig_latinify
that operates on a vector of strings. It iterates over each string and changes it to pig latin. Each iteration should run on a separate thread." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports: Base.Threads
- Defined examples: 4
- Defined unit tests: 5
- Reference solution:
function to_pig_latin(word::AbstractString)
vowels = "aeiouAEIOU"
first_vowel_idx = findfirst(c -> c in vowels, word)
if isnothing(first_vowel_idx) || first_vowel_idx == 1
return word * "ay"
else
return word[first_vowel_idx:end] * word[1:first_vowel_idx-1] * "ay"
end
end
function pig_latinify(words::Vector{<:AbstractString})
transform = similar(words)
Threads.@threads for i in 1:length(words)
transform[i] = to_pig_latin(words[i])
end
return transform
end
Winning Paid Model: "claude-3-5-sonnet-20240620" with average score 79.7 (Full score: 0/25, Zero score: 0/25)
Winning Locally-hosted Model: "codellama:13b-instruct-q4KM" with average score 48.6 (Full score: 0/25, Zero score: 2/25)
Test Case: q_and_a_extractor
- Definition file:
code_generation/utility_functions/q_and_a_extractor/definition.toml
- Prompt: "You are given a markdown-formatted text
md
. Write a functionq_and_a_extractor
to extract all text in the markdown sections Question and Answer (starting with# Question
and# Answer
, respectively) and return the answer in a tuple like(question,answer)
. Strip any leading spaces and newlines from the extracted text." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports:
- Defined examples: 3
- Defined unit tests: 5
- Reference solution:
function q_and_a_extractor(md::AbstractString)
question = match(r"(?<=# Question
).*?(?=
# [A-Za-z]+|$)"s, md)
answer = match(r"(?<=# Answer
).*?(?=
# [A-Za-z]+|$)"s, md)
return (question === nothing ? "" : strip(question.match)),
(answer === nothing ? "" : strip(answer.match))
end
Winning Paid Model: "claude-3-opus-20240229" with average score 67.3 (Full score: 0/25, Zero score: 0/25)
Winning Locally-hosted Model: "mistralai/Mixtral-8x22B-Instruct-v0.1" with average score 73.7 (Full score: 0/25, Zero score: 0/25)
Test Case: timezone_bumper
- Definition file:
code_generation/utility_functions/timezone_bumper/definition.toml
- Prompt: "Write a function
timezone_bumper(dt,bump)
that increases any provided timestamp bybump::Int
hours (defaults to +3 hours). Make sure it works only for DateTime types and throws an error for Date types." - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports: Dates
- Defined examples: 5
- Defined unit tests: 5
- Reference solution:
using Dates
function timezone_bumper(timestamp::DateTime, bump::Int=3)
return timestamp + Hour(bump)
end
Winning Paid Model: "claude-3-5-sonnet-20240620" with average score 100.0 (Full score: 25/25, Zero score: 0/25)
Winning Locally-hosted Model: "meta-llama/Llama-3-70b-chat-hf" with average score 100.0 (Full score: 25/25, Zero score: 0/25)
Test Case: wrap_string
- Definition file:
code_generation/utility_functions/wrap_string/definition.toml
- Prompt: "Write a function
wrap_string
. It iterates over words and it will add a new line each time a maximumtext_width::Int=10
would be exceeded. Provide an example" - Evaluation criteria:
parsed
,executed
,passed_unit_tests
,executed_examples
- Allowed imports:
- Defined examples: 2
- Defined unit tests: 6
- Reference solution:
function wrap_string(text::AbstractString, text_width::Int=10)
words = split(text)
line_length = 0
wrapped_text = ""
num_words = length(words)
for i in eachindex(words)
word = words[i]
# +1 for separator length for all but the last word
sep_length = (i == num_words) ? 0 : 1
if line_length + length(word) + sep_length > text_width
wrapped_text *= "
"
line_length = 0
end
wrapped_text *= word * " "
line_length += length(word) + 1
end
return strip(wrapped_text)
end
Winning Paid Model: "gpt-4-1106-preview" with average score 97.8 (Full score: 14/25, Zero score: 0/25)
Winning Locally-hosted Model: "claude-2.1" with average score 92.8 (Full score: 12/25, Zero score: 0/25)
This page was generated using Literate.jl.