Skip to content

Commit

Permalink
chk validation allows tolerance within single solution, closes #95, #136
Browse files Browse the repository at this point in the history
  • Loading branch information
jangorecki committed May 14, 2020
1 parent 00c907b commit 7eacaa1
Showing 1 changed file with 19 additions and 7 deletions.
26 changes: 19 additions & 7 deletions _report/report.R
Original file line number Diff line number Diff line change
Expand Up @@ -70,16 +70,28 @@ clean_questions = function(q) {
# model ----

model_time = function(d) {
# chk tolerance for cudf disabled as of now: https://github.com/rapidsai/cudf/issues/2494
# chk tolerance for cudf: https://github.com/rapidsai/cudf/issues/2494
#d[!is.na(chk) & solution=="cudf", .(unq_chk=paste(unique(chk), collapse=","), unqn_chk=uniqueN(chk)), .(task, solution, data, question)][unqn_chk>1L]
# as well for dask due to #136
# and dask #136
#d[!is.na(chk) & solution=="dask", .(unq_chk=paste(unique(chk), collapse=","), unqn_chk=uniqueN(chk)), .(task, solution, data, question)][unqn_chk>1L]
approxUniqueN1 = function(x, tolerance=1e-3, debug=FALSE) { ## dask is fine on 1e-6, cudf needs 1e-3
l = lapply(as.list(rbindlist(lapply(strsplit(x, ";", fixed=TRUE), as.list))), type.convert)
int = sapply(l, is.integer)
dbl = sapply(l, is.double)
if (sum(int, dbl)!=length(l)) stop("chk has elements that were not converted to int or double")
ans = vector("logical", length(l))
ans[int] = vapply(l[int], function(y) {same=uniqueN(y)==1L; if (debug&&!same) browser() else same}, NA)
ans[dbl] = vapply(l[dbl], function(y, t) {
m = mean(y)
lb = m-m*t
ub = m+m*t
same = all(y >= lb) && all(y <= ub)
if (debug&&!same) browser() else same
}, t=tolerance, NA)
all(ans)
}
if (nrow(
d[!is.na(chk) & (
solution!="cudf" &
solution!="dask"
),
.(unqn_chk=uniqueN(chk)), .(task, solution, data, question)][unqn_chk>1L]
d[!is.na(chk), .(unqn1_chk=approxUniqueN1(chk)), .(task, solution, data, question)][unqn1_chk==FALSE]
))
stop("Value of 'chk' varies for different runs for single solution+question")
if (nrow(d[!is.na(out_rows), .(unqn_out_rows=uniqueN(out_rows)), .(task, solution, data, question)][unqn_out_rows>1L]))
Expand Down

0 comments on commit 7eacaa1

Please sign in to comment.