Data parallelism
Data parallelism is parallelization across multiple processors in parallel computing environments. It focuses on distributing the data across different nodes, which operate on the data in parallel. It can be applied on regular data structures like arrays and matrices by working on each element in parallel. It contrasts to task parallelism as another form of parallelism.
A data parallel job on an array of n elements can be divided equally among all the processors. Let us assume we want to sum all the elements of the given array and the time for a single addition operation is Ta time units. In the case of sequential execution, the time taken by the process will be n×Ta time units as it sums up all the elements of an array. On the other hand, if we execute this job as a data parallel job on 4 processors the time taken would reduce to ×Ta + merging overhead time units. Parallel execution results in a speedup of 4 over sequential execution. One important thing to note is that the locality of data references plays an important part in evaluating the performance of a data parallel programming model. Locality of data depends on the memory accesses performed by the program as well as the size of the cache.
History
Exploitation of the concept of data parallelism started in 1960s with the development of Solomon machine. The Solomon machine, also called a vector processor, was developed to expedite the performance of mathematical operations by working on a large data array. Concurrency of data operations was also exploited by operating on multiple data at the same time using a single instruction. These processors were called 'array processors'. In the 1980s, the term was introduced to describe this programming style, which was widely used to program Connection Machines in data parallel languages like C*. Today, data parallelism is best exemplified in graphics processing units, which use both the techniques of operating on multiple data in space and time using a single instruction.Description
In a multiprocessor system executing a single set of instructions, data parallelism is achieved when each processor performs the same task on different distributed data. In some situations, a single execution thread controls operations on all the data. In others, different threads control the operation, but they execute the same code.For instance, consider matrix multiplication and addition in a sequential manner as discussed in the example.
Example
Below is the sequential pseudo-code for multiplication and addition of two matrices where the result is stored in the matrix C. The pseudo-code for multiplication calculates the dot product of two matrices A, B and stores the result into the output matrix C.If the following programs were executed sequentially, the time taken to calculate the result would be of the and for multiplication and addition respectively.
// Matrix multiplication
for
// Array addition
for
// Matrix multiplication in parallel
- pragma omp parallel for schedule collapse
For addition of arrays in a data parallel implementation, let’s assume a more modest system with two central processing units A and B, CPU A could add all elements from the top half of the arrays, while CPU B could add all elements from the bottom half of the arrays. Since the two processors work in parallel, the job of performing array addition would take one half the time of performing the same operation in serial using one CPU alone.
The program expressed in pseudocode below—which applies some arbitrary operation,
foo
, on every element in the array d
—illustrates data parallelism:if CPU = "a" then
lower_limit := 1
upper_limit := round
else if CPU = "b" then
lower_limit := round + 1
upper_limit := d.length
for i from lower_limit to upper_limit by 1 do
foo
In an SPMD system executed on 2 processor system, both CPUs will execute the code.
Data parallelism emphasizes the distributed nature of the data, as opposed to the processing. Most real programs fall somewhere on a continuum between task parallelism and data parallelism.
Steps to parallelization
The process of parallelizing a sequential program can be broken down into four discrete steps.Type | Description |
Decomposition | The program is broken down into tasks, the smallest exploitable unit of concurrence. |
Assignment | Tasks are assigned to processes. |
Orchestration | Data access, communication, and synchronization of processes. |
Mapping | Processes are bound to processors. |
Data parallelism vs. task parallelism
Data parallelism vs. model parallelism
Mixed data and task parallelism
Data and task parallelism, can be simultaneously implemented by combining them together for the same application. This is called Mixed data and task parallelism. Mixed parallelism requires sophisticated scheduling algorithms and software support. It is the best kind of parallelism when communication is slow and number of processors is large.Mixed data and task parallelism has many applications. It is particularly used in the following applications:
- Mixed data and task parallelism finds applications in the global climate modeling. Large data parallel computations are performed by creating grids of data representing earth’s atmosphere and oceans and task parallelism is employed for simulating the function and model of the physical processes.
- In timing based circuit simulation. The data is divided among different sub-circuits and parallelism is achieved with orchestration from the tasks.
Data parallel programming environments
- Message Passing Interface: It is a cross-platform message passing programming interface for parallel computers. It defines the semantics of library functions to allow users to write portable message passing programs in C, C++ and Fortran.
- Open Multi Processing : It’s an Application Programming Interface which supports shared memory programming models on multiple platforms of multiprocessor systems.
- CUDA and OpenACC: CUDA and OpenACC are parallel computing API platforms designed to allow a software engineer to utilize GPU’s computational units for general purpose processing.
- Threading Building Blocks and RaftLib: Both open source programming environments that enable mixed data/task parallelism in C/C++ environments across heterogeneous resources.
Applications