Download presentation
Presentation is loading. Please wait.
1
Coarse Grained Parallel Selection
Laurence Boxer Department of Computer and Information Sciences Niagara University Department of Computer Science and Engineering SUNY at Buffalo Presentation at University of District of Columbia, November, 2018
2
Presentation at University of District of Columbia, November, 2018
Selection Problem Given an array π₯ 1,β―,π of real numbers and an index π, 1 β€πβ€π, find an index π such that π₯ π is the π-th smallest entry of π₯; more generally, find record in list of records that has π-th smallest key value. So what does this generalize? for π=1 a solution to the Selection Problem computes the minimum for π=π a solution to the Selection Problem computes the maximum. for π= π 2 or π= π 2 , problem is to find median. NaΓ―ve but non-optimal solution: Sort the array in ascending order. The entry at index π is now the desired value. Presentation at University of District of Columbia, November, 2018
3
Presentation at University of District of Columbia, November, 2018
Principles of Analysis of Algorithms* Ignore machine-dependent constants. There is no concern as to how fast an individual processor executes a machine instruction, as this says nothing about the quality of the algorithm. Look at growth of resources as πββ. The interest is in π(π), the running time of an algorithm for large π, where π is typically the size of the data input to the algorithm. The following are ignored when expressing asymptotic analysis. low-order terms multiplicative constant factors Example: the function 3 π π 2 +π+17 is said to grow as π 3 . That is, for large values of π, the quadratic, linear, and constant terms, respectively, 10 π 2 , π, and 17, are insignificant compared with the cubic term when considering growth rate of the function. * This slide copied from PowerPoints for Miller and Boxer, 2013 Presentation at University of District of Columbia, November, 2018
4
Presentation at University of District of Columbia, November, 2018
Technical details Let π π , π(π) be positive-valued functions of an integer variable (in the back of your mind, think of them as measures of algorithmsβ running times for a problem of size π). π π =π π π if there exist π>0, π 0 >0 such that π β₯ π 0 implies π π β€ππ(π). π π =π π π if there exist π 2 > π 1 >0, π 0 >0 such that π β₯ π 0 implies π 1 π(π)β€π π β€ π 2 π(π). Presentation at University of District of Columbia, November, 2018
5
Presentation at University of District of Columbia, November, 2018
Example for uninitiated: 1,000,000 π+1000=π π 2 How do we know this? (I.e., proof:) Well, for π β₯1,000,000 (= π 0 ) we have 1,000,000β€π (1) and we multiply both sides of (1) by π to get 1,000,000πβ€ π (2) and 1,000<1,000,000 β€π=πΓ1<πΓπ= π (3) so by adding (2) and (3) we get 1,000,000π + 1,000< π 2 + π 2 =2 π 2 (take π=2) Presentation at University of District of Columbia, November, 2018
6
NaΓ―ve non-optimality, sequential version
log_2 n n log_2 n 1,024 10 10,240 2,048 11 22,528 4,096 12 49,152 8,192 13 106,496 16,384 14 229,376 32,768 15 491,520 65,536 16 1,048,576 131,072 17 2,228,224 262,144 18 4,718,592 524,288 19 9,961,472 The minimum and maximum problems have sequential solutions based on semigroup (simple scan of the data) operations that run in π(π) time. Sorting takes π(π log π ) time. Therefore, the naΓ―ve algorithm takes π(π log π ) time. Since Selection generalizes Minimum and Maximum, we want Selection to be solved in same asymptotic time, π(π), as Minimum and Maximum. A π(π) time sequential solution exists: [Blum et al.; Miller & Boxer] Presentation at University of District of Columbia, November, 2018
7
Application example β awarding merit scholarships
E.g., top 5% of applicants in a scholarship program are to be awarded. Determine awardees without taking the time to sort scores. Solution, analyzed sequentially: Determine π= 100% β5% π=95%π (π = # applicants) - π(1) time Use Selection algorithm to find criterion score, π β th lowest - π(π) time Scan scores to determine awardees, those with score β₯π β th lowest - π(π) time Total sequential time: π(π) This is asymptotically optimal, since you must consider all π applicants β why? Else, could overlook one who should be a winner (whose record should be part of the output). If desired, then sort awardees alphabetically by names or numerically by scores β but now only sorting 5% of original data. Though more steps described above than alternate of sorting & taking 5% at high end of sorted list, running time - π π - is asymptotically faster than π(π log π ) for sorting. . Presentation at University of District of Columbia, November, 2018
8
Coarse grained parallel multicomputer πΆπΊπ(π,π)
Much early research in parallel computing was fine grained β assume lots of processors, typically π when processing π data. This makes theory easier, but is generally wildly impractical. πΆπΊπ(π,π) has π processors of approximately same capabilities (speed, memory) for processing π data, where πβͺπ. Typically, assume π 2 β€π or π 2 log 2 π β€π ; also, Ξ© π π memory per processor More realistic, though theory is often more challenging than for fine grained parallelism. Most modern computers are coarse grained parallel, i.e., more than 1 but not many processors. Ideal: Solution times satisfy π πππ π,π =ΞΈ π π ππ (π)/π Ideal not always achievable, since even if problem is parallelizable, e.g., communications between processors take time. Note to students β this hints at challenges of parallel computing, and opportunities. Presentation at University of District of Columbia, November, 2018
9
Saukas-Song coarse grained parallel Selection algorithm
Published 1999 Restriction on number of processors: π 2 log 2 π β€π Paper analyzed algorithm in terms of local computation (processors compute in parallel, independent of each other) and βcommunication roundsβ (processors communicate data with each other) Local computing time: π π π Communications rounds: π log π In 1999, asymptotic time of communications hadnβt been studied. Now, can evaluate asymptotic time of communications [Boxer&Miller 2004] Algorithm runs in π π log π π time β efficient but not ideal Presentation at University of District of Columbia, November, 2018
10
Presentation at University of District of Columbia, November, 2018
Boxer coarse grained parallel Selection algorithm β assuming data uniformly distributed on an interval, WLOG, 0,1 Guess a small interval π,π containing the expected value of the π-th smallest entry of the list, πΈ π π = π π+1 , in π(1) time. In parallel, each processor scan its data values; accumulate counts π of those π₯ π <π and π of those such that π β€ π₯ π β€π, keeping track of the set πβ² satisfying the latter inequalities. With high probability, i.e., Pr β πββ 1, we have π<πβ€πβ€π/π. (Proofs of the probability limits from Chebyshevβs inequality). Time: π(π/π) If these are realized, then Gather πβ² to one processor - π π/π time (Boxer&Miller, 2004) Use sequential selection to find πβπ -th smallest member of πβ² - π π/π time Thus, solution finishes in π π/π time. Else Apply Saukas-Song algorithm to solve in worst-case π π log π π time Probabilities computed for previous steps enable us to compute expected running time = π π/π βπ(1) + π π log π π βπ 1 log π = π π/π . Presentation at University of District of Columbia, November, 2018
11
Presentation at University of District of Columbia, November, 2018
References L. Boxer,Β Coarse Grained Parallel Selection, submitted. Available at L. Boxer and R. Miller, Coarse grained gather and scatter operations with applications, Journal of Parallel and Distributed Computing 64 (11) (2004), M. Blum, R.W. Floyd, V. Pratt, R. L. Rivest, and R. E. Tarjan, Bounds for selection, Journal of Computer and System Sciences 7 (1973), R. Miller and L. Boxer, Algorithms Sequential and Parallel, A Unified Approach, 3rd ed., Cengage Learning, Boston, 2013. E.L.G. Saukas and S.W. Song, A note on parallel selection on coarse-grained multicomputers, Algorithmica 24 (1999), Presentation at University of District of Columbia, November, 2018
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.