Analyzing Massive Astrophysical Datasets: Can Pig/Hadoop or A Relational DBMS Help?

Download as pdf or txt
Download as pdf or txt
You are on page 1of 10

Analyzing Massive Astrophysical Datasets: Can

Pig/Hadoop or a Relational DBMS Help?


Sarah Loebman1 , Dylan Nunley2 , YongChul Kwon3 , Bill Howe4 , Magdalena Balazinska5 , and Jeffrey P. Gardner6
University of Washington, Seattle, WA
1
sloebman@astro.washington.edu
{2 dnunley,3 yongchul,4 billhowe,5 magda}@cs.washington.edu
6
gardnerj@phys.washington.edu

Abstract As the datasets used to fuel modern scientific discov- to artificially limit the scale or resolution of their simulations
ery grow increasingly large, they become increasingly difficult to in order to accommodate inadequate data analysis tools.
manage using conventional software. Parallel database manage- Existing parallel database management systems, such as
ment systems (DBMSs) and massive-scale data processing systems
such as MapReduce hold promise to address this challenge. Oracle [1], DB2 [2], Teradata [3], and Greenplum [4], and
However, since these systems have not been expressly designed new types of massive-scale data processing platforms, such as
for scientific applications, their efficacy in this domain has not MapReduce [5], Hadoop [6], and Dryad [7], can potentially
been thoroughly tested. facilitate these data analysis tasks. Each system is equipped
In this paper, we study the performance of these engines with a high-level language (e.g., SQL [8], DryadLINQ [9],
in one specific domain: massive astrophysical simulations. We
develop a use case that comprises five representative queries. We Pig Latin [10], or Sawzall [11]). Programs written in these
implement this use case in one distributed DBMS and in the languages are compiled into a graph of operators called a plan.
Pig/Hadoop system. We compare the performance of the tools to The plan is then executed as a parallel program distributed
each other and to hand-written IDL scripts. We find that certain across a cluster. However, the ability of these tools to support
representative analyses are easy to express in each engines high- realistic scientific analysis is not clear; some argue that these
level language and both systems provide competitive performance
and improved scalability relative to current IDL-based methods. systems are wholly ill-suited to the task [12]. Although these
systems have limitations, the absence of fully developed
I. I NTRODUCTION alternatives [12] raises the question: are these systems still
Advances in high-performance computing are having a better than the state of the art, which consists of writing custom
transformative impact on many scientific disciplines. Advances scripts and code to carry out the analysis?
in compute power and an increased ability to harness this In this paper, we strive to answer this question for one
power enable scientists, among other tasks, to run simulations specific domain: astrophysical simulations. DBMSs have not
at an unprecedented scale. Simulations are used to model been previously applied to this data type: DBMSs are used
the behavior of complex natural systems ranging from the by observational astronomers to store sky survey images [13],
interaction of subatomic particles to the evolution of the [14], but not to store astrophysical simulation results.
universe. These simulations produce an ever more massive We explore the emergent data management needs of the
amount of data that must be analyzed, interacted with, and University of Washingtons N-body Shop group, which
understood by the scientist. specializes in the development and utilization of large-scale
While scientists have access to tools and an unprecedented simulations (specifically, N-body tree codes [15]). These
amount of computational resources to run increasingly com- simulations serve to investigate the formation and evolution of
plex simulations, their ability to analyze the resulting data large scale structures in the universe. The UW N-body Shop
remains limited. The reason is not lack of expertise, but is representative of the current state-of-the-art in astrophysical
simple economics. A simulation code is typically used by cosmological simulation. In 2008, the N-body Shop was the
very large number of researchers, and it is often in use 10th largest consumer of NSF Teragrid [16] time, using 7.5
for 10 years or more. Data analysis applications, however, million CPU hours and generated 50 terabytes of raw data,
are often unique to individual researchers and evolve much with an additional 25 terabytes of post-processing information.
more quickly. Therefore, while it may be affordable for a In this paper, we discuss the analysis of the results of three
science discipline to invest the time and effort required to simulations with snapshots (i.e. a snapshot of the state of the
develop highly scalable simulation applications using hand- simulated system at a single instant in time) ranging in size
written code in languages like Fortran or C, it is often from 170 MB to 36 GB. The total amount of data generated
infeasible for individual researchers to each invest a similar by each simulation (i.e., all snapshots together) ranges in size
effort in developing their own scalable hand-written data from 55 GB to a few TB.
analysis applications. Consequently, data analysis is becoming We find that the required analysis involves three types of
the bottleneck to discovery: It is not uncommon for scientists tasks: filtering and correlating the data at different times in
TABLE I
the simulation, clustering data within one simulated timestep,
S IMULATION DATASETS STUDIED IN THE PAPER .
and querying the clustered data. In this paper, we focus on the
first group of tasks and study how well two existing types of Name No. Particles Snapshot Size (binary)
tools a distributed relational DBMS and a MapReduce-like dbtest128g 4.2 million 169 MB
cosmo50 33.6 million 1.4 GB
system with a declarative front-end called Pig/Hadoop [10], cosmo25 916.8 million 36 GB
[6] support this analysis. We implement the use case in
each of the two tools and measure its performance on clusters
of different sizes. We compare the performance and usability
programs, and scripts created over the past 15 years. Since
of these two tools to the state-of-the-art manually written
the simulation code generates one output file per snapshot,
programs and scripts. We report our experimental results and
all post-processing tools are written to read this standard
also discuss our general experience with using these tools in
snapshot-based format. Many of these tools generate additional
this specific context including what we find to be some benefits
data, which are then stored in separate files.
and limitations of each type of system.
Overall, we find that both types of engines offer a com- Some tools were developed by the N-body Shop, and are
pelling alternative to current scientific data management strate- widely used within the astrophysical simulation community.
gies. In particular, the relational DBMS offers excellent per- One such tools is TIPSY [17], an X11-based particle vi-
formance when manipulating datasets whose size significantly sualization tool modeled after the Santa Cruz/Lick image
outweighs the available memory. On the other hand, the processing package VISTA. There are also several codes,
Pig/Hadoop system offers somewhat more consistent speed-up group finders [18], [19], [20], [21] that identify physi-
and performs as well as the DBMS once the cluster becomes cally meaningful collections of particles within the simulation
sufficiently large. snapshots. Other tools are scripts that are usually written in
interpreted languages such as Python, Perl, or Interactive Data
II. A STRONOMY S IMULATION A PPLICATION D OMAIN Language (IDL) [22]. A trait common to these tools is that
Cosmological simulations are used to study how structure they operate in main memory they require at least one
forms and evolves in the universe on size scales ranging from a full snapshot to be read into RAM before any processing can
few million light-years to several billion light-years. Typically, begin.
the simulations start shortly after the Big Bang and run the full Astrophysicists are facing two big challenges in continu-
lifespan of the universe, roughly 14 billion years. Simulations ing to use existing strategies for data analysis. The first is
provide an invaluable contribution to our understanding of how scalability: the size of the simulations is growing much faster
the universe evolved, because the overwhelming majority of than the memory capacity of shared-memory platforms on
matter in the universe does not emit light and is therefore invis- which to deploy serial data analysis software. Secondly, the
ible to direct detection by telescopes. Furthermore, simulations I/O bandwidth of a single node has increased little over the
represent our only way to experiment with cosmic objects past decade, meaning that simulation snapshots are incurring
such as stars, galaxies, black holes, and clusters of galaxies. an increasingly long delay when loading data into memory.
For these reasons, astrophysics was among the first scientific Consequently, the queries that filter and correlate data from
disciplines to utilize leading-edge computational resources, a different snapshots require very large main memories RAM
heritage that has continued to the present day. and become highly I/O constrained.
In the simulations under discussion, the universe is rep- Scalability in RAM and I/O bandwidth can be achieved
resented by a set of particles. There are three varieties of by harnessing large numbers of distributed-memory nodes,
particles: dark matter, gas, and stars. Some properties (e.g., provided ones data analysis software can scale on such ar-
position, mass, velocity) are common to all particles. Other chitectures. The astrophysical community has investigated the
properties (e.g., formation time, temperature, chemical con- efficacy of application-specific parallel libraries to reduce the
tent) are specific only to certain types. All particles are development time of scalable in-RAM data analysis pipelines.
points in a 3D space and are simulated over a series of For example, Ntropy [23], [24] provides a parallel library
discrete timesteps. Every few timesteps, the simulator outputs for the analysis of massive particle datasets, and Ntropy
a snapshot of the state of the simulated universe. Each snapshot applications can scale to thousands of distributed-memory
records all properties of all particles at the time of the nodes. The principle disadvantages of Ntropy are that 1) it
snapshot. Simulations of this type currently have between still requires a steep learning curve and 2) this knowledge is
108 109 particles (with approximately 100 bytes per particle) not transferable outside of particle-based scientific datasets.
and output between a few dozen and a few hundred snapshots DBMSs and frameworks like Hadoop [6] and Dryad [7]
per run. Table I shows the names of each simulation used offer potentially the same scalability as application-specific
in our experiments and the sizes of their snapshot files. The libraries, but can also be used across a broad range of science
largest run, cosmo25, has a total of a few TB of snapshot files. applications. They may also be easier to learn, especially if the
For the UW N-body group, the state-of-the-art approach researcher can utilize the declarative languages built on top of
to data analysis in the absence of relational DBMSs and the frameworks, such as Pig Latin [10] and DryadLINQ [9].
MapReduce is to use a combination of many handwritten tools, Consequently, we wish to assess the effectiveness of these
TABLE II
Q2 is another common type of select query that involves
ATTRIBUTES DESCRIBING PARTICLES IN A SIMPLE COSMOLOGY SCHEMA
returning particles based upon physical proximity. In contrast
Attribute Description Particles described to Q1, Q2 demonstrates the need for spatial operators and
iOrder unique identifier all help us assess the expressiveness of the competing tools. A
X,Y ,Z position in Cartesian coordinates all
Vx ,Vy ,Vz velocity components all
concrete version of Q2 which we use in our experiments
Phi gravitational potential all finds all the stars that lie within the virial radius of the
Metals proportion of heavy elements gas, stars center of mass of a given halo. A halo is the ensemble of
Tform formation time stars particles that surrounds a galaxy or cluster of galaxies. The
Eps gravitational softening radius stars, dark matter
DenSmooth local smoothed density dark matter virial radius is the radius of a sphere, centered on a galaxy,
Hsmooth smoothing radius gas within which virial equilibrium holds. Virial equilibrium
Rho density gas describes a system in dynamic balance; stars within the virial
radius are gravitationally bound to the system. Astronomers
use the virial radius to consistently define the edge of the halo.
tools for scientific data analysis in the regime where current
state-of-the-art strategies have become constrained by I/O Q3: Return all particles of type T within distance R
bandwidth and shared memory requirements. of point P whose property X is above a threshold
III. U SE CASE computed at timestep S1 .
In order to study how well existing data management sys- Complex calculations can be expressed in a database as
tems support the analysis tasks described above, we develop a user-defined functions (UDFs). A UDF provides astronomers
concrete use case comprising a small number of representative a framework for expressing more sophisticated selection con-
queries. ditions based upon data interdependencies.
Our concrete example of Q3 uses a UDF to calculate
A. Data Model the virial temperature from a galaxys mass and radius.
Since different species of particles have different properties, An astronomer might ask to return all gas particles whose
we model the data as three different relations, or tables: one temperature is above the virial temperature at a given step
per type of particle. The attributes for each relation are the within a given halo. Such particles are considered shocked.
ones shown in Table II. Furthermore, we horizontally partition The proportion of shocked gas to total gas tells astronomers
each table: Each partition holds the data for one snapshot and about how the galaxy has been assembled over time.
one species of particles.
For each dataset, we analyzed two snapshots of data. Q4: Return gas particles destroyed between step S1
Snapshots are output from the simulation in TIPSY binary and S2 .
format. In this binary format, this amounted to 169 MB, 1.4 In addition to the select queries discussed above, scientists
GB, and 36 GB of data from simulations dbtest128g, cosmo50, often need to correlate information across two snapshots.
and cosmo25 respectively. In particular, astronomers often want to track the evolution
B. Selection and Correlation Queries of particles. For example, a scientist may want to see the
identifiers of all particles destroyed between two snapshots.
The simplest form of analysis that astronomers perform on
Such queries correspond in SQL to what are known as join
the output of a simulation is to look-up specific particles that
queries since they join together the information from two
match given conditions.
different snapshots.
Q1: Return all particles whose property X is above A join operator finds pairs of tuples, one from each of two
a given threshold at step S1. input relations, that share some property. In this query, the
Q1 corresponds to one of the simplest possible filtering join condition associates identical particles using the unique
queries: find all gas particles with temperature greater than identifier, iOrder. Destroyed particles are identified as those
150000 K. Gas particles at temperatures at or above 105 K are values of iOrder from timestep S1 that do not have a
categorized as warm/hot; these particles are typically found corresponding partner in timestep S2 .
in the regions between galaxies known as the Intergalactic In these simulations, stars form from gas; each gas particle
Medium (IGM). Astronomers seek to understand properties can form up to four star particles before it is deleted from
of the IGM such as spatial extent and total mass, and a tem- the simulation. For our concrete version of Q4, we select
perature threshold is an effective way to distinguish particles deleted gas particles, as they indicate regions of vigorous star
belonging to the IGM from the rest of the simulation. formation.
These filtering queries correspond in SQL to what is known
as select queries, since they return only selected rows. Q5: Return all particles whose property X changes
from S1 to S2 .
Q2: Return all particles of type T within distance Along with tracking how many particles are created or
R of point P . deleted, astronomers are often also interested in the change
of properties over time. For example, when stars explode in apply the condition metals=0 either before or after joining
supernovae, they release heavy elements called metals into the timesteps g1 and g2. It can then choose from one of several
intergalactic medium. Astronomers are interested in tracking join algorithms depending on the properties of the input data.
what happens to the gas that encounters these metals and Out of this space of plans, the system selects a good plan
becomes enriched. Our concrete version of Q5 selects gas by estimating the cost of the candidates. All modern DBMS
that starts with zero metal content at one step and has a non- perform this style of cost-based algebraic optimization.
zero metal content at a later time step so as to return recently RDBMSs use indexes to reduce the number of I/O opera-
enriched material. tions in a query plan. An index is a data structure that enables
In summary, the simplest form of data analysis can thus be the DBMS to skip over irrelevant data without reading it into
expressed in the form of select-project-join (SPJ) queries (the memory. The two most common indexes used in an RDBMS
project operator simply discards unwanted attributes). The are the hash index (amortized constant time access) and the B+
general class of SPJ queries is considered to be the simplest tree index (logarithmic time access with robust performance
non-trivial subset of the full relational algebra, the formal on varying data). Indexes may have additional properties that
basis for SQL. affect their performance [26].
Simple queries such as Q1, Q2, and Q3 admit a trivial Declarative queries provide a means to automatically
parallel evaluation strategy: partition the data across N nodes, achieve disk scalability as long as the dataset fits on disk,
evaluate the same query on each node, and merge the results. the RDBMS is guaranteed to finish every query. A RDBMS
These search-oriented queries are sometimes amenable to the will never crash with an out-of-memory error, and, if config-
use of indexes to quickly locate particles that match a specific ured properly, will never thrash virtual memory. The reason
condition. If indexes are not available, the best strategy is to these guarantees are possible is that the user cannot control
do an exhaustive scan of every particle as quickly as possible. which algorithms are used, and therefore cannot instruct the
Queries Q4 & Q5 can be expensive to compute because RDBMS to anything untoward such as loading the entire
they require correlating two large datasets. A naive algorithm dataset into memory before operating on it. An SQL query
might build a large data structure in memory for particles in is also frequently far shorter and simpler than an equivalent
S1 then probe this data structure for each value from S2 . This implementation in a general-purpose programming language.
algorithm is limited by the available memory of the computer. Query 1. As shown in Table III, Q1 specifies that we are
Alternatively, relational databases perform a similar algorithm, interested in the iOrder of all particles inside table gas43,
but automatically dividing the work into pieces that fit in main which represents all gas particles in snapshot 43 of our largest
memory the limiting factor is then the size of the disk rather simulation, cosmo25, with attribute temp above a threshold.
than available main memory1 . Parallel programming models To improve performance, we created a B-tree index on the
such as MapReduce use a similar mechanism to provide temp attribute using a simple CREATE INDEX command.
scalability across multiple computers: each computer handles Query 2. Q2 is an example of query with a spatial predicate
a particular set of particle identifiers, so no one computer that is awkward to express in plain SQL (though ,any relational
performs too much work. We evaluate both approaches in DBMSs now include spatial extensions). Database Z supports
Section VI. a spatial index but we did not use it in order to study query
performance when all input data must be read, as in the case
IV. R ELATIONAL DBMS I MPLEMENTATION of Pig and other MapReduce-like systems.
Relational DBMSs (RDBMSs) have a long history of pro- Query 2 also exhibits an unusual idiom: Multiple relations
viding high performance when querying or updating disk- referenced in the FROM clause, but no join condition between
resident data [25]. In our experiments, we use a common, com- them. In this case, SQL generates the cross product of the
mercial RDBMS, which we call Database Z. We performed relations: every possible pairwise combination of tuples is
no special tuning of Database Z. produced in the output. In this case, this idiom is used only to
In a RDBMS, queries are expressed in SQL a declarative bring just one appropriate tuple into context from the stat43
language in which users describe the result they need, but not table, so the number of tuples does not actually increase.
specifically how to go about obtaining it. For example, the Query 3. Q3 is similar to Q2, but 1) adds an additional con-
queries in our use case can be expressed in SQL as shown in dition on the temp attribute, and 2) expresses the temperature
Table III. The RDBMS analyzes each such query and decides threshold as a calculation involving a user-defined function.
on an evaluation strategy, called a query plan. The space of The index on temperature we created for Q1 can potentially
possible plans is large in part since the underlying formalism be reused in this query.
of SQL called the relational algebra admits a variety of Query 4 & 5. Q4 and Q5 both involve joins on the iOrder
algebraic rewrite rules. Additionally, each logical operator has attribute, so we create an index on iOrder. In a production
many different physical implementations that the system can system, iOrder would likely be designated a primary key,
choose from. For example, in Q5, the system can choose to which would enable additional optimizations that we discuss in
Section VI. Q4 could be expressed using either a join or a set
1 DBMSs also use other algorithms for joining large relations such as difference operation. We chose the former formulation to test
nested-loop and sort-merge. the general performance of correlation queries. In particular,
we identified particles at one timestep that have no matching is running on a single enterprise-scale server or across many
partner in a later timestep, implying that the particle was commodity workstation-class machines.
destroyed during the course of the simulation. Since the remote servers are known to support full SQL
Distributed query processing. Several RDBMSs [4], [27], queries, the optimizer on the head node that receives the query
[28] support parallel queries, where data can be partitioned is free to reorder operations to push more work down to the
across several nodes and accessed simultaneously. An RDBMS data nodes. For example, in the query above, a nave evaluation
can support inter-operator parallelism or intra-operator par- strategy would be to stream all tuples from all nodes back
allelism or both. Inter-operator parallelism refers to the ability to the head node, where the filter temp > 150000 would be
of the query scheduler to map different subplans to different applied. A better plan, however, is one found automatically by
nodes for simultaneous execution. Intra-operator parallelism Database Z. It pushes the filter down to each node, essentially
refers to the ability to instantiate multiple copies of one oper- generating an equivalent query of the form:
ator that work in concert to process a partitioned dataset. Both SELECT * FROM orlando.cosmo50.dbo.gas43
forms rely crucially on partitioning the data appropriately. WHERE temp > 150000
UNION ALL
Database Z does not support intra-operator parallelism, but SELECT * FROM newyork.cosmo50.dbo.gas43
it does support a robust and thorough form of inter-operator WHERE temp > 150000

parallelism. We use the term distributed queries to distinguish The Database Z optimizer does not actually generate a
the class of queries supported by this system from those new SQL statement; queries are represented internally as
involving intra-operator parallelism [4], [27], [28], [29], [30]. relational algebra expressions. This example simply illustrates
In the system that we study, remote database servers may the semantics of the optimization applied.
be linked to a head instance of Database Z, allowing them to In our experiments, we partitioned the data across 1, 2, 4 and
be referenced in queries using an extra layer of qualification. 8 nodes to assess scalability and performance of distributed
For example, the following query accesses data from a table queries in Database Z. We created the appropriate views for
named gas43 in the default namespace dbo of a database each configuration. We manually adjusted a few of these views
named cosmo50 on a remote server named orlando: to compel the optimizer to use a more efficient plan.
SELECT * FROM orlando.cosmo50.dbo.gas43
V. P IG /H ADOOP I MPLEMENTATION
It would be tedious and error-prone to explicitly reference
every node in the cluster each time one wished to query a MapReduce [5] is a programming model for processing
partitioned table. Worse, if the data is reorganized to utilize massive-scale data sets in large shared-nothing clusters. Users
more nodes, existing queries would not function until they specify a map function that generates a set of key/value pairs,
were updated. Thankfully, relational databases natively provide and a reduce function that merges or aggregates all values
a mechanism for logical data independence in the form of associated with the same key. A single combination of a map
views. A view is simply a named query that can be referenced function and a reduce function is called a job. In SQL, a
as a table in another query. For example, the following MapReduce job can usually be expressed as an aggregation
statement creates a view named gas60 dist computed as the query (i.e., a query involving a GROUP BY clause).
union of three subqueries, each referencing a different table MapReduce programs are automatically parallelized and
on a different node in the cluster. The output of this query is executed on a cluster. Data partitioning, scheduling, and
not pre-computed. The view is like a virtual table. inter-machine communication are all handled by the run-time
system. Note, however, that these systems do not offer any
CREATE VIEW gas43_dist AS
SELECT * FROM orlando.cosmo50.dbo.gas43 smart partitioning. The input data is simply split into fixed-
UNION ALL size chunks (a recommended 128MB in our experiments) that
SELECT * FROM newyork.cosmo50.dbo.gas43
UNION ALL are spread across nodes. In contrast, relational DBMSs enable
SELECT * FROM beijing.cosmo50.dbo.gas43 users to specify how the data should be partitioned and exploit
the partitioning knowledge during query optimization. Overall,
This kind of view is referred to as a distributed partitioned
however, MapReduce provides a lightweight alternative to
view in the Database Z documentation. The UNION ALL clause
parallel programming and is becoming popular in variety of
merges the results from two subqueries. This clause is distin-
domains.
guished from UNION; the latter checks for and removes any
duplicate tuples, which is an expensive operation that can be Hadoop [6] is an open-source implementation of MapRe-
avoided if the partitions are known to be disjoint a priori. duce written in Java. Because Hadoop has no predefined
schema, data must be repeatedly parsed at the beginning of
With this view established, we can write the following query
each query. However, because the parsing algorithm we used
to access data across all three nodes transparently:
is extremely straight-forward, this extra step did not introduce
SELECT * FROM gas43_dist any significant overhead.
WHERE temp > 150000
The Pig [10] engine provides a high-level language over the
No explicit knowledge of or reference to the distribution low level map and reduce primitives to simplify programming.
policy is necessary the user need not care if this database Users write procedural scripts in Pig Latin that are compiled
TABLE III
I MPLEMENTATIONS OF Q1-Q5 IN SQL AND P IG L ATIN .

Q# SQL Pig Latin


Q1 // LOAD and STORE statements are only presented for Q1
SELECT iOrder rawGas = LOAD cosmo25cmb.768g.00043_gas.bin
FROM gas43 USING quark.pig.BinCosmoLoad(gas);
WHERE temp > 150000 gas = FOREACH rawGas
GENERATE $0 AS pid:long, $10 AS temp:double;
filteredGas = FILTER gas BY temp > 150000;
filteredGasPid = FOREACH filteredGas GENERATE pid;
STORE filteredGasPid INTO q1_cosmo25.00043_gas;
Q2 and Q3 SELECT g.iOrder dark = FOREACH rawDark
FROM gas43 g, stat43 h GENERATE $0 AS pid:long, $2 AS px:double,
WHERE (g.x-(h.Xc-12.5)/25)*(g.x-(h.Xc-12.5)/25) $3 AS py:double, $4 AS pz:double;
+ (g.y-(h.Yc-12.5)/25)*(g.y-(h.Yc-12.5)/25) filteredDark = FILTER dark BY
+ (g.z-(h.Zc-12.5)/25)*(g.z-(h.Zc-12.5)/25) (px-($XC-12.5)/25)*(px-($XC-12.5)/25) +
<= (h.Rvir*h.Rvir)/6.25e8 (py-($YC-12.5)/25)*(py-($YC-12.5)/25) +
AND h.HaloID = 1 (pz-($ZC-12.5)/25)*(pz-($ZC-12.5)/25)
// The following condition appears only in Q3 <= ($RVIR*$RVIR)/6.25e8
AND g.temp > VirialTemp(h.Rvir, h.Mvir) // The following condition appears only in Q3
AND g.temp > VirialTemp(h.Rvir, h.Mvir)
filteredDarkPid = FOREACH filteredDark GENERATE pid;
Q4 SELECT g1.iOrder star43 = FOREACH rawGas43 GENERATE $0 AS pid:long;
FROM gas43 g1 FULL OUTER JOIN gas60 g2 star60 = FOREACH rawGas60 GENERATE $0 AS pid:long;
ON g1.iOrder=g2.iOrder groupedGas = COGROUP star43 BY pid, star60 BY pid;
WHERE g2.iOrder is NULL selectedGas = FOREACH groupedGas GENERATE
FLATTEN((IsEmpty(gas43) ? null : gas43)) as s43,
FLATTEN((IsEmpty(gas60) ? null : gas60)) as s60;
destroyed = FILTER selectedGas BY s60 is null;
Q5 SELECT g1.iOrder gas43 = FOREACH rawGas43
FROM gas43 g1, gas60 g2 GENERATE $0 AS pid:long, $2 AS px:double,
WHERE g1.iOrder = g2.iOrder $3 AS py:double, $4 AS pz:double,
AND g1.metals = 0 $12 AS metals:double;
AND g2.metals > 0 gas60 = FOREACH rawGas60
GENERATE $0 AS pid:long, $2 AS px:double,
$3 AS py:double, $4 AS pz:double,
$12 AS metals:double;
gas43 = FILTER gas43 BY metals == 0.0;
gas60 = FILTER gas60 BY metals > 0.0;
gasGrouped = COGROUP gas43 BY pid, gas60 BY pid;
filteredGas = FILTER gasGrouped BY NOT IsEmpty(gas43)
AND NOT IsEmpty(gas60);
filteredGasPid = FOREACH filteredGas GENERATE group;

into a network of MapReduce jobs. Each query in our astron- is syntactically similar to Q2 and Q1, but uses a UDF called
omy use case can be encoded as a Pig Latin script, as shown VirialTemp as additional filtering condition. Pig Latin posed
in the right-hand column of Table III. We explain these scripts no difficulty registering and calling a custom Java function.
in more detail in the remainder of this section. Query 4. This query is most naturally expressed with a
Query 1. Q1 is a simple selection query. Here, the LOAD relational-style join operator. In the current version of Pig,
command specifies which file the system should read and how a full outer join can be written in two steps. First, the two
that file should be parsed. We chose to split the particle into joined relations are COGROUPed by join attribute (pid). For
files based on type, just as we used separate tables in the each distinct pid value, the COGROUP operator generates
RDBMS implementation. Since Hadoop is not aware of the a tuple comprised of two bags2 containing tuples from each
schema of the data before it loads it and because it provides relation sharing a common pid. The following FOREACH
no indexing capability, the system must load and process files statement transforms the output of COGROUP into a standard
in their entirety. full outer join output by substituting nulls for empty bags3 .
The two FOREACH-GENERATE commands simply project Finally, a FILTER is used to select destroyed particles by
out unnecessary attributes to reduce the data volume. FILTER examining null value in s60 field.
performs the actual selection. Finally STORE dumps the result This query is converted into a single MapReduce job with
into a new HDFS file. There is no other way for users to get both map and reduce tasks. The map step loads the data and
output data in Pig/Hadoop. sends tuples to the reduce job based on their pid values. The
Since this query requires no grouping, the entire query is reduce job performs the join and filter operations. Different
performed in one MapReduce job comprising only map tasks.
2A bag is a collection that allows duplicates, in contrast to a set.
Query 2. Q2 is similar to Q1 with a more complex predicate. 3 InQ4, each bag contains at most one element because pid is unique in
Query 3. The third query, the select-project with UDF query, each input.
Database Z Database Z Database Z
104 Hadoop 104 Hadoop 104 Hadoop
IDL IDL IDL
Time (seconds)

Time (seconds)

Time (seconds)
102 102 102

100 100 100

10-2 10-2 10-2


dbtest128g cosmo50 cosmo25 dbtest128g cosmo50 cosmo25 dbtest128g cosmo50 cosmo25

(a) Q1 (b) Q4 (c) Q5

Fig. 1. Single node experiments. Since the results for Q1, Q2 and Q3 are very similar, only Q1, Q4, and Q5 are presented here for brevitys sake. Please
note that the log scale on the y-axis.

14000 A. Single-Node Query Performance


Database Z
12000 Hadoop
IDL Figure 1 shows the single-node query latencies for three of
Time (seconds)

10000
the five queries for three datasets and three engines: Database
8000
Z, Pig/Hadoop, and IDL. The latter runs the original analysis
6000
script used by the astronomers. The figure shows the average
4000
of three executions of each query. The variance is too small
2000
to be seen. Between executions, we restarted the machine to
0 clear all caches. Figure 2 highlights the same results for the
Q1 Q2 Q3 Q4 Q5
largest dataset on a linear scale.
Fig. 2. Query times from single-node implementation of RDBMS, Hadoop Overall, IDL shows the most consistent numbers across
& IDL for largest data set. queries. We find that its execution time is completely dom-
inated by load times. As noted previously, IDL loads all data
into memory before it operates on it (which is why it needs to
reduce tasks process tuples with different sets of pid values. run with the 128 GB of RAM!). In Q1 - Q3, IDL had to read
Query 5. This join query is similar to Query 4 and thus our in one snapshot, while in Q4 and Q5 it had to read in two.
implementation is also similar. For Q5, we load the input data Interestingly, the Hadoop runtime in Figure 2, although
into two bags because the selection conditions differ. As with presumably also dominated by load times, shows significantly
Query 4, this script compiles into a single MapReduce job. more variance than IDL. This is because the IDL system had
Overall, we found it quite natural to express our use case enough RAM to completely fit two snapshots of cosmo25, but
queries in the Pig Latin scripting language. We note that a Hadoop node only had 16GB of RAM, enough for only half
most of our queries only touch a few columns/variables in the of a single snapshot.
dataset, and as such, a column-store system [31] [32] might Database Z performs better than Hadoop under the same
have a significant advantage over a traditional RDBMS or limited memory conditions. To see why, consider Q2. The
Hadoop. We leave the study of CStore DBMSs in the context performance of all engines is most similar on Q2, where
of astrophysical simulation analysis for future work. the RDBMS, like the other engines, simply scans the input
data and filters it. On this query, Pig/Hadoop shows a higher
VI. E VALUATION overhead compared with Database Z. One reason for this is the
query startup cost; Hadoop must start several new processes
In this section, we present results from running all five on remote nodes to execute a query.
queries on both systems and different cluster configurations. Now consider Q1, where the benefits of indexing are appar-
Given the relatively manageable size of our data, we use ent. While the performance of Pig/Hadoop and IDL remain
a cluster of only eight nodes. We measure two primary approximately the same as for Q2, the query time for the
values: performance on a single node and speedup achieved DBMS is significantly reduced relative to Q1. The reason is
by increasing the cluster size. that the DBMS uses the index to identify exactly those pages
For all Database Z and Pig/Hadoop tests, each node had two on disk that must be reads and only reads those. In general,
quad-core Intel Xeon E5335 processors running at 2.0 GHz, 16 the performance benefit of an index is sensitive to properties
GB RAM, and two 500 GB SATA disks in RAID 0. The IDL of the data, the index, and the optimizer and is therefore not
platform was an SGI Altix with 16 Opteron 880 processors generally predictable [26].
running at 2.4 GHz, 128 GB RAM, and 3.1 TB of RAID 6 Our results for Q1 do not exploit covering indexes, an
SATA disk. The IDL system was thus significantly different optimization that would typically be available in practice.
from the Database Z and Hadoop platforms, and therefore the Consider an index over two attributes (temp, iOrder). In
runtimes are not directly comparable. this case, the DBMS does not need to use the index to
1400 its speedup is inconsistent on some queries, especially Q2.
Q2, Hadoop The speedup limitations of Database Z stem from a parallel
1200 Q2, RDBMS execution model that involves funneling results back to a head
1000 Q1, Hadoop node, a bottleneck for scalability. We expect this problem to
Q1, RDBMS
elapsed time (s)

800 become more apparent as the number of nodes increases. For


our test dataset, Hadoop seems to be at least as fast as Database
600
Z on 8 nodes, and in Q2 it is significantly faster.
400 More specifically, Figure 3 compares performance for both
200 Q1 and Q2. For Q1 (squares), we see smooth speedup in both
Hadoop and Database Z. Both systems exhibit diminishing re-
0 1 2 3 4 5 6 7 8 turns as the number of nodes increases. An index on the temp
# of nodes
attribute and a relatively small query result size minimizes the
Fig. 3. Query 1 and Query 2 parallel speedup. overhead of streaming all result tuples back to the head node,
so Database Z outperforms Hadoop easily.
In Q2 (circles), Hadoop exhibits a smooth speedup with
look up pages in the original table all the data needed some diminishing returns. Database Z however is erratic
to answer the query are available in the index itself. This additional nodes do not always reduce elapsed time. This result
optimization produces remarkable performance benefits Q1 is consistently reproducible: two nodes are slower than one
can be evaluated in under 100 ms! node, and eight nodes are more expensive than four nodes.
Q3 shows a similar effect as Q1 because the UDF to This result demonstrates the overhead of providing parallel
compute VirialTemp does not prevent the use of the index processing. Although it is difficult to ascertain exactly where
on temperature. the additional costs are incurred, it is clear from the other
The improved performance of the RDBMS is especially queries that there is some cost to coordinating a distributed
clear on the two queries involving joins, Q4 and Q5. The query. Query latency improves only when this overhead is
RDBMS is once again able to exploit indexes. For Q4, the outweighed by the time savings in processing each data
DBMS can answer the whole query using the (covering) index. partition much faster.
This index was also sorted on iOrder, allowing sequential I/O In Figure 4, we see that Q3 exhibits similar characteristics to
instead of random I/O during the evaluation of the join. Q2: the overhead of managing a distributed query is apparent
In these experiments, we cleared all caches between runs. in the slope between the 1-node case and the 2-node case,
In practice, query times could go down for all systems thanks but the parallelism still pays off in this case. Once again, 4
to caching. This would lead to the most significant runtime nodes appears to be the sweet spot. Speedup and overall
improvement for the IDL approach that runs on a system with performance between Hadoop and Database Z are comparable
128 GB RAM and can thus cache entire snapshots at the time. for this query.
To exploit such a cache, however, a scientist would need to Q4 and Q5 are the most expensive queries for both systems
access the same snapshot repeatedly. (Figure 5 and Figure 6). In both cases, Database Z significantly
In summary, in contrast to IDL, on a single node, both outperforms Hadoop, though the effect is diminished as the
Pig/Hadoop and Database Z give a researcher the ability to number of nodes increases. Interestingly, the speedup curve
analyze datasets that are significantly larger than the RAM of for Database Z is quite flat. Although this is generally a bad
that node, and do so in a time comparable to or better than IDL sign, the comparison with Hadoop shows that the flatness is
on a much more expensive system with enough RAM to hold better attributed to the strong performance of the single node
the dataset in memory. The RDBMS is especially efficient in case than simply poor speedup.
its memory management. It is important to point out that these experiments do not
properly represent the operational performance of Database
B. Parallel Query Processing Performance Z the database was unfairly penalized by not allowing it to
We evaluate speedup through experiments on the largest of exercise some of its most important features such as caching.
the three datasets. Speedup refers to improved query execution We also did almost no physical database tuning (selecting
time when using additional nodes to process the same dataset. views to materialize, which is a form of caching, changing
For perfect speedup, given a data set and a query, the execution properties of indexes, etc.).
time for a cluster of N nodes should be equal to TN1 , where However, this strength also illustrates a well-known weak-
T1 is the query execution time on a single node. Figures 3 ness of relational databases: they are complicated pieces of
through 6 show the results. Overall, both Pig/Hadoop and the software that require significant experience to operate properly.
RDBMS offer adequate speedup. Hadoop exhibits the most A typical research lab cannot afford a Database Administrator
consistent speedup for all 5 of our queries. In the worse case, on staff, so the full potential of a RDBMS may be difficult to
(Q1) speedup is still over 80% linear on 8 nodes, with most realize in practice. This problem is well-known in the database
of the other queries achieving over 90% linearity on 8 nodes. community, who are studying self-managing and self-tuning
While Database Z was faster on the single node experiments, enhancements to databases to simplify the cognitive load.
1600 14000 14000
1400 Q3, Hadoop Q4, Hadoop Q5, Hadoop
Q3, RDBMS 12000 Q4, RDBMS 12000 Q5, RDBMS
1200 10000 10000
elapsed time (s)

elapsed time (s)

elapsed time (s)


1000
8000 8000
800
6000 6000
600
400 4000 4000
200 2000 2000
0 1 2 3 4 5 6 7 8 0 1 2 3 4 5 6 7 8 0 1 2 3 4 5 6 7 8
# of nodes # of nodes # of nodes

Fig. 4. Query 3 parallel speedup. Fig. 5. Query 4 parallel speedup. Fig. 6. Query 5 parallel speedup.

Hadoop is also somewhat unfairly represented. Hadoop is outperformed Hadoop. Instead, different engines performed
designed for massive parallelism hundreds or thousands better on different queries.
of nodes. Testing on such few nodes means that important Benchmarks demonstrating the performance of relational
features such as intra-query fault tolerance are never exercised. DBMSs [25], Hadoop [43], or Pig [44] have previously
The overhead of having central coordination of a distributed been published. These benchmarks, however, evaluate these
query is also not evident with only eight nodes. systems in finely tuned environments, using synthetic data,
In summary, on these larger cluster configurations, Database and synthetic tasks such as sorting. In contrast, we evaluated
Z outperforms Hadoop on join queries and one of the selection these systems within the context of a specific application and
queries. This makes sense as our queries are I/O dominated, without extensive tunings.
and Database Z minimizes I/O whereas Hadoop must read in Cary et al. [45] studied the applicability of MapReduce to
the entire dataset. spatial data processing workloads and confirmed the excellent
scalability of MapReduce in that domain. In contrast, our work
VII. R ELATED W ORK focuses on data from a different domain, experiments with
Parallel query processing in a shared-nothing architecture a different engine (Pig instead of raw MapReduce) and also
has a long history [33], [34], [35], [36], [37], [38], [39] compares the performance with that of a RDBMS.
and many high-end commercial products are on the market The Sloan Digital Sky Survey [46] has successfully used
today [4], [27], [28], [29], [30]. Recently, a new generation of relational DBMSs to store and serve astronomy data. Their
systems have been introduced for massive-scale data process- data, however, comes from telescope imagery rather than
ing. These systems include MapReduce [5], [40] and similar large-scale simulations.
massively parallel data processing systems (e.g., Clustera [41], Palankar et al. [47] recently evaluated Amazon S3 [48] as
Dryad [7], and Hadoop [6]) along with their specialized lan- a feasible and cost effective alternative for hosting scientific
guages [9], [10], [11], [42]). All these systems, however, have datasets, particularly those produced by large community col-
not been designed specifically for scientific workloads and laborations such as LSST [49]. This work is orthogonal to ours
many argue that that they are ill-suited for this purpose [12]. since S3 is purely a storage system. It does not provide any
Our goal in this paper was to evaluate how well two examples data management capabilities beyond storing and retrieving
of such systems, one of each type, could be used for scientific objects based on their unique keys [48].
data analysis in astronomy simulation research. There are several ongoing efforts to build new types of
There is little published work that compares the perfor- database management systems for sciences [12], [50]. Evaluat-
mance of different parallel data processing systems. Recently, ing the applicability of these systems to astronomy simulation
Pavlo et al. [31], comparatively benchmarked a parallel rela- or other scientific analysis tasks is an area of future work.
tional DBMS, Hadoop [6], and Vertica [28], a column-store
VIII. C ONCLUSION
parallel DBMS. The goal of their work was to evaluate the
performance of these three systems in general. The study In this paper, we evaluated the performance of a commercial
thus used synthetic data. In contrast, our goal is to measure RDBMS and Hadoop on astronomy simulation analysis tasks.
how suitable such systems are for scientific data analysis We found that it was natural and concise to express the
and, in particular, astronomy simulation analysis. Hence, our required analysis tasks in these tools respective languages.
work focuses on real queries important in the astronomy On small-to-medium scale clusters (<10 nodes), we found the
domain and uses real data from that domain. Additionally, modern RDBMS to offer a powerful platform for organizing
we compared the DBMS to Pig, which brings a declarative data and an excellent constellation of features for improving
layer to Hadoop. For these reasons (and also due to differences performance: indexes, distributed queries, cost-based algebraic
in settings and relational DBMS used), some of our findings optimization, and logical data independence. Our tests also
differ from those in this previous study. In particular, in our indicate that overall a RDBMS outperforms Hadoop and IDL
setting, we did not find that the relational DBMS consistently for representative I/O-dominated queries in the astronomy
domain. However, we acknowledge that Hadoop is designed [22] IDL - Data Visualization Solutions, http://www.ittvis.com/
for scalability to hundreds or thousands of nodes, and is likely ProductServices/IDL.aspx.
[23] J. P. Gardner, A. Connolly, and C. McBride, Enabling rapid devel-
to outperform a RDBMS in this context. opment of parallel tree search applications, in Proceedings of the
2007 Symposium on Challenges of Large Applications in Distri buted
ACKNOWLEDGMENTS Environments (CLADE 2007). ACM Press, 2007.
[24] , Enabling knowledge discovery in a virtual universe, in Proceed-
It is a pleasure to acknowledge the help we have received ings of TeraGrid 07: Broadening Participation in the TeraGrid. ACM
from Tom Quinn, both during the project and in writing this Press, 2007.
publication. Simulations Cosmo25 and Cosmo50 were [25] The TPC-H benchmark, http://www.tpc.org.
[26] H. Garcia-Molina, J. D. Ullman, and J. Widom, Database Systems: The
graciously supplied by Tom Quinn and Fabio Governato of the complete book, 2nd ed. Prentice Hall, 2009.
University of Washington Department of Astronomy. The sim- [27] C. Ballinger, Born to be parallel: Why parallel origins give Teradata
ulations were produced using allocations of advanced NSF database an enduring performance edge, http://www.teradata.com/t/
page/87083/index.html.
supported computing resources operated by the Pittsburgh [28] Vertica, inc. http://www.vertica.com/.
Supercomputing Center, NCSA, and the TeraGrid. [29] IBM zSeries SYSPLEX, http://publib.boulder.ibm.com/infocenter/
This work was funded in part by the NASA Advanced In- \\dzichelp/v2r2/index.jsp?topic=/com.ibm.db2.doc.admin/xf6495.htm.
[30] A. Pruscino, Oracle RAC: Architecture and performance, in Proc. of
formation Systems Research Program grants NNG06GE23G, the SIGMOD Conf., 2003, p. 635.
NNX08AY72G, NSF CAREER award IIS-0845397, NSF CRI [31] Pavlo A. et. al., A comparison of approaches to large-scale data
grant CNS-0454425, the eScience Institute at the University of analysis, in Proc. of the SIGMOD Conf., 2009.
[32] M. Ivanova, M. L. Kersten, N. Nes, and R. Goncalves, An Architecture
Washington, gifts from Microsoft Research, and Balazinskas for Recycling Intermediates in a Column-store, in Proceedings of
Microsoft Research New Faculty Fellowship. the ACM SIGMOD International Conference on Management of Data,
Providence, RI, USA, June 2009, accepted for publication.
R EFERENCES [33] H. Boral, W. Alexander, L. Clay, G. Copeland, S. Danforth, M. Franklin,
B. Hart, M. Smith, and P. Valduriez, Prototyping Bubba, a highly
[1] Oracle, http://www.oracle.com/database. parallel database system, IEEE TKDE, vol. 2, no. 1, pp. 424, 1990.
[2] Db2, http://www.ibm.com/db2/. [34] L. Chen, C. Olston, and R. Ramakrishnan, Parallel evaluation of com-
[3] Teradata, http://www.teradata.com/. posite aggregate queries, in Proc. of the 24th International Conference
[4] Greenplum database, http://www.greenplum.com/. on Data Engineering (ICDE), 2008.
[5] J. Dean and S. Ghemawat, MapReduce: simplified data processing on [35] A. Deshpande and L. Hellerstein, Flow algorithms for parallel query
large clusters, in Proc. of the 6th USENIX Symposium on Operating optimization, in Proc. of the 24th International Conference on Data
Systems Design & Implementation (OSDI), 2004. Engineering (ICDE), 2008.
[6] Hadoop, http://hadoop.apache.org/. [36] D. DeWitt and J. Gray, Parallel database systems: the future of high
[7] M. Isard, M. Budiu, Y. Yu, A. Birrell, and D. Fetterly, Dryad: performance database systems, Communications of the ACM, vol. 35,
Distributed data-parallel programs from sequential building blocks, in no. 6, pp. 8598, 1992.
Proc. of the European Conference on Computer Systems (EuroSys), [37] D. J. Dewitt, S. Ghandeharizadeh, D. A. Schneider, A. Bricker, H. I.
2007, pp. 5972. Hsiao, and R. Rasmussen, The Gamma database machine project,
[8] ISO/IEC 9075-*:2003, Database Languages - SQL. ISO, Geneva, IEEE TKDE, vol. 2, no. 1, pp. 4462, 1990.
Switzerland. [38] G. Graefe, Encapsulation of parallelism in the Volcano query process-
[9] Y. Yu, M. Isard, D. Fetterly, M. Budiu, U. Erlingsson, P. K. Gunda, ing system, SIGMOD Record, vol. 19, no. 2, pp. 102111, 1990.
and J. Currey, DryadLINQ: A system for general-purpose distributed [39] Y. Xu, P. Kostamaa, X. Zhou, and L. Chen, Handling data skew in
data-parallel computing using a high-level language, 2008. parallel joins in shared-nothing systems, in Proc. of the SIGMOD Conf.,
[10] C. Olston, B. Reed, U. Srivastava, R. Kumar, and A. Tomkins, Pig latin: 2008, pp. 10431052.
a not-so-foreign language for data processing, in Proc. of the SIGMOD [40] H. Yang, A. Dasdan, R.-L. Hsiao, and D. S. Parker, Map-reduce-merge:
Conf., 2008, pp. 10991110. simplified relational data processing on large clusters, in Proc. of the
[11] R. Pike, S. Dorward, R. Griesemer, and S. Quinlan, Interpreting the SIGMOD Conf., 2007, pp. 10291040.
data: Parallel analysis with Sawzall, Scientific Programming, vol. 13, [41] D. J. DeWitt, E. Paulson, E. Robinson, J. Naughton, J. Royalty,
no. 4, 2005. S. Shankar, and A. Krioukov, Clustera: an integrated computation and
[12] M. Stonebraker, J. Becla, D. DeWitt, K.-T. Lim, D. Maier, O. Ratzes- data management system, in Proc. of the 34th International Conference
berger, and S. Zdonik, Requirements for science data bases and SciDB, on Very Large DataBases (VLDB), 2008, pp. 2841.
in Fourth CIDR Conf. Perspectives, 2009. [42] R. Chaiken, B. Jenkins, P.-A. Larson, B. Ramsey, D. Shakib, S. Weaver,
[13] SDSS SkyServer DR7. [Online]. Available: http://skyserver.sdss.org and J. Zhou, Scope: easy and efficient parallel processing of massive
[14] V. Singh, J. Gray, A. Thakar, A. S. Szalay, J. Raddick, B. Boroski, data sets, in Proc. of the 34th International Conference on Very Large
S. Lebedeva, and B. Yanny, Skyserver traffic report - the first five DataBases (VLDB), 2008, pp. 12651276.
years, 2007. [Online]. Available: http://www.citebase.org/abstract?id= [43] O. OMalley and A. C. Murthy, Winning a 60 second dash with a yel-
oai:arXiv.org:cs/0701173 low elephant, http://developer.yahoo.net/blogs/hadoop/Yahoo2009.pdf,
[15] J. G. Stadel, Cosmological N-body simulations and their analysis, 2009.
Ph.D. dissertation, University of Washington, 2001. [44] PigMix, http://wiki.apache.org/pig/PigMix.
[16] The NSF TeraGrid, http://www.teragrid.org. [45] A. Cary, Z. Sun, V. Hristidis, and N. Rishe, Experiences on processing
[17] TIPSY: A Theoretical Image Processing SYstem, http://hpcc.astro. spatial data with mapreduce, in Proc. of the 21st SSDBM Conf., 2009.
washington.edu/tools/tipsy/tipsy.html. [46] Sloan Digital Sky Survey, http://cas.sdss.org.
[18] M. Davis, G. Efstathiou, C. S. Frenk, and S. D. M. White, The evolution [47] M. R. Palankar, A. Iamnitchi, M. Ripeanu, and S. Garfinkel, Amazon
of large-scale structure in a universe dominated by cold dark matt er, S3 for science grids: a viable solution? in DADC 08: Proceedings of
Astroph J, vol. 292, pp. 371394, May 1985. the 2008 international workshop on Data-aware distributed computing,
[19] D. H. Weinberg, L. Hernquist, and N. Katz, Photoionization, Numerical 2008, pp. 5564.
Resolution, and Galaxy Formation, Astroph. J., vol. 477, pp. 8+, Mar. [48] Amazon Simple Storage Service (Amazon S3), http://www.amazon.
1997. com/gp/browse.html?node=16427261.
[20] An Overview of SKID, http://www-hpcc.astro.washington.edu/tools/ [49] Large Synoptic Survey Telescope, http://www.lsst.org/.
skid.html. [50] Rasdaman: The intelligent RasterServer, http://www.rasdaman.com/.
[21] S. R. Knollmann and A. Knebe, AHF: Amigas Halo Finder, Astroph.
J. Suppl., vol. 182, pp. 608624, June 2009.

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy