diff --git a/duckdb-latest/groupby-duckdb-latest.R b/duckdb-latest/groupby-duckdb-latest.R index fac77580..a747960b 100755 --- a/duckdb-latest/groupby-duckdb-latest.R +++ b/duckdb-latest/groupby-duckdb-latest.R @@ -64,7 +64,7 @@ cat("grouping...\n") question = "sum v1 by id1" # q1 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, sum(v1) AS v1 FROM x GROUP BY id1") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, sum(v1) AS v1 FROM x GROUP BY id1") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -72,7 +72,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v1) AS v1 FROM ans"))[["elap write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, sum(v1) AS v1 FROM x GROUP BY id1") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, sum(v1) AS v1 FROM x GROUP BY id1") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -84,7 +84,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "sum v1 by id1:id2" # q2 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, id2, sum(v1) AS v1 FROM x GROUP BY id1, id2") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, id2, sum(v1) AS v1 FROM x GROUP BY id1, id2") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -92,7 +92,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v1) AS v1 FROM ans"))[["elap write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, id2, sum(v1) AS v1 FROM x GROUP BY id1, id2") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, id2, sum(v1) AS v1 FROM x GROUP BY id1, id2") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -104,7 +104,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "sum v1 mean v3 by id3" # q3 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id3, sum(v1) AS v1, avg(v3) AS v3 FROM x GROUP BY id3") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id3, sum(v1) AS v1, avg(v3) AS v3 FROM x GROUP BY id3") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -112,7 +112,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v1) AS v1, sum(v3) AS v3 FRO write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id3, sum(v1) AS v1, avg(v3) AS v3 FROM x GROUP BY id3") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id3, sum(v1) AS v1, avg(v3) AS v3 FROM x GROUP BY id3") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -124,7 +124,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "mean v1:v3 by id4" # q4 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id4, avg(v1) AS v1, avg(v2) AS v2, avg(v3) AS v3 FROM x GROUP BY id4") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id4, avg(v1) AS v1, avg(v2) AS v2, avg(v3) AS v3 FROM x GROUP BY id4") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -132,7 +132,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v1) AS v1, sum(v2) AS v2, su write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id4, avg(v1) AS v1, avg(v2) AS v2, avg(v3) AS v3 FROM x GROUP BY id4") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id4, avg(v1) AS v1, avg(v2) AS v2, avg(v3) AS v3 FROM x GROUP BY id4") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -144,7 +144,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "sum v1:v3 by id6" # q5 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id6, sum(v1) AS v1, sum(v2) AS v2, sum(v3) AS v3 FROM x GROUP BY id6") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id6, sum(v1) AS v1, sum(v2) AS v2, sum(v3) AS v3 FROM x GROUP BY id6") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -152,7 +152,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v1) AS v1, sum(v2) AS v2, su write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id6, sum(v1) AS v1, sum(v2) AS v2, sum(v3) AS v3 FROM x GROUP BY id6") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id6, sum(v1) AS v1, sum(v2) AS v2, sum(v3) AS v3 FROM x GROUP BY id6") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -164,7 +164,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "median v3 sd v3 by id4 id5" # q6 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id4, id5, quantile_cont(v3, 0.5) AS median_v3, stddev(v3) AS sd_v3 FROM x GROUP BY id4, id5") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id4, id5, quantile_cont(v3, 0.5) AS median_v3, stddev(v3) AS sd_v3 FROM x GROUP BY id4, id5") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -172,7 +172,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(median_v3) AS median_v3, sum write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id4, id5, quantile_cont(v3, 0.5) AS median_v3, stddev(v3) AS sd_v3 FROM x GROUP BY id4, id5") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id4, id5, quantile_cont(v3, 0.5) AS median_v3, stddev(v3) AS sd_v3 FROM x GROUP BY id4, id5") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -184,7 +184,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "max v1 - min v2 by id3" # q7 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id3, max(v1)-min(v2) AS range_v1_v2 FROM x GROUP BY id3") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id3, max(v1)-min(v2) AS range_v1_v2 FROM x GROUP BY id3") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -192,7 +192,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(range_v1_v2) AS range_v1_v2 write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id3, max(v1)-min(v2) AS range_v1_v2 FROM x GROUP BY id3") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id3, max(v1)-min(v2) AS range_v1_v2 FROM x GROUP BY id3") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -204,7 +204,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "largest two v3 by id6" # q8 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id6, v3 AS largest2_v3 FROM (SELECT id6, v3, row_number() OVER (PARTITION BY id6 ORDER BY v3 DESC) AS order_v3 FROM x WHERE v3 IS NOT NULL) sub_query WHERE order_v3 <= 2") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id6, v3 AS largest2_v3 FROM (SELECT id6, v3, row_number() OVER (PARTITION BY id6 ORDER BY v3 DESC) AS order_v3 FROM x WHERE v3 IS NOT NULL) sub_query WHERE order_v3 <= 2") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -212,7 +212,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(largest2_v3) AS largest2_v3 write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id6, v3 AS largest2_v3 FROM (SELECT id6, v3, row_number() OVER (PARTITION BY id6 ORDER BY v3 DESC) AS order_v3 FROM x WHERE v3 IS NOT NULL) sub_query WHERE order_v3 <= 2") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id6, v3 AS largest2_v3 FROM (SELECT id6, v3, row_number() OVER (PARTITION BY id6 ORDER BY v3 DESC) AS order_v3 FROM x WHERE v3 IS NOT NULL) sub_query WHERE order_v3 <= 2") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -224,7 +224,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "regression v1 v2 by id2 id4" # q9 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id2, id4, pow(corr(v1, v2), 2) AS r2 FROM x GROUP BY id2, id4") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id2, id4, pow(corr(v1, v2), 2) AS r2 FROM x GROUP BY id2, id4") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -232,7 +232,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(r2) AS r2 FROM ans"))[["elap write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id2, id4, pow(corr(v1, v2), 2) AS r2 FROM x GROUP BY id2, id4") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id2, id4, pow(corr(v1, v2), 2) AS r2 FROM x GROUP BY id2, id4") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -244,7 +244,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "sum v3 count by id1:id6" # q10 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, id2, id3, id4, id5, id6, sum(v3) AS v3, count(*) AS count FROM x GROUP BY id1, id2, id3, id4, id5, id6") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, id2, id3, id4, id5, id6, sum(v3) AS v3, count(*) AS count FROM x GROUP BY id1, id2, id3, id4, id5, id6") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -252,7 +252,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v3) AS v3, sum(count) AS cou write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, id2, id3, id4, id5, id6, sum(v3) AS v3, count(*) AS count FROM x GROUP BY id1, id2, id3, id4, id5, id6") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, id2, id3, id4, id5, id6, sum(v3) AS v3, count(*) AS count FROM x GROUP BY id1, id2, id3, id4, id5, id6") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() diff --git a/duckdb-latest/join-duckdb-latest.R b/duckdb-latest/join-duckdb-latest.R index 75518d42..0e920b8b 100755 --- a/duckdb-latest/join-duckdb-latest.R +++ b/duckdb-latest/join-duckdb-latest.R @@ -21,27 +21,6 @@ src_jn_y = setNames(file.path("data", paste(y_data_name, "csv", sep=".")), names stopifnot(length(src_jn_y)==3L) cat(sprintf("loading datasets %s\n", paste(c(data_name, y_data_name), collapse=", "))) -attach_and_use <- function(con, db_file, db) { - if (on_disk) { - # in case a previous solution failed during query execution and left the file around. - if (file.exists(db_file)) { - unlink(db_file) - } - dbExecute(con, sprintf("ATTACH '%s'", db_file)) - } else { - dbExecute(con, sprintf("CREATE SCHEMA %s", db)) - } -} - -detach_and_drop <- function(con, db_file, db) { - if (on_disk) { - dbExecute(con, sprintf("DETACH %s", db)) - unlink(db_file) - } else { - dbExecute(con, sprintf("DROP SCHEMA %s CASCADE", db)) - } -} - duckdb_join_db = sprintf('%s_%s_%s.db', gsub("-","_",solution), task, data_name) if (file.exists(duckdb_join_db)) { unlink(duckdb_join_db) @@ -65,6 +44,7 @@ if (less_cores) { ncores = min(ncores, 40) } invisible(dbExecute(con, sprintf("PRAGMA THREADS=%d", ncores))) +invisible(dbExecute(con, "SET memory_limit='220GB'")) git = dbGetQuery(con, "SELECT source_id FROM pragma_version()")[[1L]] invisible({ @@ -142,133 +122,113 @@ question = "small inner on int" # q1 fun = "inner_join" -attach_and_use(con, 'q1.db', 'q1') t = system.time({ - dbExecute(con, "CREATE TABLE q1.ans AS SELECT x.*, small.id4 AS small_id4, v2 FROM x JOIN small USING (id1)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q1.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q1.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, small.id4 AS small_id4, v2 FROM x JOIN small USING (id1)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q1.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -invisible(dbExecute(con, "DROP TABLE IF EXISTS q1.ans")) -detach_and_drop(con, 'q1.db', 'q1') -attach_and_use(con, 'q1.db', 'q1') +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE q1.ans AS SELECT x.*, small.id4 AS small_id4, v2 FROM x JOIN small USING (id1)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q1.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q1.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, small.id4 AS small_id4, v2 FROM x JOIN small USING (id1)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q1.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=2L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -print(dbGetQuery(con, "SELECT * FROM q1.ans LIMIT 3")) ## head -print(dbGetQuery(con, "SELECT * FROM q1.ans WHERE ROWID > (SELECT count(*) FROM q1.ans) - 4")) ## tail -invisible(dbExecute(con, "DROP TABLE IF EXISTS q1.ans")) -detach_and_drop(con, 'q1.db', 'q1') +print(dbGetQuery(con, "SELECT * FROM ans LIMIT 3")) ## head +print(dbGetQuery(con, "SELECT * FROM ans WHERE ROWID > (SELECT count(*) FROM ans) - 4")) ## tail +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "medium inner on int" # q2 fun = "inner_join" -attach_and_use(con, 'q2.db', 'q2') t = system.time({ - dbExecute(con, "CREATE TABLE q2.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x JOIN medium USING (id2)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q2.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q2.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x JOIN medium USING (id2)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q2.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -invisible(dbExecute(con, "DROP TABLE IF EXISTS q2.ans")) -detach_and_drop(con, 'q2.db', 'q2') -attach_and_use(con, 'q2.db', 'q2') +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE q2.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x JOIN medium USING (id2)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q2.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q2.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x JOIN medium USING (id2)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q2.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=2L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -print(dbGetQuery(con, "SELECT * FROM q2.ans LIMIT 3")) ## head -print(dbGetQuery(con, "SELECT * FROM q2.ans WHERE ROWID > (SELECT count(*) FROM q2.ans) - 4")) ## tail -invisible(dbExecute(con, "DROP TABLE IF EXISTS q2.ans")) -detach_and_drop(con, 'q2.db', 'q2') +print(dbGetQuery(con, "SELECT * FROM ans LIMIT 3")) ## head +print(dbGetQuery(con, "SELECT * FROM ans WHERE ROWID > (SELECT count(*) FROM ans) - 4")) ## tail +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "medium outer on int" # q3 fun = "left_join" -attach_and_use(con, 'q3.db', 'q3') t = system.time({ - dbExecute(con, "CREATE TABLE q3.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x LEFT JOIN medium USING (id2)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q3.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q3.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x LEFT JOIN medium USING (id2)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q3.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -invisible(dbExecute(con, "DROP TABLE IF EXISTS q3.ans")) -detach_and_drop(con, 'q3.db', 'q3') -attach_and_use(con, 'q3.db', 'q3') +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE q3.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x LEFT JOIN medium USING (id2)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q3.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q3.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x LEFT JOIN medium USING (id2)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q3.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=2L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -print(dbGetQuery(con, "SELECT * FROM q3.ans LIMIT 3")) ## head -print(dbGetQuery(con, "SELECT * FROM q3.ans WHERE ROWID > (SELECT count(*) FROM q3.ans) - 4")) ## tail -invisible(dbExecute(con, "DROP TABLE IF EXISTS q3.ans")) -detach_and_drop(con, 'q3.db', 'q3') +print(dbGetQuery(con, "SELECT * FROM ans LIMIT 3")) ## head +print(dbGetQuery(con, "SELECT * FROM ans WHERE ROWID > (SELECT count(*) FROM ans) - 4")) ## tail +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "medium inner on factor" # q4 fun = "inner_join" -attach_and_use(con, 'q4.db', 'q4') t = system.time({ - dbExecute(con, "CREATE TABLE q4.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id2 AS medium_id2, medium.id4 AS medium_id4, v2 FROM x JOIN medium USING (id5)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q4.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q4.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id2 AS medium_id2, medium.id4 AS medium_id4, v2 FROM x JOIN medium USING (id5)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q4.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -invisible(dbExecute(con, "DROP TABLE IF EXISTS q4.ans")) -detach_and_drop(con, 'q4.db', 'q4') -attach_and_use(con, 'q4.db', 'q4') +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE q4.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id2 AS medium_id2, medium.id4 AS medium_id4, v2 FROM x JOIN medium USING (id5)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q4.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q4.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id2 AS medium_id2, medium.id4 AS medium_id4, v2 FROM x JOIN medium USING (id5)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q4.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=2L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -print(dbGetQuery(con, "SELECT * FROM q4.ans LIMIT 3")) ## head -print(dbGetQuery(con, "SELECT * FROM q4.ans WHERE ROWID > (SELECT count(*) FROM q4.ans) - 4")) ## tail -invisible(dbExecute(con, "DROP TABLE IF EXISTS q4.ans")) -detach_and_drop(con, 'q4.db', 'q4') +print(dbGetQuery(con, "SELECT * FROM ans LIMIT 3")) ## head +print(dbGetQuery(con, "SELECT * FROM ans WHERE ROWID > (SELECT count(*) FROM ans) - 4")) ## tail +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "big inner on int" # q5 fun = "inner_join" -attach_and_use(con, 'q5.db', 'q5') t = system.time({ - dbExecute(con, "CREATE TABLE q5.ans AS SELECT x.*, big.id1 AS big_id1, big.id2 AS big_id2, big.id4 AS big_id4, big.id5 AS big_id5, big.id6 AS big_id6, v2 FROM x JOIN big USING (id3)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q5.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q5.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, big.id1 AS big_id1, big.id2 AS big_id2, big.id4 AS big_id4, big.id5 AS big_id5, big.id6 AS big_id6, v2 FROM x JOIN big USING (id3)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q5.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -invisible(dbExecute(con, "DROP TABLE IF EXISTS q5.ans")) -detach_and_drop(con, 'q5.db', 'q5') -attach_and_use(con, 'q5.db', 'q5') +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE q5.ans AS SELECT x.*, big.id1 AS big_id1, big.id2 AS big_id2, big.id4 AS big_id4, big.id5 AS big_id5, big.id6 AS big_id6, v2 FROM x JOIN big USING (id3)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q5.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q5.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, big.id1 AS big_id1, big.id2 AS big_id2, big.id4 AS big_id4, big.id5 AS big_id5, big.id6 AS big_id6, v2 FROM x JOIN big USING (id3)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q5.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=2L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -print(dbGetQuery(con, "SELECT * FROM q5.ans LIMIT 3")) ## head -print(dbGetQuery(con, "SELECT * FROM q5.ans WHERE ROWID > (SELECT count(*) FROM q5.ans) - 4")) ## tail -invisible(dbExecute(con, "DROP TABLE IF EXISTS q5.ans")) -detach_and_drop(con, 'q5.db', 'q5') +print(dbGetQuery(con, "SELECT * FROM ans LIMIT 3")) ## head +print(dbGetQuery(con, "SELECT * FROM ans WHERE ROWID > (SELECT count(*) FROM ans) - 4")) ## tail +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) dbDisconnect(con, shutdown=TRUE) diff --git a/duckdb/VERSION b/duckdb/VERSION index db5f2c74..3eefcb9d 100644 --- a/duckdb/VERSION +++ b/duckdb/VERSION @@ -1 +1 @@ -0.8.1.3 +1.0.0 diff --git a/duckdb/groupby-duckdb.R b/duckdb/groupby-duckdb.R index 84102531..13703e74 100755 --- a/duckdb/groupby-duckdb.R +++ b/duckdb/groupby-duckdb.R @@ -64,7 +64,7 @@ cat("grouping...\n") question = "sum v1 by id1" # q1 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, sum(v1) AS v1 FROM x GROUP BY id1") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, sum(v1) AS v1 FROM x GROUP BY id1") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -72,7 +72,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v1) AS v1 FROM ans"))[["elap write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, sum(v1) AS v1 FROM x GROUP BY id1") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, sum(v1) AS v1 FROM x GROUP BY id1") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -84,7 +84,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "sum v1 by id1:id2" # q2 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, id2, sum(v1) AS v1 FROM x GROUP BY id1, id2") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, id2, sum(v1) AS v1 FROM x GROUP BY id1, id2") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -92,7 +92,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v1) AS v1 FROM ans"))[["elap write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, id2, sum(v1) AS v1 FROM x GROUP BY id1, id2") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, id2, sum(v1) AS v1 FROM x GROUP BY id1, id2") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -104,7 +104,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "sum v1 mean v3 by id3" # q3 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id3, sum(v1) AS v1, avg(v3) AS v3 FROM x GROUP BY id3") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id3, sum(v1) AS v1, avg(v3) AS v3 FROM x GROUP BY id3") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -112,7 +112,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v1) AS v1, sum(v3) AS v3 FRO write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id3, sum(v1) AS v1, avg(v3) AS v3 FROM x GROUP BY id3") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id3, sum(v1) AS v1, avg(v3) AS v3 FROM x GROUP BY id3") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -124,7 +124,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "mean v1:v3 by id4" # q4 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id4, avg(v1) AS v1, avg(v2) AS v2, avg(v3) AS v3 FROM x GROUP BY id4") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id4, avg(v1) AS v1, avg(v2) AS v2, avg(v3) AS v3 FROM x GROUP BY id4") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -132,7 +132,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v1) AS v1, sum(v2) AS v2, su write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id4, avg(v1) AS v1, avg(v2) AS v2, avg(v3) AS v3 FROM x GROUP BY id4") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id4, avg(v1) AS v1, avg(v2) AS v2, avg(v3) AS v3 FROM x GROUP BY id4") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -144,7 +144,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "sum v1:v3 by id6" # q5 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id6, sum(v1) AS v1, sum(v2) AS v2, sum(v3) AS v3 FROM x GROUP BY id6") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id6, sum(v1) AS v1, sum(v2) AS v2, sum(v3) AS v3 FROM x GROUP BY id6") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -152,7 +152,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v1) AS v1, sum(v2) AS v2, su write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id6, sum(v1) AS v1, sum(v2) AS v2, sum(v3) AS v3 FROM x GROUP BY id6") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id6, sum(v1) AS v1, sum(v2) AS v2, sum(v3) AS v3 FROM x GROUP BY id6") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -164,7 +164,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "median v3 sd v3 by id4 id5" # q6 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id4, id5, quantile_cont(v3, 0.5) AS median_v3, stddev(v3) AS sd_v3 FROM x GROUP BY id4, id5") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id4, id5, quantile_cont(v3, 0.5) AS median_v3, stddev(v3) AS sd_v3 FROM x GROUP BY id4, id5") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -172,7 +172,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(median_v3) AS median_v3, sum write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id4, id5, quantile_cont(v3, 0.5) AS median_v3, stddev(v3) AS sd_v3 FROM x GROUP BY id4, id5") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id4, id5, quantile_cont(v3, 0.5) AS median_v3, stddev(v3) AS sd_v3 FROM x GROUP BY id4, id5") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -184,7 +184,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "max v1 - min v2 by id3" # q7 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id3, max(v1)-min(v2) AS range_v1_v2 FROM x GROUP BY id3") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id3, max(v1)-min(v2) AS range_v1_v2 FROM x GROUP BY id3") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -192,7 +192,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(range_v1_v2) AS range_v1_v2 write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id3, max(v1)-min(v2) AS range_v1_v2 FROM x GROUP BY id3") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id3, max(v1)-min(v2) AS range_v1_v2 FROM x GROUP BY id3") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -204,7 +204,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "largest two v3 by id6" # q8 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id6, v3 AS largest2_v3 FROM (SELECT id6, v3, row_number() OVER (PARTITION BY id6 ORDER BY v3 DESC) AS order_v3 FROM x WHERE v3 IS NOT NULL) sub_query WHERE order_v3 <= 2") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id6, v3 AS largest2_v3 FROM (SELECT id6, v3, row_number() OVER (PARTITION BY id6 ORDER BY v3 DESC) AS order_v3 FROM x WHERE v3 IS NOT NULL) sub_query WHERE order_v3 <= 2") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -212,7 +212,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(largest2_v3) AS largest2_v3 write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id6, v3 AS largest2_v3 FROM (SELECT id6, v3, row_number() OVER (PARTITION BY id6 ORDER BY v3 DESC) AS order_v3 FROM x WHERE v3 IS NOT NULL) sub_query WHERE order_v3 <= 2") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id6, v3 AS largest2_v3 FROM (SELECT id6, v3, row_number() OVER (PARTITION BY id6 ORDER BY v3 DESC) AS order_v3 FROM x WHERE v3 IS NOT NULL) sub_query WHERE order_v3 <= 2") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -224,7 +224,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "regression v1 v2 by id2 id4" # q9 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id2, id4, pow(corr(v1, v2), 2) AS r2 FROM x GROUP BY id2, id4") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id2, id4, pow(corr(v1, v2), 2) AS r2 FROM x GROUP BY id2, id4") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -232,7 +232,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(r2) AS r2 FROM ans"))[["elap write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id2, id4, pow(corr(v1, v2), 2) AS r2 FROM x GROUP BY id2, id4") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id2, id4, pow(corr(v1, v2), 2) AS r2 FROM x GROUP BY id2, id4") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -244,7 +244,7 @@ invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "sum v3 count by id1:id6" # q10 t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, id2, id3, id4, id5, id6, sum(v3) AS v3, count(*) AS count FROM x GROUP BY id1, id2, id3, id4, id5, id6") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, id2, id3, id4, id5, id6, sum(v3) AS v3, count(*) AS count FROM x GROUP BY id1, id2, id3, id4, id5, id6") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() @@ -252,7 +252,7 @@ chkt = system.time(chk<-dbGetQuery(con, "SELECT sum(v3) AS v3, sum(count) AS cou write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE ans AS SELECT id1, id2, id3, id4, id5, id6, sum(v3) AS v3, count(*) AS count FROM x GROUP BY id1, id2, id3, id4, id5, id6") + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT id1, id2, id3, id4, id5, id6, sum(v3) AS v3, count(*) AS count FROM x GROUP BY id1, id2, id3, id4, id5, id6") print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() diff --git a/duckdb/join-duckdb.R b/duckdb/join-duckdb.R index e5e02c5b..371f0e28 100755 --- a/duckdb/join-duckdb.R +++ b/duckdb/join-duckdb.R @@ -21,27 +21,6 @@ src_jn_y = setNames(file.path("data", paste(y_data_name, "csv", sep=".")), names stopifnot(length(src_jn_y)==3L) cat(sprintf("loading datasets %s\n", paste(c(data_name, y_data_name), collapse=", "))) -attach_and_use <- function(con, db_file, db) { - if (on_disk) { - # in case a previous solution failed during query execution and left the file around. - if (file.exists(db_file)) { - unlink(db_file) - } - dbExecute(con, sprintf("ATTACH '%s'", db_file)) - } else { - dbExecute(con, sprintf("CREATE SCHEMA %s", db)) - } -} - -detach_and_drop <- function(con, db_file, db) { - if (on_disk) { - dbExecute(con, sprintf("DETACH %s", db)) - unlink(db_file) - } else { - dbExecute(con, sprintf("DROP SCHEMA %s CASCADE", db)) - } -} - duckdb_join_db = sprintf('%s_%s_%s.db', solution, task, data_name) on_disk = as.numeric(strsplit(data_name, "_", fixed=TRUE)[[1L]][2L])>=1e9 less_cores = as.numeric(strsplit("J1_1e7_NA_0_0", "_", fixed=TRUE)[[1L]][2L])<=1e7 @@ -62,6 +41,7 @@ if (less_cores) { } invisible(dbExecute(con, sprintf("PRAGMA THREADS=%d", ncores))) +invisible(dbExecute(con, "SET memory_limit='220GB'")) git = dbGetQuery(con, "SELECT source_id FROM pragma_version()")[[1L]] invisible({ @@ -118,133 +98,113 @@ question = "small inner on int" # q1 fun = "inner_join" -attach_and_use(con, 'q1.db', 'q1') t = system.time({ - dbExecute(con, "CREATE TABLE q1.ans AS SELECT x.*, small.id4 AS small_id4, v2 FROM x JOIN small USING (id1)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q1.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q1.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, small.id4 AS small_id4, v2 FROM x JOIN small USING (id1)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q1.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -invisible(dbExecute(con, "DROP TABLE IF EXISTS q1.ans")) -detach_and_drop(con, 'q1.db', 'q1') -attach_and_use(con, 'q1.db', 'q1') +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE q1.ans AS SELECT x.*, small.id4 AS small_id4, v2 FROM x JOIN small USING (id1)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q1.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q1.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, small.id4 AS small_id4, v2 FROM x JOIN small USING (id1)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q1.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=2L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -print(dbGetQuery(con, "SELECT * FROM q1.ans LIMIT 3")) ## head -print(dbGetQuery(con, "SELECT * FROM q1.ans WHERE ROWID > (SELECT count(*) FROM q1.ans) - 4")) ## tail -invisible(dbExecute(con, "DROP TABLE IF EXISTS q1.ans")) -detach_and_drop(con, 'q1.db', 'q1') +print(dbGetQuery(con, "SELECT * FROM ans LIMIT 3")) ## head +print(dbGetQuery(con, "SELECT * FROM ans WHERE ROWID > (SELECT count(*) FROM ans) - 4")) ## tail +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "medium inner on int" # q2 fun = "inner_join" -attach_and_use(con, 'q2.db', 'q2') t = system.time({ - dbExecute(con, "CREATE TABLE q2.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x JOIN medium USING (id2)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q2.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q2.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x JOIN medium USING (id2)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q2.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -invisible(dbExecute(con, "DROP TABLE IF EXISTS q2.ans")) -detach_and_drop(con, 'q2.db', 'q2') -attach_and_use(con, 'q2.db', 'q2') +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE q2.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x JOIN medium USING (id2)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q2.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q2.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x JOIN medium USING (id2)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q2.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=2L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -print(dbGetQuery(con, "SELECT * FROM q2.ans LIMIT 3")) ## head -print(dbGetQuery(con, "SELECT * FROM q2.ans WHERE ROWID > (SELECT count(*) FROM q2.ans) - 4")) ## tail -invisible(dbExecute(con, "DROP TABLE IF EXISTS q2.ans")) -detach_and_drop(con, 'q2.db', 'q2') +print(dbGetQuery(con, "SELECT * FROM ans LIMIT 3")) ## head +print(dbGetQuery(con, "SELECT * FROM ans WHERE ROWID > (SELECT count(*) FROM ans) - 4")) ## tail +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "medium outer on int" # q3 fun = "left_join" -attach_and_use(con, 'q3.db', 'q3') t = system.time({ - dbExecute(con, "CREATE TABLE q3.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x LEFT JOIN medium USING (id2)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q3.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q3.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x LEFT JOIN medium USING (id2)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q3.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -invisible(dbExecute(con, "DROP TABLE IF EXISTS q3.ans")) -detach_and_drop(con, 'q3.db', 'q3') -attach_and_use(con, 'q3.db', 'q3') +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE q3.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x LEFT JOIN medium USING (id2)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q3.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q3.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id4 AS medium_id4, medium.id5 AS medium_id5, v2 FROM x LEFT JOIN medium USING (id2)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q3.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=2L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -print(dbGetQuery(con, "SELECT * FROM q3.ans LIMIT 3")) ## head -print(dbGetQuery(con, "SELECT * FROM q3.ans WHERE ROWID > (SELECT count(*) FROM q3.ans) - 4")) ## tail -invisible(dbExecute(con, "DROP TABLE IF EXISTS q3.ans")) -detach_and_drop(con, 'q3.db', 'q3') +print(dbGetQuery(con, "SELECT * FROM ans LIMIT 3")) ## head +print(dbGetQuery(con, "SELECT * FROM ans WHERE ROWID > (SELECT count(*) FROM ans) - 4")) ## tail +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "medium inner on factor" # q4 fun = "inner_join" -attach_and_use(con, 'q4.db', 'q4') t = system.time({ - dbExecute(con, "CREATE TABLE q4.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id2 AS medium_id2, medium.id4 AS medium_id4, v2 FROM x JOIN medium USING (id5)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q4.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q4.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id2 AS medium_id2, medium.id4 AS medium_id4, v2 FROM x JOIN medium USING (id5)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q4.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -invisible(dbExecute(con, "DROP TABLE IF EXISTS q4.ans")) -detach_and_drop(con, 'q4.db', 'q4') -attach_and_use(con, 'q4.db', 'q4') +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE q4.ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id2 AS medium_id2, medium.id4 AS medium_id4, v2 FROM x JOIN medium USING (id5)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q4.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q4.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, medium.id1 AS medium_id1, medium.id2 AS medium_id2, medium.id4 AS medium_id4, v2 FROM x JOIN medium USING (id5)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q4.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=2L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -print(dbGetQuery(con, "SELECT * FROM q4.ans LIMIT 3")) ## head -print(dbGetQuery(con, "SELECT * FROM q4.ans WHERE ROWID > (SELECT count(*) FROM q4.ans) - 4")) ## tail -invisible(dbExecute(con, "DROP TABLE IF EXISTS q4.ans")) -detach_and_drop(con, 'q4.db', 'q4') +print(dbGetQuery(con, "SELECT * FROM ans LIMIT 3")) ## head +print(dbGetQuery(con, "SELECT * FROM ans WHERE ROWID > (SELECT count(*) FROM ans) - 4")) ## tail +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) question = "big inner on int" # q5 fun = "inner_join" -attach_and_use(con, 'q5.db', 'q5') t = system.time({ - dbExecute(con, "CREATE TABLE q5.ans AS SELECT x.*, big.id1 AS big_id1, big.id2 AS big_id2, big.id4 AS big_id4, big.id5 AS big_id5, big.id6 AS big_id6, v2 FROM x JOIN big USING (id3)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q5.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q5.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, big.id1 AS big_id1, big.id2 AS big_id2, big.id4 AS big_id4, big.id5 AS big_id5, big.id6 AS big_id6, v2 FROM x JOIN big USING (id3)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q5.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=1L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -invisible(dbExecute(con, "DROP TABLE IF EXISTS q5.ans")) -detach_and_drop(con, 'q5.db', 'q5') -attach_and_use(con, 'q5.db', 'q5') +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) t = system.time({ - dbExecute(con, "CREATE TABLE q5.ans AS SELECT x.*, big.id1 AS big_id1, big.id2 AS big_id2, big.id4 AS big_id4, big.id5 AS big_id5, big.id6 AS big_id6, v2 FROM x JOIN big USING (id3)") - print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM q5.ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM q5.ans LIMIT 0")))) + dbExecute(con, "CREATE TEMP TABLE ans AS SELECT x.*, big.id1 AS big_id1, big.id2 AS big_id2, big.id4 AS big_id4, big.id5 AS big_id5, big.id6 AS big_id6, v2 FROM x JOIN big USING (id3)") + print(c(nr<-dbGetQuery(con, "SELECT count(*) AS cnt FROM ans")$cnt, nc<-ncol(dbGetQuery(con, "SELECT * FROM ans LIMIT 0")))) })[["elapsed"]] m = memory_usage() -chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM q5.ans"))[["elapsed"]] +chkt = system.time(chk<-dbGetQuery(con, "SELECT SUM(v1) AS v1, SUM(v2) AS v2 FROM ans"))[["elapsed"]] write.log(run=2L, task=task, data=data_name, in_rows=in_nr, question=question, out_rows=nr, out_cols=nc, solution=solution, version=ver, git=git, fun=fun, time_sec=t, mem_gb=m, cache=cache, chk=make_chk(chk), chk_time_sec=chkt, on_disk=on_disk) -print(dbGetQuery(con, "SELECT * FROM q5.ans LIMIT 3")) ## head -print(dbGetQuery(con, "SELECT * FROM q5.ans WHERE ROWID > (SELECT count(*) FROM q5.ans) - 4")) ## tail -invisible(dbExecute(con, "DROP TABLE IF EXISTS q5.ans")) -detach_and_drop(con, 'q5.db', 'q5') +print(dbGetQuery(con, "SELECT * FROM ans LIMIT 3")) ## head +print(dbGetQuery(con, "SELECT * FROM ans WHERE ROWID > (SELECT count(*) FROM ans) - 4")) ## tail +invisible(dbExecute(con, "DROP TABLE IF EXISTS ans")) dbDisconnect(con, shutdown=TRUE) diff --git a/logs.csv b/logs.csv index 48a3e523..d6b3be3d 100644 --- a/logs.csv +++ b/logs.csv @@ -1699,3 +1699,49 @@ ip-172-31-31-147,1718279082,clickhouse,24.5.1.1763,,join,J1_1e9_NA_0_0,171827908 ip-172-31-31-147,1718279082,clickhouse,24.5.1.1763,,join,J1_1e9_NA_0_0,1718279083.67147,finish,2,1 ip-172-31-31-147,1718281186,clickhouse,24.5.1.1763,,join,J1_1e9_NA_0_0,1718281205.40778,start,, ip-172-31-31-147,1718281186,clickhouse,24.5.1.1763,,join,J1_1e9_NA_0_0,1718283056.26073,finish,3,0 +ip-172-31-31-147,1720087707,duckdb,1.0.0,1f98600c2c,join,J1_1e9_NA_0_0,1720087708.10783,start,, +ip-172-31-31-147,1720087707,duckdb,1.0.0,1f98600c2c,join,J1_1e9_NA_0_0,1720088594.76064,finish,0,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e7_1e2_0_0,1720089751.84857,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e7_1e2_0_0,1720089756.04845,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e7_1e1_0_0,1720089771.06363,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e7_1e1_0_0,1720089775.58506,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e7_2e0_0_0,1720089790.60025,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e7_2e0_0_0,1720089795.42417,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e7_1e2_0_1,1720089810.43936,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e7_1e2_0_1,1720089814.46421,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e7_1e2_5_0,1720089829.4793,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e7_1e2_5_0,1720089833.18464,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e8_1e2_0_0,1720089848.1999,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e8_1e2_0_0,1720089870.23383,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e8_1e1_0_0,1720089885.24911,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e8_1e1_0_0,1720089911.37606,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e8_2e0_0_0,1720089926.39113,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e8_2e0_0_0,1720089950.10011,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e8_1e2_0_1,1720089965.11533,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e8_1e2_0_1,1720089984.2696,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e8_1e2_5_0,1720089999.28477,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e8_1e2_5_0,1720090014.90238,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e9_1e2_0_0,1720090029.9176,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e9_1e2_0_0,1720090232.35485,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e9_1e1_0_0,1720090247.37006,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e9_1e1_0_0,1720090467.96155,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e9_2e0_0_0,1720090482.97659,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e9_2e0_0_0,1720090695.08406,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e9_1e2_0_1,1720090710.09926,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e9_1e2_0_1,1720090887.82297,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e9_1e2_5_0,1720090902.83815,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,groupby,G1_1e9_1e2_5_0,1720091058.81463,finish,2,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e7_NA_0_0,1720091073.8299,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e7_NA_0_0,1720091079.0002,finish,0,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e7_NA_5_0,1720091094.01542,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e7_NA_5_0,1720091097.9436,finish,0,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e7_NA_0_1,1720091112.9589,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e7_NA_0_1,1720091117.63519,finish,0,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e8_NA_0_0,1720091132.6503,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e8_NA_0_0,1720091173.25737,finish,0,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e8_NA_5_0,1720091188.27262,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e8_NA_5_0,1720091211.49617,finish,0,0 +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e8_NA_0_1,1720091226.51143,start,, +ip-172-31-31-147,1720089751,duckdb,1.0.0,1f98600c2c,join,J1_1e8_NA_0_1,1720091262.47306,finish,0,0 +ip-172-31-31-147,1720529276,duckdb,1.0.0,1f98600c2c,join,J1_1e9_NA_0_0,1720529277.33854,start,, +ip-172-31-31-147,1720529276,duckdb,1.0.0,1f98600c2c,join,J1_1e9_NA_0_0,1720530147.30009,finish,0,0 diff --git a/time.csv b/time.csv index 1310ba46..ecca1106 100644 --- a/time.csv +++ b/time.csv @@ -12245,3 +12245,383 @@ ip-172-31-31-147,1718281186,1718282633,join,J1_1e9_NA_0_0,1000000000,medium oute ip-172-31-31-147,1718281186,1718282691,join,J1_1e9_NA_0_0,1000000000,medium outer on int,NA,NA,clickhouse,24.5.1.1763,NA,NA,2,56.762,NA,TRUE,NA,NA,NA,TRUE ip-172-31-31-147,1718281186,1718282736,join,J1_1e9_NA_0_0,1000000000,medium inner on factor,NA,NA,clickhouse,24.5.1.1763,NA,NA,1,44.4,NA,TRUE,NA,NA,NA,TRUE ip-172-31-31-147,1718281186,1718282784,join,J1_1e9_NA_0_0,1000000000,medium inner on factor,NA,NA,clickhouse,24.5.1.1763,NA,NA,2,47.024,NA,TRUE,NA,NA,NA,TRUE +ip-172-31-31-147,1720087707,1720088411,join,J1_1e9_NA_0_0,1000000000,small inner on int,899999033,9,duckdb,1.0.0,1f98600c2c,inner_join,1,4.772,NA,TRUE,44998904641;45286789554,0.207,NA,TRUE +ip-172-31-31-147,1720087707,1720088416,join,J1_1e9_NA_0_0,1000000000,small inner on int,899999033,9,duckdb,1.0.0,1f98600c2c,inner_join,2,4.531,NA,TRUE,44998904641;45286789554,0.214,NA,TRUE +ip-172-31-31-147,1720087707,1720088427,join,J1_1e9_NA_0_0,1000000000,medium inner on int,899989698,11,duckdb,1.0.0,1f98600c2c,inner_join,1,7.819,NA,TRUE,44998219782;44956313963,0.193,NA,TRUE +ip-172-31-31-147,1720087707,1720088437,join,J1_1e9_NA_0_0,1000000000,medium inner on int,899989698,11,duckdb,1.0.0,1f98600c2c,inner_join,2,7.845,NA,TRUE,44998219782;44956313963,0.15,NA,TRUE +ip-172-31-31-147,1720087707,1720088451,join,J1_1e9_NA_0_0,1000000000,medium outer on int,1000000000,11,duckdb,1.0.0,1f98600c2c,left_join,1,8.665,NA,TRUE,49998622440;44956313963,0.171,NA,TRUE +ip-172-31-31-147,1720087707,1720088460,join,J1_1e9_NA_0_0,1000000000,medium outer on int,1000000000,11,duckdb,1.0.0,1f98600c2c,left_join,2,8.439,NA,TRUE,49998622440;44956313963,0.166,NA,TRUE +ip-172-31-31-147,1720087707,1720088472,join,J1_1e9_NA_0_0,1000000000,medium inner on factor,899989698,11,duckdb,1.0.0,1f98600c2c,inner_join,1,6.881,NA,TRUE,44998219782;44956313963,0.188,NA,TRUE +ip-172-31-31-147,1720087707,1720088480,join,J1_1e9_NA_0_0,1000000000,medium inner on factor,899989698,11,duckdb,1.0.0,1f98600c2c,inner_join,2,7.123,NA,TRUE,44998219782;44956313963,0.142,NA,TRUE +ip-172-31-31-147,1720087707,1720088525,join,J1_1e9_NA_0_0,1000000000,big inner on int,900000000,13,duckdb,1.0.0,1f98600c2c,inner_join,1,41.547,NA,TRUE,44999013966;45000583182,0.269,NA,TRUE +ip-172-31-31-147,1720087707,1720088569,join,J1_1e9_NA_0_0,1000000000,big inner on int,900000000,13,duckdb,1.0.0,1f98600c2c,inner_join,2,40.907,NA,TRUE,44999013966;45000583182,0.415,NA,TRUE +ip-172-31-31-147,1720089751,1720089753,groupby,G1_1e7_1e2_0_0,10000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.004,NA,TRUE,29998789,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089754,groupby,G1_1e7_1e2_0_0,10000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.005,NA,TRUE,29998789,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089754,groupby,G1_1e7_1e2_0_0,10000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.016,NA,TRUE,29998789,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089754,groupby,G1_1e7_1e2_0_0,10000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.014,NA,TRUE,29998789,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089754,groupby,G1_1e7_1e2_0_0,10000000,sum v1 mean v3 by id3,100000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.086,NA,TRUE,29998789;4999720,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089754,groupby,G1_1e7_1e2_0_0,10000000,sum v1 mean v3 by id3,100000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.06,NA,TRUE,29998789;4999720,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089754,groupby,G1_1e7_1e2_0_0,10000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.006,NA,TRUE,299.988;799.8942;4999.767,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089754,groupby,G1_1e7_1e2_0_0,10000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.006,NA,TRUE,299.988;799.8942;4999.767,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089754,groupby,G1_1e7_1e2_0_0,10000000,sum v1:v3 by id6,100000,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.071,NA,TRUE,29998789;79989360;499976651,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089754,groupby,G1_1e7_1e2_0_0,10000000,sum v1:v3 by id6,100000,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.054,NA,TRUE,29998789;79989360;499976651,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089754,groupby,G1_1e7_1e2_0_0,10000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.086,NA,TRUE,499920.1;288648.1,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089755,groupby,G1_1e7_1e2_0_0,10000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.07,NA,TRUE,499920.1;288648.1,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089755,groupby,G1_1e7_1e2_0_0,10000000,max v1 - min v2 by id3,100000,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.062,NA,TRUE,399882,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089755,groupby,G1_1e7_1e2_0_0,10000000,max v1 - min v2 by id3,100000,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.053,NA,TRUE,399882,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089755,groupby,G1_1e7_1e2_0_0,10000000,largest two v3 by id6,200000,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.128,NA,TRUE,19700451,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089755,groupby,G1_1e7_1e2_0_0,10000000,largest two v3 by id6,200000,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.125,NA,TRUE,19700451,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089755,groupby,G1_1e7_1e2_0_0,10000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.02,NA,TRUE,9.838641,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089755,groupby,G1_1e7_1e2_0_0,10000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.023,NA,TRUE,9.838641,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089756,groupby,G1_1e7_1e2_0_0,10000000,sum v3 count by id1:id6,10000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,0.175,NA,TRUE,499976651;10000000,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089756,groupby,G1_1e7_1e2_0_0,10000000,sum v3 count by id1:id6,10000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,0.136,NA,TRUE,499976651;10000000,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089773,groupby,G1_1e7_1e1_0_0,10000000,sum v1 by id1,10,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.005,NA,TRUE,29998597,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089773,groupby,G1_1e7_1e1_0_0,10000000,sum v1 by id1,10,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.005,NA,TRUE,29998597,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089773,groupby,G1_1e7_1e1_0_0,10000000,sum v1 by id1:id2,100,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.005,NA,TRUE,29998597,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089773,groupby,G1_1e7_1e1_0_0,10000000,sum v1 by id1:id2,100,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.005,NA,TRUE,29998597,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089773,groupby,G1_1e7_1e1_0_0,10000000,sum v1 mean v3 by id3,999951,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.13,NA,TRUE,29998597;50000559,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089773,groupby,G1_1e7_1e1_0_0,10000000,sum v1 mean v3 by id3,999951,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.126,NA,TRUE,29998597;50000559,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089773,groupby,G1_1e7_1e1_0_0,10000000,mean v1:v3 by id4,10,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.006,NA,TRUE,29.9986;79.99191;499.9807,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089773,groupby,G1_1e7_1e1_0_0,10000000,mean v1:v3 by id4,10,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.006,NA,TRUE,29.9986;79.99191;499.9807,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089773,groupby,G1_1e7_1e1_0_0,10000000,sum v1:v3 by id6,999965,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.085,NA,TRUE,29998597;79991898;499980747,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089774,groupby,G1_1e7_1e1_0_0,10000000,sum v1:v3 by id6,999965,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.098,NA,TRUE,29998597;79991898;499980747,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089774,groupby,G1_1e7_1e1_0_0,10000000,median v3 sd v3 by id4 id5,100,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.137,NA,TRUE,4999.573;2887.162,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089774,groupby,G1_1e7_1e1_0_0,10000000,median v3 sd v3 by id4 id5,100,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.135,NA,TRUE,4999.573;2887.162,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089774,groupby,G1_1e7_1e1_0_0,10000000,max v1 - min v2 by id3,999951,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.101,NA,TRUE,2789316,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089774,groupby,G1_1e7_1e1_0_0,10000000,max v1 - min v2 by id3,999951,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.106,NA,TRUE,2789316,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089775,groupby,G1_1e7_1e1_0_0,10000000,largest two v3 by id6,1999500,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.155,NA,TRUE,170016563,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089775,groupby,G1_1e7_1e1_0_0,10000000,largest two v3 by id6,1999500,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.159,NA,TRUE,170016563,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089775,groupby,G1_1e7_1e1_0_0,10000000,regression v1 v2 by id2 id4,100,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.009,NA,TRUE,0.001036507,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089775,groupby,G1_1e7_1e1_0_0,10000000,regression v1 v2 by id2 id4,100,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.007,NA,TRUE,0.001036507,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089775,groupby,G1_1e7_1e1_0_0,10000000,sum v3 count by id1:id6,10000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,0.176,NA,TRUE,499980747;10000000,0.005,NA,FALSE +ip-172-31-31-147,1720089751,1720089775,groupby,G1_1e7_1e1_0_0,10000000,sum v3 count by id1:id6,10000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,0.165,NA,TRUE,499980747;10000000,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089792,groupby,G1_1e7_2e0_0_0,10000000,sum v1 by id1,2,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.004,NA,TRUE,30000054,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089792,groupby,G1_1e7_2e0_0_0,10000000,sum v1 by id1,2,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.005,NA,TRUE,30000054,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089792,groupby,G1_1e7_2e0_0_0,10000000,sum v1 by id1:id2,4,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.005,NA,TRUE,30000054,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089792,groupby,G1_1e7_2e0_0_0,10000000,sum v1 by id1:id2,4,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.004,NA,TRUE,30000054,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089792,groupby,G1_1e7_2e0_0_0,10000000,sum v1 mean v3 by id3,4323566,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.103,NA,TRUE,30000054;216107547,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089792,groupby,G1_1e7_2e0_0_0,10000000,sum v1 mean v3 by id3,4323566,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.096,NA,TRUE,30000054;216107547,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089793,groupby,G1_1e7_2e0_0_0,10000000,mean v1:v3 by id4,2,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.006,NA,TRUE,6.000011;15.99728;99.9872,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089793,groupby,G1_1e7_2e0_0_0,10000000,mean v1:v3 by id4,2,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.005,NA,TRUE,6.000011;15.99728;99.9872,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089793,groupby,G1_1e7_2e0_0_0,10000000,sum v1:v3 by id6,4322014,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.085,NA,TRUE,30000054;79986418;499936032,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089793,groupby,G1_1e7_2e0_0_0,10000000,sum v1:v3 by id6,4322014,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.142,NA,TRUE,30000054;79986418;499936032,0.005,NA,FALSE +ip-172-31-31-147,1720089751,1720089793,groupby,G1_1e7_2e0_0_0,10000000,median v3 sd v3 by id4 id5,4,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.132,NA,TRUE,199.9701;115.4886,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089793,groupby,G1_1e7_2e0_0_0,10000000,median v3 sd v3 by id4 id5,4,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.143,NA,TRUE,199.9701;115.4886,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089794,groupby,G1_1e7_2e0_0_0,10000000,max v1 - min v2 by id3,4323566,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.227,NA,TRUE,-8263086,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089794,groupby,G1_1e7_2e0_0_0,10000000,max v1 - min v2 by id3,4323566,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.16,NA,TRUE,-8263086,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089794,groupby,G1_1e7_2e0_0_0,10000000,largest two v3 by id6,7291480,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.263,NA,TRUE,419079607,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089795,groupby,G1_1e7_2e0_0_0,10000000,largest two v3 by id6,7291480,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.275,NA,TRUE,419079607,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089795,groupby,G1_1e7_2e0_0_0,10000000,regression v1 v2 by id2 id4,4,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.008,NA,TRUE,0.000001462804,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089795,groupby,G1_1e7_2e0_0_0,10000000,regression v1 v2 by id2 id4,4,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.008,NA,TRUE,0.000001462804,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089795,groupby,G1_1e7_2e0_0_0,10000000,sum v3 count by id1:id6,10000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,0.165,NA,TRUE,499936032;10000000,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089795,groupby,G1_1e7_2e0_0_0,10000000,sum v3 count by id1:id6,10000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,0.169,NA,TRUE,499936032;10000000,0.005,NA,FALSE +ip-172-31-31-147,1720089751,1720089812,groupby,G1_1e7_1e2_0_1,10000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.005,NA,TRUE,29998789,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089812,groupby,G1_1e7_1e2_0_1,10000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.005,NA,TRUE,29998789,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089812,groupby,G1_1e7_1e2_0_1,10000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.012,NA,TRUE,29998789,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089812,groupby,G1_1e7_1e2_0_1,10000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.009,NA,TRUE,29998789,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089812,groupby,G1_1e7_1e2_0_1,10000000,sum v1 mean v3 by id3,100000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.077,NA,TRUE,29998789;4999720,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089812,groupby,G1_1e7_1e2_0_1,10000000,sum v1 mean v3 by id3,100000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.075,NA,TRUE,29998789;4999720,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089812,groupby,G1_1e7_1e2_0_1,10000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.005,NA,TRUE,299.988;799.8942;4999.767,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089812,groupby,G1_1e7_1e2_0_1,10000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.006,NA,TRUE,299.988;799.8942;4999.767,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089813,groupby,G1_1e7_1e2_0_1,10000000,sum v1:v3 by id6,100000,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.051,NA,TRUE,29998789;79989360;499976651,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089813,groupby,G1_1e7_1e2_0_1,10000000,sum v1:v3 by id6,100000,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.071,NA,TRUE,29998789;79989360;499976651,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089813,groupby,G1_1e7_1e2_0_1,10000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.067,NA,TRUE,499920.1;288648.1,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089813,groupby,G1_1e7_1e2_0_1,10000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.086,NA,TRUE,499920.1;288648.1,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089813,groupby,G1_1e7_1e2_0_1,10000000,max v1 - min v2 by id3,100000,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.067,NA,TRUE,399882,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089813,groupby,G1_1e7_1e2_0_1,10000000,max v1 - min v2 by id3,100000,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.072,NA,TRUE,399882,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089813,groupby,G1_1e7_1e2_0_1,10000000,largest two v3 by id6,200000,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.123,NA,TRUE,19700451,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089813,groupby,G1_1e7_1e2_0_1,10000000,largest two v3 by id6,200000,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.117,NA,TRUE,19700451,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089814,groupby,G1_1e7_1e2_0_1,10000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.019,NA,TRUE,9.838641,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089814,groupby,G1_1e7_1e2_0_1,10000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.016,NA,TRUE,9.838641,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089814,groupby,G1_1e7_1e2_0_1,10000000,sum v3 count by id1:id6,10000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,0.319,NA,TRUE,499976651;10000000,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089814,groupby,G1_1e7_1e2_0_1,10000000,sum v3 count by id1:id6,10000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,0.169,NA,TRUE,499976651;10000000,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089830,groupby,G1_1e7_1e2_5_0,10000000,sum v1 by id1,96,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.018,NA,TRUE,28498857,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089830,groupby,G1_1e7_1e2_5_0,10000000,sum v1 by id1,96,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.017,NA,TRUE,28498857,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089831,groupby,G1_1e7_1e2_5_0,10000000,sum v1 by id1:id2,9216,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.03,NA,TRUE,28498857,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089831,groupby,G1_1e7_1e2_5_0,10000000,sum v1 by id1:id2,9216,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.029,NA,TRUE,28498857,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089831,groupby,G1_1e7_1e2_5_0,10000000,sum v1 mean v3 by id3,95001,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.057,NA,TRUE,28498857;4749468,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089831,groupby,G1_1e7_1e2_5_0,10000000,sum v1 mean v3 by id3,95001,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.068,NA,TRUE,28498857;4749468,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089831,groupby,G1_1e7_1e2_5_0,10000000,mean v1:v3 by id4,96,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.01,NA,TRUE,287.9894;767.8529;4799.873,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089831,groupby,G1_1e7_1e2_5_0,10000000,mean v1:v3 by id4,96,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.006,NA,TRUE,287.9894;767.8529;4799.873,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089831,groupby,G1_1e7_1e2_5_0,10000000,sum v1:v3 by id6,95001,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.047,NA,TRUE,28498857;75988394;474969574,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089831,groupby,G1_1e7_1e2_5_0,10000000,sum v1:v3 by id6,95001,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.063,NA,TRUE,28498857;75988394;474969574,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089831,groupby,G1_1e7_1e2_5_0,10000000,median v3 sd v3 by id4 id5,9216,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.076,NA,TRUE,460771.2;266006.9,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089831,groupby,G1_1e7_1e2_5_0,10000000,median v3 sd v3 by id4 id5,9216,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.079,NA,TRUE,460771.2;266006.9,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089832,groupby,G1_1e7_1e2_5_0,10000000,max v1 - min v2 by id3,95001,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.061,NA,TRUE,379850,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089832,groupby,G1_1e7_1e2_5_0,10000000,max v1 - min v2 by id3,95001,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.065,NA,TRUE,379850,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089832,groupby,G1_1e7_1e2_5_0,10000000,largest two v3 by id6,190002,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.16,NA,TRUE,18700555,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089832,groupby,G1_1e7_1e2_5_0,10000000,largest two v3 by id6,190002,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.148,NA,TRUE,18700555,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089832,groupby,G1_1e7_1e2_5_0,10000000,regression v1 v2 by id2 id4,9216,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.032,NA,TRUE,9.940516,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089832,groupby,G1_1e7_1e2_5_0,10000000,regression v1 v2 by id2 id4,9216,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.029,NA,TRUE,9.940516,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089833,groupby,G1_1e7_1e2_5_0,10000000,sum v3 count by id1:id6,9999993,8,duckdb,1.0.0,1f98600c2c,group_by,1,0.232,NA,TRUE,474969574;10000000,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089833,groupby,G1_1e7_1e2_5_0,10000000,sum v3 count by id1:id6,9999993,8,duckdb,1.0.0,1f98600c2c,group_by,2,0.232,NA,TRUE,474969574;10000000,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089859,groupby,G1_1e8_1e2_0_0,100000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.024,NA,TRUE,299991302,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089859,groupby,G1_1e8_1e2_0_0,100000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.026,NA,TRUE,299991302,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089859,groupby,G1_1e8_1e2_0_0,100000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.056,NA,TRUE,299991302,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089859,groupby,G1_1e8_1e2_0_0,100000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.052,NA,TRUE,299991302,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089860,groupby,G1_1e8_1e2_0_0,100000000,sum v1 mean v3 by id3,1000000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.571,NA,TRUE,299991302;50001192,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089860,groupby,G1_1e8_1e2_0_0,100000000,sum v1 mean v3 by id3,1000000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.538,NA,TRUE,299991302;50001192,0.015,NA,FALSE +ip-172-31-31-147,1720089751,1720089861,groupby,G1_1e8_1e2_0_0,100000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.032,NA,TRUE,299.9913;799.9782;5000.104,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089861,groupby,G1_1e8_1e2_0_0,100000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.031,NA,TRUE,299.9913;799.9782;5000.104,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089861,groupby,G1_1e8_1e2_0_0,100000000,sum v1:v3 by id6,1000000,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.502,NA,TRUE,299991302;799978221;5000103938,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089862,groupby,G1_1e8_1e2_0_0,100000000,sum v1:v3 by id6,1000000,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.507,NA,TRUE,299991302;799978221;5000103938,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089862,groupby,G1_1e8_1e2_0_0,100000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.524,NA,TRUE,500020;288668.4,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089863,groupby,G1_1e8_1e2_0_0,100000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.552,NA,TRUE,500020;288668.4,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089863,groupby,G1_1e8_1e2_0_0,100000000,max v1 - min v2 by id3,1000000,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.456,NA,TRUE,3998729,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089864,groupby,G1_1e8_1e2_0_0,100000000,max v1 - min v2 by id3,1000000,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.455,NA,TRUE,3998729,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089865,groupby,G1_1e8_1e2_0_0,100000000,largest two v3 by id6,2000000,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.973,NA,TRUE,196996660,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089866,groupby,G1_1e8_1e2_0_0,100000000,largest two v3 by id6,2000000,2,duckdb,1.0.0,1f98600c2c,group_by,2,1.098,NA,TRUE,196996660,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089866,groupby,G1_1e8_1e2_0_0,100000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.139,NA,TRUE,1.006723,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089867,groupby,G1_1e8_1e2_0_0,100000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.127,NA,TRUE,1.006723,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089868,groupby,G1_1e8_1e2_0_0,100000000,sum v3 count by id1:id6,100000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,1.002,NA,TRUE,5000103938;100000000,0.057,NA,FALSE +ip-172-31-31-147,1720089751,1720089869,groupby,G1_1e8_1e2_0_0,100000000,sum v3 count by id1:id6,100000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,0.873,NA,TRUE,5000103938;100000000,0.055,NA,FALSE +ip-172-31-31-147,1720089751,1720089896,groupby,G1_1e8_1e1_0_0,100000000,sum v1 by id1,10,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.031,NA,TRUE,300012466,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089896,groupby,G1_1e8_1e1_0_0,100000000,sum v1 by id1,10,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.024,NA,TRUE,300012466,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089896,groupby,G1_1e8_1e1_0_0,100000000,sum v1 by id1:id2,100,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.024,NA,TRUE,300012466,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089896,groupby,G1_1e8_1e1_0_0,100000000,sum v1 by id1:id2,100,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.028,NA,TRUE,300012466,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089897,groupby,G1_1e8_1e1_0_0,100000000,sum v1 mean v3 by id3,9999602,3,duckdb,1.0.0,1f98600c2c,group_by,1,1.233,NA,TRUE,300012466;499941401,0.014,NA,FALSE +ip-172-31-31-147,1720089751,1720089899,groupby,G1_1e8_1e1_0_0,100000000,sum v1 mean v3 by id3,9999602,3,duckdb,1.0.0,1f98600c2c,group_by,2,1.171,NA,TRUE,300012466;499941401,0.005,NA,FALSE +ip-172-31-31-147,1720089751,1720089899,groupby,G1_1e8_1e1_0_0,100000000,mean v1:v3 by id4,10,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.031,NA,TRUE,30.00125;80.00796;499.9575,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089899,groupby,G1_1e8_1e1_0_0,100000000,mean v1:v3 by id4,10,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.035,NA,TRUE,30.00125;80.00796;499.9575,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089900,groupby,G1_1e8_1e1_0_0,100000000,sum v1:v3 by id6,9999538,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.825,NA,TRUE,300012466;800079612;4999575436,0.005,NA,FALSE +ip-172-31-31-147,1720089751,1720089901,groupby,G1_1e8_1e1_0_0,100000000,sum v1:v3 by id6,9999538,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.856,NA,TRUE,300012466;800079612;4999575436,0.03,NA,FALSE +ip-172-31-31-147,1720089751,1720089902,groupby,G1_1e8_1e1_0_0,100000000,median v3 sd v3 by id4 id5,100,4,duckdb,1.0.0,1f98600c2c,group_by,1,1.385,NA,TRUE,4999.826;2886.819,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089903,groupby,G1_1e8_1e1_0_0,100000000,median v3 sd v3 by id4 id5,100,4,duckdb,1.0.0,1f98600c2c,group_by,2,1.407,NA,TRUE,4999.826;2886.819,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089905,groupby,G1_1e8_1e1_0_0,100000000,max v1 - min v2 by id3,9999602,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.988,NA,TRUE,27890093,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089906,groupby,G1_1e8_1e1_0_0,100000000,max v1 - min v2 by id3,9999602,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.987,NA,TRUE,27890093,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089907,groupby,G1_1e8_1e1_0_0,100000000,largest two v3 by id6,19994518,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.985,NA,TRUE,1700010092,0.006,NA,FALSE +ip-172-31-31-147,1720089751,1720089908,groupby,G1_1e8_1e1_0_0,100000000,largest two v3 by id6,19994518,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.917,NA,TRUE,1700010092,0.005,NA,FALSE +ip-172-31-31-147,1720089751,1720089908,groupby,G1_1e8_1e1_0_0,100000000,regression v1 v2 by id2 id4,100,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.046,NA,TRUE,0.000091405,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089908,groupby,G1_1e8_1e1_0_0,100000000,regression v1 v2 by id2 id4,100,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.041,NA,TRUE,0.000091405,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089909,groupby,G1_1e8_1e1_0_0,100000000,sum v3 count by id1:id6,100000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,0.828,NA,TRUE,4999575436;100000000,0.054,NA,FALSE +ip-172-31-31-147,1720089751,1720089910,groupby,G1_1e8_1e1_0_0,100000000,sum v3 count by id1:id6,100000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,0.868,NA,TRUE,4999575436;100000000,0.049,NA,FALSE +ip-172-31-31-147,1720089751,1720089935,groupby,G1_1e8_2e0_0_0,100000000,sum v1 by id1,2,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.024,NA,TRUE,299988126,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089935,groupby,G1_1e8_2e0_0_0,100000000,sum v1 by id1,2,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.023,NA,TRUE,299988126,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089935,groupby,G1_1e8_2e0_0_0,100000000,sum v1 by id1:id2,4,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.026,NA,TRUE,299988126,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089935,groupby,G1_1e8_2e0_0_0,100000000,sum v1 by id1:id2,4,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.032,NA,TRUE,299988126,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089936,groupby,G1_1e8_2e0_0_0,100000000,sum v1 mean v3 by id3,43233017,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.651,NA,TRUE,299988126;2161776167,0.027,NA,FALSE +ip-172-31-31-147,1720089751,1720089937,groupby,G1_1e8_2e0_0_0,100000000,sum v1 mean v3 by id3,43233017,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.652,NA,TRUE,299988126;2161776167,0.026,NA,FALSE +ip-172-31-31-147,1720089751,1720089937,groupby,G1_1e8_2e0_0_0,100000000,mean v1:v3 by id4,2,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.035,NA,TRUE,5.999763;15.99904;100.001,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089937,groupby,G1_1e8_2e0_0_0,100000000,mean v1:v3 by id4,2,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.033,NA,TRUE,5.999763;15.99904;100.001,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089938,groupby,G1_1e8_2e0_0_0,100000000,sum v1:v3 by id6,43238066,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.644,NA,TRUE,299988126;799952220;5000051370,0.037,NA,FALSE +ip-172-31-31-147,1720089751,1720089939,groupby,G1_1e8_2e0_0_0,100000000,sum v1:v3 by id6,43238066,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.664,NA,TRUE,299988126;799952220;5000051370,0.048,NA,FALSE +ip-172-31-31-147,1720089751,1720089941,groupby,G1_1e8_2e0_0_0,100000000,median v3 sd v3 by id4 id5,4,4,duckdb,1.0.0,1f98600c2c,group_by,1,1.762,NA,TRUE,199.9981;115.4678,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089942,groupby,G1_1e8_2e0_0_0,100000000,median v3 sd v3 by id4 id5,4,4,duckdb,1.0.0,1f98600c2c,group_by,2,1.675,NA,TRUE,199.9981;115.4678,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089943,groupby,G1_1e8_2e0_0_0,100000000,max v1 - min v2 by id3,43233017,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.588,NA,TRUE,-82715914,0.011,NA,FALSE +ip-172-31-31-147,1720089751,1720089944,groupby,G1_1e8_2e0_0_0,100000000,max v1 - min v2 by id3,43233017,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.558,NA,TRUE,-82715914,0.012,NA,FALSE +ip-172-31-31-147,1720089751,1720089945,groupby,G1_1e8_2e0_0_0,100000000,largest two v3 by id6,72939140,2,duckdb,1.0.0,1f98600c2c,group_by,1,1.004,NA,TRUE,4191769306,0.018,NA,FALSE +ip-172-31-31-147,1720089751,1720089946,groupby,G1_1e8_2e0_0_0,100000000,largest two v3 by id6,72939140,2,duckdb,1.0.0,1f98600c2c,group_by,2,1.029,NA,TRUE,4191769306,0.04,NA,FALSE +ip-172-31-31-147,1720089751,1720089946,groupby,G1_1e8_2e0_0_0,100000000,regression v1 v2 by id2 id4,4,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.048,NA,TRUE,0.0000002443467,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089946,groupby,G1_1e8_2e0_0_0,100000000,regression v1 v2 by id2 id4,4,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.046,NA,TRUE,0.0000002443467,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089947,groupby,G1_1e8_2e0_0_0,100000000,sum v3 count by id1:id6,100000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,0.923,NA,TRUE,5000051370;100000000,0.05,NA,FALSE +ip-172-31-31-147,1720089751,1720089948,groupby,G1_1e8_2e0_0_0,100000000,sum v3 count by id1:id6,100000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,0.841,NA,TRUE,5000051370;100000000,0.049,NA,FALSE +ip-172-31-31-147,1720089751,1720089974,groupby,G1_1e8_1e2_0_1,100000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.023,NA,TRUE,299991302,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089974,groupby,G1_1e8_1e2_0_1,100000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.024,NA,TRUE,299991302,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089974,groupby,G1_1e8_1e2_0_1,100000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.038,NA,TRUE,299991302,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089974,groupby,G1_1e8_1e2_0_1,100000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.041,NA,TRUE,299991302,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089975,groupby,G1_1e8_1e2_0_1,100000000,sum v1 mean v3 by id3,1000000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.503,NA,TRUE,299991302;50001192,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089975,groupby,G1_1e8_1e2_0_1,100000000,sum v1 mean v3 by id3,1000000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.508,NA,TRUE,299991302;50001192,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720089976,groupby,G1_1e8_1e2_0_1,100000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.031,NA,TRUE,299.9913;799.9782;5000.104,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089976,groupby,G1_1e8_1e2_0_1,100000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.028,NA,TRUE,299.9913;799.9782;5000.104,0,NA,FALSE +ip-172-31-31-147,1720089751,1720089976,groupby,G1_1e8_1e2_0_1,100000000,sum v1:v3 by id6,1000000,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.426,NA,TRUE,299991302;799978221;5000103938,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089977,groupby,G1_1e8_1e2_0_1,100000000,sum v1:v3 by id6,1000000,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.436,NA,TRUE,299991302;799978221;5000103938,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720089977,groupby,G1_1e8_1e2_0_1,100000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.449,NA,TRUE,500020;288668.4,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089978,groupby,G1_1e8_1e2_0_1,100000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.477,NA,TRUE,500020;288668.4,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089978,groupby,G1_1e8_1e2_0_1,100000000,max v1 - min v2 by id3,1000000,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.426,NA,TRUE,3998729,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089979,groupby,G1_1e8_1e2_0_1,100000000,max v1 - min v2 by id3,1000000,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.43,NA,TRUE,3998729,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089980,groupby,G1_1e8_1e2_0_1,100000000,largest two v3 by id6,2000000,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.976,NA,TRUE,196996660,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089981,groupby,G1_1e8_1e2_0_1,100000000,largest two v3 by id6,2000000,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.952,NA,TRUE,196996660,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720089981,groupby,G1_1e8_1e2_0_1,100000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.064,NA,TRUE,1.006723,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089981,groupby,G1_1e8_1e2_0_1,100000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.065,NA,TRUE,1.006723,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720089982,groupby,G1_1e8_1e2_0_1,100000000,sum v3 count by id1:id6,100000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,0.831,NA,TRUE,5000103938;100000000,0.049,NA,FALSE +ip-172-31-31-147,1720089751,1720089983,groupby,G1_1e8_1e2_0_1,100000000,sum v3 count by id1:id6,100000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,0.777,NA,TRUE,5000103938;100000000,0.034,NA,FALSE +ip-172-31-31-147,1720089751,1720090003,groupby,G1_1e8_1e2_5_0,100000000,sum v1 by id1,96,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.069,NA,TRUE,284994735,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090003,groupby,G1_1e8_1e2_5_0,100000000,sum v1 by id1,96,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.066,NA,TRUE,284994735,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090004,groupby,G1_1e8_1e2_5_0,100000000,sum v1 by id1:id2,9216,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.124,NA,TRUE,284994735,0,NA,FALSE +ip-172-31-31-147,1720089751,1720090004,groupby,G1_1e8_1e2_5_0,100000000,sum v1 by id1:id2,9216,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.121,NA,TRUE,284994735,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090004,groupby,G1_1e8_1e2_5_0,100000000,sum v1 mean v3 by id3,950001,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.577,NA,TRUE,284994735;47500173,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720090005,groupby,G1_1e8_1e2_5_0,100000000,sum v1 mean v3 by id3,950001,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.495,NA,TRUE,284994735;47500173,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720090005,groupby,G1_1e8_1e2_5_0,100000000,mean v1:v3 by id4,96,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.026,NA,TRUE,287.9924;767.9688;4799.99,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090005,groupby,G1_1e8_1e2_5_0,100000000,mean v1:v3 by id4,96,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.034,NA,TRUE,287.9924;767.9688;4799.99,0,NA,FALSE +ip-172-31-31-147,1720089751,1720090006,groupby,G1_1e8_1e2_5_0,100000000,sum v1:v3 by id6,950001,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.439,NA,TRUE,284994735;759971497;4750083909,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720090006,groupby,G1_1e8_1e2_5_0,100000000,sum v1:v3 by id6,950001,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.452,NA,TRUE,284994735;759971497;4750083909,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720090007,groupby,G1_1e8_1e2_5_0,100000000,median v3 sd v3 by id4 id5,9216,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.468,NA,TRUE,460792.4;266033.6,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090007,groupby,G1_1e8_1e2_5_0,100000000,median v3 sd v3 by id4 id5,9216,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.447,NA,TRUE,460792.4;266033.6,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090008,groupby,G1_1e8_1e2_5_0,100000000,max v1 - min v2 by id3,950001,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.428,NA,TRUE,3798317,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090008,groupby,G1_1e8_1e2_5_0,100000000,max v1 - min v2 by id3,950001,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.436,NA,TRUE,3798317,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090009,groupby,G1_1e8_1e2_5_0,100000000,largest two v3 by id6,1900002,2,duckdb,1.0.0,1f98600c2c,group_by,1,1.081,NA,TRUE,186996834,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720090011,groupby,G1_1e8_1e2_5_0,100000000,largest two v3 by id6,1900002,2,duckdb,1.0.0,1f98600c2c,group_by,2,1.22,NA,TRUE,186996834,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720090011,groupby,G1_1e8_1e2_5_0,100000000,regression v1 v2 by id2 id4,9216,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.166,NA,TRUE,1.028772,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090011,groupby,G1_1e8_1e2_5_0,100000000,regression v1 v2 by id2 id4,9216,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.145,NA,TRUE,1.028772,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090012,groupby,G1_1e8_1e2_5_0,100000000,sum v3 count by id1:id6,99999338,8,duckdb,1.0.0,1f98600c2c,group_by,1,1.092,NA,TRUE,4750083909;100000000,0.066,NA,FALSE +ip-172-31-31-147,1720089751,1720090014,groupby,G1_1e8_1e2_5_0,100000000,sum v3 count by id1:id6,99999338,8,duckdb,1.0.0,1f98600c2c,group_by,2,1.044,NA,TRUE,4750083909;100000000,0.047,NA,FALSE +ip-172-31-31-147,1720089751,1720090134,groupby,G1_1e9_1e2_0_0,1000000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.204,NA,TRUE,2999924714,0,NA,FALSE +ip-172-31-31-147,1720089751,1720090134,groupby,G1_1e9_1e2_0_0,1000000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.259,NA,TRUE,2999924714,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090135,groupby,G1_1e9_1e2_0_0,1000000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.343,NA,TRUE,2999924714,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090135,groupby,G1_1e9_1e2_0_0,1000000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.457,NA,TRUE,2999924714,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090142,groupby,G1_1e9_1e2_0_0,1000000000,sum v1 mean v3 by id3,10000000,3,duckdb,1.0.0,1f98600c2c,group_by,1,6.383,NA,TRUE,2999924714;499986250,0.006,NA,FALSE +ip-172-31-31-147,1720089751,1720090148,groupby,G1_1e9_1e2_0_0,1000000000,sum v1 mean v3 by id3,10000000,3,duckdb,1.0.0,1f98600c2c,group_by,2,5.969,NA,TRUE,2999924714;499986250,0.005,NA,FALSE +ip-172-31-31-147,1720089751,1720090148,groupby,G1_1e9_1e2_0_0,1000000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.328,NA,TRUE,299.9925;799.9993;4999.87,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090148,groupby,G1_1e9_1e2_0_0,1000000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.302,NA,TRUE,299.9925;799.9993;4999.87,0,NA,FALSE +ip-172-31-31-147,1720089751,1720090154,groupby,G1_1e9_1e2_0_0,1000000000,sum v1:v3 by id6,10000000,4,duckdb,1.0.0,1f98600c2c,group_by,1,5.473,NA,TRUE,2999924714;7999992854;49998699478,0.141,NA,FALSE +ip-172-31-31-147,1720089751,1720090160,groupby,G1_1e9_1e2_0_0,1000000000,sum v1:v3 by id6,10000000,4,duckdb,1.0.0,1f98600c2c,group_by,2,5.682,NA,TRUE,2999924714;7999992854;49998699478,0.164,NA,FALSE +ip-172-31-31-147,1720089751,1720090165,groupby,G1_1e9_1e2_0_0,1000000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,1,4.468,NA,TRUE,499981.8;288669.2,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090169,groupby,G1_1e9_1e2_0_0,1000000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,2,4.483,NA,TRUE,499981.8;288669.2,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720090174,groupby,G1_1e9_1e2_0_0,1000000000,max v1 - min v2 by id3,10000000,2,duckdb,1.0.0,1f98600c2c,group_by,1,4.846,NA,TRUE,39987226,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720090179,groupby,G1_1e9_1e2_0_0,1000000000,max v1 - min v2 by id3,10000000,2,duckdb,1.0.0,1f98600c2c,group_by,2,4.91,NA,TRUE,39987226,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720090189,groupby,G1_1e9_1e2_0_0,1000000000,largest two v3 by id6,20000000,2,duckdb,1.0.0,1f98600c2c,group_by,1,9.543,NA,TRUE,1970001790,0.007,NA,FALSE +ip-172-31-31-147,1720089751,1720090198,groupby,G1_1e9_1e2_0_0,1000000000,largest two v3 by id6,20000000,2,duckdb,1.0.0,1f98600c2c,group_by,2,9.327,NA,TRUE,1970001790,0.006,NA,FALSE +ip-172-31-31-147,1720089751,1720090200,groupby,G1_1e9_1e2_0_0,1000000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,1.048,NA,TRUE,0.09821376,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090201,groupby,G1_1e9_1e2_0_0,1000000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,1.016,NA,TRUE,0.09821376,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090211,groupby,G1_1e9_1e2_0_0,1000000000,sum v3 count by id1:id6,1000000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,9.77,NA,TRUE,49998699478;1000000000,0.783,NA,FALSE +ip-172-31-31-147,1720089751,1720090221,groupby,G1_1e9_1e2_0_0,1000000000,sum v3 count by id1:id6,1000000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,8.298,NA,TRUE,49998699478;1000000000,0.322,NA,FALSE +ip-172-31-31-147,1720089751,1720090350,groupby,G1_1e9_1e1_0_0,1000000000,sum v1 by id1,10,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.231,NA,TRUE,2999933732,0,NA,FALSE +ip-172-31-31-147,1720089751,1720090350,groupby,G1_1e9_1e1_0_0,1000000000,sum v1 by id1,10,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.331,NA,TRUE,2999933732,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090350,groupby,G1_1e9_1e1_0_0,1000000000,sum v1 by id1:id2,100,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.259,NA,TRUE,2999933732,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090351,groupby,G1_1e9_1e1_0_0,1000000000,sum v1 by id1:id2,100,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.273,NA,TRUE,2999933732,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090357,groupby,G1_1e9_1e1_0_0,1000000000,sum v1 mean v3 by id3,99995434,3,duckdb,1.0.0,1f98600c2c,group_by,1,5.569,NA,TRUE,2999933732;4999733095,0.239,NA,FALSE +ip-172-31-31-147,1720089751,1720090363,groupby,G1_1e9_1e1_0_0,1000000000,sum v1 mean v3 by id3,99995434,3,duckdb,1.0.0,1f98600c2c,group_by,2,5.59,NA,TRUE,2999933732;4999733095,0.324,NA,FALSE +ip-172-31-31-147,1720089751,1720090363,groupby,G1_1e9_1e1_0_0,1000000000,mean v1:v3 by id4,10,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.301,NA,TRUE,29.99934;79.99944;499.9972,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090364,groupby,G1_1e9_1e1_0_0,1000000000,mean v1:v3 by id4,10,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.307,NA,TRUE,29.99934;79.99944;499.9972,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090369,groupby,G1_1e9_1e1_0_0,1000000000,sum v1:v3 by id6,99995520,4,duckdb,1.0.0,1f98600c2c,group_by,1,5.203,NA,TRUE,2999933732;7999944432;49999721740,0.205,NA,FALSE +ip-172-31-31-147,1720089751,1720090375,groupby,G1_1e9_1e1_0_0,1000000000,sum v1:v3 by id6,99995520,4,duckdb,1.0.0,1f98600c2c,group_by,2,5.765,NA,TRUE,2999933732;7999944432;49999721740,0.146,NA,FALSE +ip-172-31-31-147,1720089751,1720090391,groupby,G1_1e9_1e1_0_0,1000000000,median v3 sd v3 by id4 id5,100,4,duckdb,1.0.0,1f98600c2c,group_by,1,15.879,NA,TRUE,4999.949;2886.7,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090406,groupby,G1_1e9_1e1_0_0,1000000000,median v3 sd v3 by id4 id5,100,4,duckdb,1.0.0,1f98600c2c,group_by,2,14.303,NA,TRUE,4999.949;2886.7,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090411,groupby,G1_1e9_1e1_0_0,1000000000,max v1 - min v2 by id3,99995434,2,duckdb,1.0.0,1f98600c2c,group_by,1,5.196,NA,TRUE,278916351,0.024,NA,FALSE +ip-172-31-31-147,1720089751,1720090416,groupby,G1_1e9_1e1_0_0,1000000000,max v1 - min v2 by id3,99995434,2,duckdb,1.0.0,1f98600c2c,group_by,2,4.836,NA,TRUE,278916351,0.176,NA,FALSE +ip-172-31-31-147,1720089751,1720090426,groupby,G1_1e9_1e1_0_0,1000000000,largest two v3 by id6,199945478,2,duckdb,1.0.0,1f98600c2c,group_by,1,9.482,NA,TRUE,17000225999,0.201,NA,FALSE +ip-172-31-31-147,1720089751,1720090435,groupby,G1_1e9_1e1_0_0,1000000000,largest two v3 by id6,199945478,2,duckdb,1.0.0,1f98600c2c,group_by,2,8.614,NA,TRUE,17000225999,0.396,NA,FALSE +ip-172-31-31-147,1720089751,1720090436,groupby,G1_1e9_1e1_0_0,1000000000,regression v1 v2 by id2 id4,100,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.427,NA,TRUE,0.000008661068,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090437,groupby,G1_1e9_1e1_0_0,1000000000,regression v1 v2 by id2 id4,100,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.376,NA,TRUE,0.000008661068,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090447,groupby,G1_1e9_1e1_0_0,1000000000,sum v3 count by id1:id6,1000000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,9.619,NA,TRUE,49999721740;1000000000,0.377,NA,FALSE +ip-172-31-31-147,1720089751,1720090457,groupby,G1_1e9_1e1_0_0,1000000000,sum v3 count by id1:id6,1000000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,8.811,NA,TRUE,49999721740;1000000000,0.402,NA,FALSE +ip-172-31-31-147,1720089751,1720090571,groupby,G1_1e9_2e0_0_0,1000000000,sum v1 by id1,2,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.213,NA,TRUE,2999997259,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090571,groupby,G1_1e9_2e0_0_0,1000000000,sum v1 by id1,2,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.191,NA,TRUE,2999997259,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090572,groupby,G1_1e9_2e0_0_0,1000000000,sum v1 by id1:id2,4,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.201,NA,TRUE,2999997259,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090572,groupby,G1_1e9_2e0_0_0,1000000000,sum v1 by id1:id2,4,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.214,NA,TRUE,2999997259,0,NA,FALSE +ip-172-31-31-147,1720089751,1720090578,groupby,G1_1e9_2e0_0_0,1000000000,sum v1 mean v3 by id3,432315576,3,duckdb,1.0.0,1f98600c2c,group_by,1,6.015,NA,TRUE,2999997259;21616611234,0.289,NA,FALSE +ip-172-31-31-147,1720089751,1720090585,groupby,G1_1e9_2e0_0_0,1000000000,sum v1 mean v3 by id3,432315576,3,duckdb,1.0.0,1f98600c2c,group_by,2,5.885,NA,TRUE,2999997259;21616611234,0.293,NA,FALSE +ip-172-31-31-147,1720089751,1720090586,groupby,G1_1e9_2e0_0_0,1000000000,mean v1:v3 by id4,2,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.383,NA,TRUE,5.999995;15.9999;100.0035,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090586,groupby,G1_1e9_2e0_0_0,1000000000,mean v1:v3 by id4,2,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.347,NA,TRUE,5.999995;15.9999;100.0035,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090593,groupby,G1_1e9_2e0_0_0,1000000000,sum v1:v3 by id6,432336311,4,duckdb,1.0.0,1f98600c2c,group_by,1,6.252,NA,TRUE,2999997259;7999948710;50001752881,0.455,NA,FALSE +ip-172-31-31-147,1720089751,1720090599,groupby,G1_1e9_2e0_0_0,1000000000,sum v1:v3 by id6,432336311,4,duckdb,1.0.0,1f98600c2c,group_by,2,5.92,NA,TRUE,2999997259;7999948710;50001752881,0.301,NA,FALSE +ip-172-31-31-147,1720089751,1720090616,groupby,G1_1e9_2e0_0_0,1000000000,median v3 sd v3 by id4 id5,4,4,duckdb,1.0.0,1f98600c2c,group_by,1,16.42,NA,TRUE,200.011;115.4703,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090632,groupby,G1_1e9_2e0_0_0,1000000000,median v3 sd v3 by id4 id5,4,4,duckdb,1.0.0,1f98600c2c,group_by,2,15.013,NA,TRUE,200.011;115.4703,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090637,groupby,G1_1e9_2e0_0_0,1000000000,max v1 - min v2 by id3,432315576,2,duckdb,1.0.0,1f98600c2c,group_by,1,5.216,NA,TRUE,-827387120,0.293,NA,FALSE +ip-172-31-31-147,1720089751,1720090643,groupby,G1_1e9_2e0_0_0,1000000000,max v1 - min v2 by id3,432315576,2,duckdb,1.0.0,1f98600c2c,group_by,2,5.779,NA,TRUE,-827387120,0.342,NA,FALSE +ip-172-31-31-147,1720089751,1720090652,groupby,G1_1e9_2e0_0_0,1000000000,largest two v3 by id6,729336659,2,duckdb,1.0.0,1f98600c2c,group_by,1,7.917,NA,TRUE,41918035876,0.23,NA,FALSE +ip-172-31-31-147,1720089751,1720090662,groupby,G1_1e9_2e0_0_0,1000000000,largest two v3 by id6,729336659,2,duckdb,1.0.0,1f98600c2c,group_by,2,9.618,NA,TRUE,41918035876,0.296,NA,FALSE +ip-172-31-31-147,1720089751,1720090664,groupby,G1_1e9_2e0_0_0,1000000000,regression v1 v2 by id2 id4,4,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.405,NA,TRUE,0.00000004661463,0,NA,FALSE +ip-172-31-31-147,1720089751,1720090664,groupby,G1_1e9_2e0_0_0,1000000000,regression v1 v2 by id2 id4,4,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.419,NA,TRUE,0.00000004661463,0,NA,FALSE +ip-172-31-31-147,1720089751,1720090673,groupby,G1_1e9_2e0_0_0,1000000000,sum v3 count by id1:id6,1000000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,8.371,NA,TRUE,50001752881;1000000000,0.427,NA,FALSE +ip-172-31-31-147,1720089751,1720090684,groupby,G1_1e9_2e0_0_0,1000000000,sum v3 count by id1:id6,1000000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,9.392,NA,TRUE,50001752881;1000000000,0.431,NA,FALSE +ip-172-31-31-147,1720089751,1720090797,groupby,G1_1e9_1e2_0_1,1000000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.326,NA,TRUE,2999924714,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090797,groupby,G1_1e9_1e2_0_1,1000000000,sum v1 by id1,100,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.207,NA,TRUE,2999924714,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090797,groupby,G1_1e9_1e2_0_1,1000000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.285,NA,TRUE,2999924714,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090798,groupby,G1_1e9_1e2_0_1,1000000000,sum v1 by id1:id2,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.412,NA,TRUE,2999924714,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090803,groupby,G1_1e9_1e2_0_1,1000000000,sum v1 mean v3 by id3,10000000,3,duckdb,1.0.0,1f98600c2c,group_by,1,5.242,NA,TRUE,2999924714;499986250,0.131,NA,FALSE +ip-172-31-31-147,1720089751,1720090809,groupby,G1_1e9_1e2_0_1,1000000000,sum v1 mean v3 by id3,10000000,3,duckdb,1.0.0,1f98600c2c,group_by,2,5.191,NA,TRUE,2999924714;499986250,0.154,NA,FALSE +ip-172-31-31-147,1720089751,1720090809,groupby,G1_1e9_1e2_0_1,1000000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.274,NA,TRUE,299.9925;799.9993;4999.87,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090809,groupby,G1_1e9_1e2_0_1,1000000000,mean v1:v3 by id4,100,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.337,NA,TRUE,299.9925;799.9993;4999.87,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090814,groupby,G1_1e9_1e2_0_1,1000000000,sum v1:v3 by id6,10000000,4,duckdb,1.0.0,1f98600c2c,group_by,1,4.648,NA,TRUE,2999924714;7999992854;49998699478,0.01,NA,FALSE +ip-172-31-31-147,1720089751,1720090819,groupby,G1_1e9_1e2_0_1,1000000000,sum v1:v3 by id6,10000000,4,duckdb,1.0.0,1f98600c2c,group_by,2,5.11,NA,TRUE,2999924714;7999992854;49998699478,0.21,NA,FALSE +ip-172-31-31-147,1720089751,1720090823,groupby,G1_1e9_1e2_0_1,1000000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,1,3.938,NA,TRUE,499981.8;288669.2,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090827,groupby,G1_1e9_1e2_0_1,1000000000,median v3 sd v3 by id4 id5,10000,4,duckdb,1.0.0,1f98600c2c,group_by,2,3.814,NA,TRUE,499981.8;288669.2,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090832,groupby,G1_1e9_1e2_0_1,1000000000,max v1 - min v2 by id3,10000000,2,duckdb,1.0.0,1f98600c2c,group_by,1,4.488,NA,TRUE,39987226,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720090836,groupby,G1_1e9_1e2_0_1,1000000000,max v1 - min v2 by id3,10000000,2,duckdb,1.0.0,1f98600c2c,group_by,2,4.265,NA,TRUE,39987226,0.008,NA,FALSE +ip-172-31-31-147,1720089751,1720090844,groupby,G1_1e9_1e2_0_1,1000000000,largest two v3 by id6,20000000,2,duckdb,1.0.0,1f98600c2c,group_by,1,7.827,NA,TRUE,1970001790,0.006,NA,FALSE +ip-172-31-31-147,1720089751,1720090853,groupby,G1_1e9_1e2_0_1,1000000000,largest two v3 by id6,20000000,2,duckdb,1.0.0,1f98600c2c,group_by,2,8.476,NA,TRUE,1970001790,0.006,NA,FALSE +ip-172-31-31-147,1720089751,1720090854,groupby,G1_1e9_1e2_0_1,1000000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,1,0.601,NA,TRUE,0.09821376,0,NA,FALSE +ip-172-31-31-147,1720089751,1720090855,groupby,G1_1e9_1e2_0_1,1000000000,regression v1 v2 by id2 id4,10000,3,duckdb,1.0.0,1f98600c2c,group_by,2,0.94,NA,TRUE,0.09821376,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090864,groupby,G1_1e9_1e2_0_1,1000000000,sum v3 count by id1:id6,1000000000,8,duckdb,1.0.0,1f98600c2c,group_by,1,8.048,NA,TRUE,49998699478;1000000000,0.58,NA,FALSE +ip-172-31-31-147,1720089751,1720090876,groupby,G1_1e9_1e2_0_1,1000000000,sum v3 count by id1:id6,1000000000,8,duckdb,1.0.0,1f98600c2c,group_by,2,11.806,NA,TRUE,49998699478;1000000000,0.488,NA,FALSE +ip-172-31-31-147,1720089751,1720090939,groupby,G1_1e9_1e2_5_0,1000000000,sum v1 by id1,96,2,duckdb,1.0.0,1f98600c2c,group_by,1,0.55,NA,TRUE,2849922064,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090940,groupby,G1_1e9_1e2_5_0,1000000000,sum v1 by id1,96,2,duckdb,1.0.0,1f98600c2c,group_by,2,0.525,NA,TRUE,2849922064,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720090941,groupby,G1_1e9_1e2_5_0,1000000000,sum v1 by id1:id2,9216,3,duckdb,1.0.0,1f98600c2c,group_by,1,1.102,NA,TRUE,2849922064,0,NA,FALSE +ip-172-31-31-147,1720089751,1720090942,groupby,G1_1e9_1e2_5_0,1000000000,sum v1 by id1:id2,9216,3,duckdb,1.0.0,1f98600c2c,group_by,2,1.109,NA,TRUE,2849922064,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090950,groupby,G1_1e9_1e2_5_0,1000000000,sum v1 mean v3 by id3,9500001,3,duckdb,1.0.0,1f98600c2c,group_by,1,7.664,NA,TRUE,2849922064;474988853,0.006,NA,FALSE +ip-172-31-31-147,1720089751,1720090956,groupby,G1_1e9_1e2_5_0,1000000000,sum v1 mean v3 by id3,9500001,3,duckdb,1.0.0,1f98600c2c,group_by,2,5.851,NA,TRUE,2849922064;474988853,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720090956,groupby,G1_1e9_1e2_5_0,1000000000,mean v1:v3 by id4,96,4,duckdb,1.0.0,1f98600c2c,group_by,1,0.463,NA,TRUE,287.9927;768.0034;4799.897,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090957,groupby,G1_1e9_1e2_5_0,1000000000,mean v1:v3 by id4,96,4,duckdb,1.0.0,1f98600c2c,group_by,2,0.241,NA,TRUE,287.9927;768.0034;4799.897,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090962,groupby,G1_1e9_1e2_5_0,1000000000,sum v1:v3 by id6,9500001,4,duckdb,1.0.0,1f98600c2c,group_by,1,5.739,NA,TRUE,2849922064;7600000111;47498842806,0.139,NA,FALSE +ip-172-31-31-147,1720089751,1720090968,groupby,G1_1e9_1e2_5_0,1000000000,sum v1:v3 by id6,9500001,4,duckdb,1.0.0,1f98600c2c,group_by,2,5.798,NA,TRUE,2849922064;7600000111;47498842806,0.148,NA,FALSE +ip-172-31-31-147,1720089751,1720090973,groupby,G1_1e9_1e2_5_0,1000000000,median v3 sd v3 by id4 id5,9216,4,duckdb,1.0.0,1f98600c2c,group_by,1,4.357,NA,TRUE,460786.5;266038.4,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090977,groupby,G1_1e9_1e2_5_0,1000000000,median v3 sd v3 by id4 id5,9216,4,duckdb,1.0.0,1f98600c2c,group_by,2,4.333,NA,TRUE,460786.5;266038.4,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720090982,groupby,G1_1e9_1e2_5_0,1000000000,max v1 - min v2 by id3,9500001,2,duckdb,1.0.0,1f98600c2c,group_by,1,4.692,NA,TRUE,37982992,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720090987,groupby,G1_1e9_1e2_5_0,1000000000,max v1 - min v2 by id3,9500001,2,duckdb,1.0.0,1f98600c2c,group_by,2,5.158,NA,TRUE,37982992,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091004,groupby,G1_1e9_1e2_5_0,1000000000,largest two v3 by id6,19000002,2,duckdb,1.0.0,1f98600c2c,group_by,1,16.159,NA,TRUE,1870003947,0.006,NA,FALSE +ip-172-31-31-147,1720089751,1720091018,groupby,G1_1e9_1e2_5_0,1000000000,largest two v3 by id6,19000002,2,duckdb,1.0.0,1f98600c2c,group_by,2,14.807,NA,TRUE,1870003947,0.005,NA,FALSE +ip-172-31-31-147,1720089751,1720091020,groupby,G1_1e9_1e2_5_0,1000000000,regression v1 v2 by id2 id4,9216,3,duckdb,1.0.0,1f98600c2c,group_by,1,1.478,NA,TRUE,0.09857194,0.001,NA,FALSE +ip-172-31-31-147,1720089751,1720091021,groupby,G1_1e9_1e2_5_0,1000000000,regression v1 v2 by id2 id4,9216,3,duckdb,1.0.0,1f98600c2c,group_by,2,1.445,NA,TRUE,0.09857194,0,NA,FALSE +ip-172-31-31-147,1720089751,1720091035,groupby,G1_1e9_1e2_5_0,1000000000,sum v3 count by id1:id6,999939563,8,duckdb,1.0.0,1f98600c2c,group_by,1,12.506,NA,TRUE,47498842806;1000000000,0.517,NA,FALSE +ip-172-31-31-147,1720089751,1720091047,groupby,G1_1e9_1e2_5_0,1000000000,sum v3 count by id1:id6,999939563,8,duckdb,1.0.0,1f98600c2c,group_by,2,11.049,NA,TRUE,47498842806;1000000000,0.395,NA,FALSE +ip-172-31-31-147,1720089751,1720091077,join,J1_1e7_NA_0_0,10000000,small inner on int,8998860,9,duckdb,1.0.0,1f98600c2c,inner_join,1,0.08,NA,TRUE,450015154;347720187,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091077,join,J1_1e7_NA_0_0,10000000,small inner on int,8998860,9,duckdb,1.0.0,1f98600c2c,inner_join,2,0.077,NA,TRUE,450015154;347720187,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091077,join,J1_1e7_NA_0_0,10000000,medium inner on int,8998412,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.094,NA,TRUE,449954076;449999845,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091077,join,J1_1e7_NA_0_0,10000000,medium inner on int,8998412,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.093,NA,TRUE,449954076;449999845,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720091078,join,J1_1e7_NA_0_0,10000000,medium outer on int,10000000,11,duckdb,1.0.0,1f98600c2c,left_join,1,0.088,NA,TRUE,500043741;449999845,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091078,join,J1_1e7_NA_0_0,10000000,medium outer on int,10000000,11,duckdb,1.0.0,1f98600c2c,left_join,2,0.096,NA,TRUE,500043741;449999845,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091078,join,J1_1e7_NA_0_0,10000000,medium inner on factor,8998412,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.105,NA,TRUE,449954076;449999845,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091078,join,J1_1e7_NA_0_0,10000000,medium inner on factor,8998412,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.082,NA,TRUE,449954076;449999845,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720091078,join,J1_1e7_NA_0_0,10000000,big inner on int,9000000,13,duckdb,1.0.0,1f98600c2c,inner_join,1,0.307,NA,TRUE,450032092;449860429,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720091079,join,J1_1e7_NA_0_0,10000000,big inner on int,9000000,13,duckdb,1.0.0,1f98600c2c,inner_join,2,0.309,NA,TRUE,450032092;449860429,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720091095,join,J1_1e7_NA_5_0,10000000,small inner on int,8998860,9,duckdb,1.0.0,1f98600c2c,inner_join,1,0.111,NA,TRUE,427503549;436095569,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720091096,join,J1_1e7_NA_5_0,10000000,small inner on int,8998860,9,duckdb,1.0.0,1f98600c2c,inner_join,2,0.105,NA,TRUE,427503549;436095569,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091096,join,J1_1e7_NA_5_0,10000000,medium inner on int,8547170,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.127,NA,TRUE,406023280;423957579,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091096,join,J1_1e7_NA_5_0,10000000,medium inner on int,8547170,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.113,NA,TRUE,406023280;423957579,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091096,join,J1_1e7_NA_5_0,10000000,medium outer on int,10000000,11,duckdb,1.0.0,1f98600c2c,left_join,1,0.141,NA,TRUE,475042481;423957579,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091096,join,J1_1e7_NA_5_0,10000000,medium outer on int,10000000,11,duckdb,1.0.0,1f98600c2c,left_join,2,0.147,NA,TRUE,475042481;423957579,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720091097,join,J1_1e7_NA_5_0,10000000,medium inner on factor,8547170,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.114,NA,TRUE,406023280;423957579,0.004,NA,FALSE +ip-172-31-31-147,1720089751,1720091097,join,J1_1e7_NA_5_0,10000000,medium inner on factor,8547170,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.121,NA,TRUE,406023280;423957579,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720091097,join,J1_1e7_NA_5_0,10000000,big inner on int,8550110,13,duckdb,1.0.0,1f98600c2c,inner_join,1,0.335,NA,TRUE,406160610;427451488,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091098,join,J1_1e7_NA_5_0,10000000,big inner on int,8550110,13,duckdb,1.0.0,1f98600c2c,inner_join,2,0.324,NA,TRUE,406160610;427451488,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091116,join,J1_1e7_NA_0_1,10000000,small inner on int,8998860,9,duckdb,1.0.0,1f98600c2c,inner_join,1,0.065,NA,TRUE,449966347;386180314,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091116,join,J1_1e7_NA_0_1,10000000,small inner on int,8998860,9,duckdb,1.0.0,1f98600c2c,inner_join,2,0.057,NA,TRUE,449966347;386180314,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720091116,join,J1_1e7_NA_0_1,10000000,medium inner on int,8998412,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.098,NA,TRUE,449944125;448928500,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091116,join,J1_1e7_NA_0_1,10000000,medium inner on int,8998412,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.117,NA,TRUE,449944125;448928500,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091116,join,J1_1e7_NA_0_1,10000000,medium outer on int,10000000,11,duckdb,1.0.0,1f98600c2c,left_join,1,0.08,NA,TRUE,500043741;448928500,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091116,join,J1_1e7_NA_0_1,10000000,medium outer on int,10000000,11,duckdb,1.0.0,1f98600c2c,left_join,2,0.089,NA,TRUE,500043741;448928500,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720091117,join,J1_1e7_NA_0_1,10000000,medium inner on factor,8998412,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.098,NA,TRUE,449944125;448928500,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091117,join,J1_1e7_NA_0_1,10000000,medium inner on factor,8998412,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.094,NA,TRUE,449944125;448928500,0.002,NA,FALSE +ip-172-31-31-147,1720089751,1720091117,join,J1_1e7_NA_0_1,10000000,big inner on int,9000000,13,duckdb,1.0.0,1f98600c2c,inner_join,1,0.284,NA,TRUE,450020346;449938346,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091117,join,J1_1e7_NA_0_1,10000000,big inner on int,9000000,13,duckdb,1.0.0,1f98600c2c,inner_join,2,0.28,NA,TRUE,450020346;449938346,0.003,NA,FALSE +ip-172-31-31-147,1720089751,1720091160,join,J1_1e8_NA_0_0,100000000,small inner on int,89997128,9,duckdb,1.0.0,1f98600c2c,inner_join,1,0.433,NA,TRUE,4499430832;4388703871,0.014,NA,FALSE +ip-172-31-31-147,1720089751,1720091161,join,J1_1e8_NA_0_0,100000000,small inner on int,89997128,9,duckdb,1.0.0,1f98600c2c,inner_join,2,0.411,NA,TRUE,4499430832;4388703871,0.018,NA,FALSE +ip-172-31-31-147,1720089751,1720091162,join,J1_1e8_NA_0_0,100000000,medium inner on int,89995511,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.567,NA,TRUE,4499423746;4507751463,0.017,NA,FALSE +ip-172-31-31-147,1720089751,1720091162,join,J1_1e8_NA_0_0,100000000,medium inner on int,89995511,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.55,NA,TRUE,4499423746;4507751463,0.017,NA,FALSE +ip-172-31-31-147,1720089751,1720091164,join,J1_1e8_NA_0_0,100000000,medium outer on int,100000000,11,duckdb,1.0.0,1f98600c2c,left_join,1,0.708,NA,TRUE,4999542478;4507751463,0.039,NA,FALSE +ip-172-31-31-147,1720089751,1720091164,join,J1_1e8_NA_0_0,100000000,medium outer on int,100000000,11,duckdb,1.0.0,1f98600c2c,left_join,2,0.72,NA,TRUE,4999542478;4507751463,0.016,NA,FALSE +ip-172-31-31-147,1720089751,1720091165,join,J1_1e8_NA_0_0,100000000,medium inner on factor,89995511,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.595,NA,TRUE,4499423746;4507751463,0.02,NA,FALSE +ip-172-31-31-147,1720089751,1720091166,join,J1_1e8_NA_0_0,100000000,medium inner on factor,89995511,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.587,NA,TRUE,4499423746;4507751463,0.031,NA,FALSE +ip-172-31-31-147,1720089751,1720091169,join,J1_1e8_NA_0_0,100000000,big inner on int,90000000,13,duckdb,1.0.0,1f98600c2c,inner_join,1,2.244,NA,TRUE,4499590098;4499913694,0.018,NA,FALSE +ip-172-31-31-147,1720089751,1720091171,join,J1_1e8_NA_0_0,100000000,big inner on int,90000000,13,duckdb,1.0.0,1f98600c2c,inner_join,2,2.202,NA,TRUE,4499590098;4499913694,0.019,NA,FALSE +ip-172-31-31-147,1720089751,1720091197,join,J1_1e8_NA_5_0,100000000,small inner on int,85996086,9,duckdb,1.0.0,1f98600c2c,inner_join,1,0.727,NA,TRUE,4084298007;4658773531,0.017,NA,FALSE +ip-172-31-31-147,1720089751,1720091197,join,J1_1e8_NA_5_0,100000000,small inner on int,85996086,9,duckdb,1.0.0,1f98600c2c,inner_join,2,0.608,NA,TRUE,4084298007;4658773531,0.014,NA,FALSE +ip-172-31-31-147,1720089751,1720091198,join,J1_1e8_NA_5_0,100000000,medium inner on int,85508174,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.806,NA,TRUE,4061304227;4268317288,0.019,NA,FALSE +ip-172-31-31-147,1720089751,1720091199,join,J1_1e8_NA_5_0,100000000,medium inner on int,85508174,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.8,NA,TRUE,4061304227;4268317288,0.015,NA,FALSE +ip-172-31-31-147,1720089751,1720091201,join,J1_1e8_NA_5_0,100000000,medium outer on int,100000000,11,duckdb,1.0.0,1f98600c2c,left_join,1,0.971,NA,TRUE,4749474734;4268317288,0.022,NA,FALSE +ip-172-31-31-147,1720089751,1720091202,join,J1_1e8_NA_5_0,100000000,medium outer on int,100000000,11,duckdb,1.0.0,1f98600c2c,left_join,2,0.975,NA,TRUE,4749474734;4268317288,0.023,NA,FALSE +ip-172-31-31-147,1720089751,1720091203,join,J1_1e8_NA_5_0,100000000,medium inner on factor,85508174,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.795,NA,TRUE,4061304227;4268317288,0.015,NA,FALSE +ip-172-31-31-147,1720089751,1720091204,join,J1_1e8_NA_5_0,100000000,medium inner on factor,85508174,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.824,NA,TRUE,4061304227;4268317288,0.015,NA,FALSE +ip-172-31-31-147,1720089751,1720091207,join,J1_1e8_NA_5_0,100000000,big inner on int,85499801,13,duckdb,1.0.0,1f98600c2c,inner_join,1,2.609,NA,TRUE,4060971185;4275319617,0.014,NA,FALSE +ip-172-31-31-147,1720089751,1720091209,join,J1_1e8_NA_5_0,100000000,big inner on int,85499801,13,duckdb,1.0.0,1f98600c2c,inner_join,2,2.596,NA,TRUE,4060971185;4275319617,0.021,NA,FALSE +ip-172-31-31-147,1720089751,1720091250,join,J1_1e8_NA_0_1,100000000,small inner on int,89997128,9,duckdb,1.0.0,1f98600c2c,inner_join,1,0.382,NA,TRUE,4499308287;3953465650,0.019,NA,FALSE +ip-172-31-31-147,1720089751,1720091251,join,J1_1e8_NA_0_1,100000000,small inner on int,89997128,9,duckdb,1.0.0,1f98600c2c,inner_join,2,0.378,NA,TRUE,4499308287;3953465650,0.016,NA,FALSE +ip-172-31-31-147,1720089751,1720091251,join,J1_1e8_NA_0_1,100000000,medium inner on int,89995511,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.526,NA,TRUE,4499224468;4506958891,0.019,NA,FALSE +ip-172-31-31-147,1720089751,1720091252,join,J1_1e8_NA_0_1,100000000,medium inner on int,89995511,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.509,NA,TRUE,4499224468;4506958891,0.044,NA,FALSE +ip-172-31-31-147,1720089751,1720091253,join,J1_1e8_NA_0_1,100000000,medium outer on int,100000000,11,duckdb,1.0.0,1f98600c2c,left_join,1,0.622,NA,TRUE,4999542478;4506958891,0.017,NA,FALSE +ip-172-31-31-147,1720089751,1720091254,join,J1_1e8_NA_0_1,100000000,medium outer on int,100000000,11,duckdb,1.0.0,1f98600c2c,left_join,2,0.62,NA,TRUE,4999542478;4506958891,0.02,NA,FALSE +ip-172-31-31-147,1720089751,1720091255,join,J1_1e8_NA_0_1,100000000,medium inner on factor,89995511,11,duckdb,1.0.0,1f98600c2c,inner_join,1,0.514,NA,TRUE,4499224468;4506958891,0.02,NA,FALSE +ip-172-31-31-147,1720089751,1720091255,join,J1_1e8_NA_0_1,100000000,medium inner on factor,89995511,11,duckdb,1.0.0,1f98600c2c,inner_join,2,0.516,NA,TRUE,4499224468;4506958891,0.042,NA,FALSE +ip-172-31-31-147,1720089751,1720091258,join,J1_1e8_NA_0_1,100000000,big inner on int,90000000,13,duckdb,1.0.0,1f98600c2c,inner_join,1,2.285,NA,TRUE,4499618843;4499951833,0.019,NA,FALSE +ip-172-31-31-147,1720089751,1720091260,join,J1_1e8_NA_0_1,100000000,big inner on int,90000000,13,duckdb,1.0.0,1f98600c2c,inner_join,2,2.307,NA,TRUE,4499618843;4499951833,0.02,NA,FALSE +ip-172-31-31-147,1720529276,1720529971,join,J1_1e9_NA_0_0,1000000000,small inner on int,899999033,9,duckdb,1.0.0,1f98600c2c,inner_join,1,4.804,NA,TRUE,44998904641;45286789554,0.238,NA,TRUE +ip-172-31-31-147,1720529276,1720529976,join,J1_1e9_NA_0_0,1000000000,small inner on int,899999033,9,duckdb,1.0.0,1f98600c2c,inner_join,2,4.58,NA,TRUE,44998904641;45286789554,0.122,NA,TRUE +ip-172-31-31-147,1720529276,1720529988,join,J1_1e9_NA_0_0,1000000000,medium inner on int,899989698,11,duckdb,1.0.0,1f98600c2c,inner_join,1,8.366,NA,TRUE,44998219782;44956313963,0.203,NA,TRUE +ip-172-31-31-147,1720529276,1720529998,join,J1_1e9_NA_0_0,1000000000,medium inner on int,899989698,11,duckdb,1.0.0,1f98600c2c,inner_join,2,8.027,NA,TRUE,44998219782;44956313963,0.177,NA,TRUE +ip-172-31-31-147,1720529276,1720530013,join,J1_1e9_NA_0_0,1000000000,medium outer on int,1000000000,11,duckdb,1.0.0,1f98600c2c,left_join,1,8.907,NA,TRUE,49998622440;44956313963,0.219,NA,TRUE +ip-172-31-31-147,1720529276,1720530024,join,J1_1e9_NA_0_0,1000000000,medium outer on int,1000000000,11,duckdb,1.0.0,1f98600c2c,left_join,2,8.769,NA,TRUE,49998622440;44956313963,0.189,NA,TRUE +ip-172-31-31-147,1720529276,1720530036,join,J1_1e9_NA_0_0,1000000000,medium inner on factor,899989698,11,duckdb,1.0.0,1f98600c2c,inner_join,1,6.988,NA,TRUE,44998219782;44956313963,0.155,NA,TRUE +ip-172-31-31-147,1720529276,1720530044,join,J1_1e9_NA_0_0,1000000000,medium inner on factor,899989698,11,duckdb,1.0.0,1f98600c2c,inner_join,2,6.859,NA,TRUE,44998219782;44956313963,0.144,NA,TRUE +ip-172-31-31-147,1720529276,1720530081,join,J1_1e9_NA_0_0,1000000000,big inner on int,900000000,13,duckdb,1.0.0,1f98600c2c,inner_join,1,34.159,NA,TRUE,44999013966;45000583182,0.583,NA,TRUE +ip-172-31-31-147,1720529276,1720530123,join,J1_1e9_NA_0_0,1000000000,big inner on int,900000000,13,duckdb,1.0.0,1f98600c2c,inner_join,2,34.749,NA,TRUE,44999013966;45000583182,0.514,NA,TRUE