Parallel Processing and the Madrigal Database

The Madrigal database is used throughout the space science community to distribute data on Earth's upper atmosphere. Built into the Madrigal database is a derivation engine that can calculate many additional scientific parameters besides those stored in the underlying data files. However, this extra dynamic computation can slow the response of the database when a user requests a large set of data with many derived parameters. The derivation engine is presently run serially, but its underlying algorithm seems to lend itself to parallelization. The goal of this project is to investigate possible improvement to Madrigal's performance using a NVIDIA CUDA GPU processor. The Madrigal derivation engine is built using both python and C, so parallelization may be done either at the C level or the python level using PyCUDA.

Questions that might be answered:

Task list

Notes

Notes on Fermi:

Notes on CUDA:

pyCUDA Timing Table:

*A more complex method in the Madrigal engine, actually written in Fortran (convrt.f):

convrt

pyCUDA

Fortran

Number of Computations(10^n)

Computation Time(sec)

Computation Time(sec)

7

0.481

19.5

6

0.0463

1.95

5

0.00552

0.194

4

0.00144

0.0195

3

0.00110

0.00195

2

0.00160

0.000340