ACM Home Page
Please provide us with feedback. Feedback
Compiling object-oriented data intensive applications
Full text PdfPdf (1.18 MB)
Source International Conference on Supercomputing archive
Proceedings of the 14th international conference on Supercomputing table of contents
Santa Fe, New Mexico, United States
Pages: 11 - 21  
Year of Publication: 2000
ISBN:1-58113-270-0
Authors
Renato Ferreira  Department of Computer Science, University of Maryland, College Park, MD
Gagan Agrawal  Department of Computer and Information Sciences, University of Delaware, Newark, DE
Joel Saltz  Department of Computer Science, University of Maryland, College Park, MD
Sponsor
SIGARCH: ACM Special Interest Group on Computer Architecture
Publisher
ACM  New York, NY, USA
Bibliometrics
Downloads (6 Weeks): 4,   Downloads (12 Months): 19,   Citation Count: 5
Additional Information:

abstract   references   cited by   index terms   collaborative colleagues  

Tools and Actions: Request Permissions Request Permissions    Review this Article  
DOI Bookmark: Use this link to bookmark this Article: http://doi.acm.org/10.1145/335231.335233
What is a DOI?

ABSTRACT

Processing and analyzing large volumes of data plays an increasingly important role in many domains of scientific research. High-level language and compiler support for developing applications that analyze and process such datasets has, however, been lacking so far.In this paper, we present a set of language extensions and a prototype compiler for supporting high-level object-oriented programming of data intensive reduction operations over multidimensional data. We have chosen a dialect of Java with data-parallel extensions for specifying collection of objects, a parallel for loop, and reduction variables as our source high-level language. Our compiler analyzes parallel loops and optimizes the processing of datasets through the use of an existing run-time system, called Active Data Repository (ADR). We show how loop fission followed by interprocedural static program slicing can be used by the compiler to extract required information for the run-time system. We present the design of a compiler/n-time interface which allows the compiler to effectively utilize the existing run-time system.A prototype compiler incorporating these techniques has been developed using the Titanium front-end from Berkeley. We have evaluated this compiler by comparing the performance of compiler generated code with hand customized ADR code for three templates, from the areas of digital microscopy and scientific simulations. Our experimental results show that the performance of compiler generated versions is, on the average 21% lower, and in all cases within a factor of two, of the performance of hand coded versions.


REFERENCES

Note: OCR errors may be found in this Reference List extracted from the full text article. ACM has opted to expose the complete List rather than only correct and linked references.

 
1
A. Bik, J. Villacis, and D. Gannon. javar: A prototype Java restructing compiler. Concurrency Practice and Ezperience, 9(11):1181-91, November 1997.
 
2
Francois Bodin, Peter Beckman, Dennis Gannon, Srinivas Narayana, and Shelby X. Yang. Distributed pC.t-+: Basic ideas for an object parallel language. Scientific Programming, 2(3), Fall 1993.
3
 
4
Bryan Carpenter, Guansong Zhan, Geoffrey Fox, Yuhong Wen, and Xinyng Li. HPJava: Data-parallel extensions to Java. Available from http ://wwv. npac. syr. edu/proj ecCs/pcrc/July97/doc, hCml, December 1997.
 
5
6
7
8
 
9
 
10
High Performance Fortran Forum. Hpf language specification, version 2.0. Available from http://www.crpe.rice.edu/HPFF/versions/hpfP/files/hpfv20.ps.gz, January 1997.
11
 
12
 
13
David Kotz. Disk-directed I/O for MIMD multiprocessors. In Proceedings of the 1994 Symposium on Operating Systems Design and Implementation, pages 61-74. ACM Press, November 1994.
 
14
Tahsin M. Kurc, Alan Sussman, and Joel Saltz. Coupling multiple simulations via a high performance customizable database system. In Proceedings of the Ninth SIAM Conference on Parallel Processing for Scientific Computing. SIAM, March 1999.
 
15
16
 
17
18
 
19
 
20
K. Yelick, L. Semenzato, G. Pike, C. Miyamoto, B. Libit, A. Krishnamurthy, P. Hilfinger, S. Graham, D. Gay, P. Colella, and A. Aiken. Titanium: A high-performance Java dialect. Concurrency Practice and Ezperience, 9(11) November 1998.


Collaborative Colleagues:
Renato Ferreira: colleagues
Gagan Agrawal: colleagues
Joel Saltz: colleagues