Implementation of Parallel Merge Sort
- Get link
- X
- Other Apps
Experiment
No: HPC-03
TITLE:
-
For Merger Sort, based on existing sequential
algorithms, design and implement parallel algorithm utilizing all
resources available.
-
Implement Any One Sorting Strategy(Merge sort Or Bubble Sort)
Problem
Statement: -
Understand Parallel Sorting Algorithms like Bubble sort and Merge
Sort.
Objective:
-
To understand the implementation of Merger sort and bubble sort
-
To study OpenMP Parallel programming model
Requirements
(Hw/Sw):
PC, gcc, OpenMP tool, Ubuntu system,C/C++.
Theory:-
i)
What is Sorting?
Sorting
is a process of arranging elements in a group in a particular order,
i.e., ascending order, descending order, alphabetic order, etc.
Characteristics
of Sorting are:
•
Arrange
elements of a list into certain order
•
Make
data become easier to access
•
Speed
up other operations such as searching and merging. Many sorting
algorithms with different time and space complexities
ii)
What is Parallel
Sorting?
- parallel sorting algorithm as compared with traditional sequential sorting algorithm which can execute a task on many processing device ,and then combined together at the end to get correct results.
A
sequential sorting algorithm may not be efficient enough when we have
to sort a huge volume of data. Therefore, parallel algorithms are
used in sorting.
Design
methodology:
•
Based
on an existing sequential sort algorithm
–
Try
to utilize all resources available
–
Possible
to turn a poor sequential algorithm into a reasonable parallel
algorithm (bubble sort and parallel bubble sort)
•
Completely
new approach
–
New
algorithm from scratch
–
Harder
to develop
–
Sometimes
yield better solution
Merge
Sort
•
Collects
sorted list onto one processor
•
Merges
elements as they come together
•
Simple
tree structure
•
Parallelism
is limited when near the root
Merge Sort
Merge sort first divides the unsorted list into smallest possible sub-lists, compares it with the adjacent list, and merges it in a sorted order.
Like QuickSort, Merge Sort is a Divide and Conquer algorithm. It divides input array in two halves, calls itself for the two halves and then merges the two sorted halves. The merge() function is used for merging two halves. The merge(arr, l, m, r) is key process that assumes that arr[l..m] and arr[m+1..r] are sorted and merges the two sorted sub-arrays into one.
Like QuickSort, Merge Sort is a Divide and Conquer algorithm. It divides input array in two halves, calls itself for the two halves and then merges the two sorted halves. The merge() function is used for merging two halves. The merge(arr, l, m, r) is key process that assumes that arr[l..m] and arr[m+1..r] are sorted and merges the two sorted sub-arrays into one.
Theory:
To
sort A[p
.. r]:
1.
Divide Step
If
a given array A has
zero or one element, simply return; it is already sorted. Otherwise,
splitA[p
.. r]
into two subarraysA[p
.. q]
and A[q
+ 1 .. r],
each containing about half of the elements of A[p
.. r].
That is, q is
the halfway point of A[p
.. r].
2.
Conquer Step
Conquer
by recursively sorting the two subarraysA[p
.. q]
and A[q
+ 1 .. r].
3.
Combine Step
Combine
the elements back in A[p
.. r]
by merging the two sorted subarraysA[p
.. q]
and A[q
+ 1 .. r]
into a sorted sequence. To accomplish this step, we will define a
procedure MERGE (A,
p,
q,
r).
Example:
The following diagram from shows the complete merge sort process for an example array {38, 27, 43, 3, 9, 82, 10}. If we take a closer look at the diagram, we can see that the array is recursively divided in two halves till the size becomes 1. Once the size becomes 1, the merge processes comes into action and starts merging arrays back till the complete array is merged.
The following diagram from shows the complete merge sort process for an example array {38, 27, 43, 3, 9, 82, 10}. If we take a closer look at the diagram, we can see that the array is recursively divided in two halves till the size becomes 1. Once the size becomes 1, the merge processes comes into action and starts merging arrays back till the complete array is merged.
1.
Procedure parallelMergeSort
2.
Begin
3.
Create processors Pi where i = 1 to n
4.
if i > 0 then recieve size and parent from the root
5.
recieve the list, size and parent from the root
6.
endif
7.
midvalue= listsize/2
8.
if both children is present in the tree then
9.
send midvalue, first child
10.
send listsize-mid,second child
11.
send list, midvalue, first child
12.
send list from midvalue, listsize-midvalue, second child
13.
call mergelist(list,0,midvalue,list,
midvalue+1,listsize,temp,0,listsize)
14.
store temp in another array list2
15.
else
16.
call parallelMergeSort(list,0,listsize)
17.
endif
18.
if i >0 then
19.
send list, listsize,parent
20.
endif
21.
end
Input
:
1.
Array of integer numbers.
Output
:
1.
Sorted array of numbers
ALGORITHM
ANALYSIS
1.
Time Complexity Of parallel Merge Sort and parallel Bubble sort in
best case is( when all data is already in sorted form):O(n)
2.
Time Complexity Of parallel Merge Sort and parallel Bubble sort in
worst case is: O(n logn)
1.
Representing Linear data structure & Sequential data organization
: structure & files
CONCLUSION
Thus,
we have studied Parallel Bubble and Parallel Merge sort
implementation.
based on existing sequential algorithms
bubble sort
Bubble Sort and Merger Sort
design and implement parallel algorithm
merge sort
MPI
OpenMp
parallel bubble sort
parallel sorting
- Get link
- X
- Other Apps
Comments
Post a Comment