Big Data query systems represent data in a columnar format for fast, selective access, and in some cases (e.g. Apache Drill), perform calculations directly on the columnar data without row materialization, avoiding runtime costs. However, many analysis procedures cannot be easily or efficiently expressed as SQL. In High Energy Physics, the majority of data processing requires nested loops with complex dependencies. When faced with tasks like these, the conventional approach is to convert the columnar data back into an object form, usually with a performance price. This paper describes a new technique to transform procedural code so that it operates on columnar data natively, without row materialization. It can be viewed as a compiler pass on the typed abstract syntax tree, rewriting references to objects as columnar array lookups. We will also present performance comparisons between transformed code and conventional object-oriented code in a High Energy Physics context.
[1]
Fons Rademakers,et al.
ROOT — An object oriented data analysis framework
,
1997
.
[2]
Siu Kwan Lam,et al.
Numba: a LLVM-based Python JIT compiler
,
2015,
LLVM '15.
[3]
Joseph K. Bradley,et al.
Spark SQL: Relational Data Processing in Spark
,
2015,
SIGMOD Conference.
[4]
John Salvatier,et al.
Theano: A Python framework for fast computation of mathematical expressions
,
2016,
ArXiv.
[5]
Wes McKinney,et al.
Data Structures for Statistical Computing in Python
,
2010,
SciPy.
[6]
Andrey Gubarev,et al.
Dremel : Interactive Analysis of Web-Scale Datasets
,
2011
.
[7]
Alan Edelman,et al.
Julia: A Fast Dynamic Language for Technical Computing
,
2012,
ArXiv.