Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

In Exercises 42-46 we will study the problem of load balancing. The input to the problem is a collection of p processors and n jobs, tjis the time required to run job j, jobs run without interruption on a single machine until finished, and a processor can run only one job at a time. The load Lkof processor k is the sum over all jobs assigned to processor k of the times required to run these jobs. The make span is the maximum load over all the p processors. The load balancing problem asks for an assignment of jobs to processors to minimize the make span.

An approximation algorithm for an optimization problem produces a solution guaranteed to be close to an optimal solution. More precisely, suppose that the optimization problem asks for an input S that minimizesF(X) where F is some function of the input X. If an algorithm always finds an input T with F(T)cF(S)where c is a fixed positive real number, the algorithm is called a c-approximation algorithm for the problem.

Prove that the algorithm from Exercise 44 is a 2 -approximation algorithm for the load balancing problem.

[Hint: Use both parts of Exercise 43 ].

Short Answer

Expert verified

The algorithm is a 2 -approximation algorithm for the load balancing problem.

Step by step solution

Achieve better grades quicker with Premium

  • Unlimited AI interaction
  • Study offline
  • Say goodbye to ads
  • Export flashcards

Over 22 million students worldwide already upgrade their learning with Vaia!

01

Step 1

We call the algorithm “minimal make span”, while the input to the algorithm are the non-negative real numberst1,t2,...,tn and positive integers n and p.

Procedure- minimal make span (t1,t2,...,tn:non-negativerealnumbers;n,p:positiveinteger). Initially, we set the load of each processorsLk equal to . We move through the jobs in the order that they were given (job1,job2,...,jobn). We add the time required to run job j to the processors with the smallest load Lkand j to the set of jobs Jkto processor k. After we ran through all jobs, we return the assignments of the jobs along with the make span M.

fori:=1top

Li:=0Ji:=ϕ

for role="math" localid="1668674778317" i:=1ton

k:=1

for i:=2top

if Li<Lkthen

k:=i

Lk:=Lk+tjJk:=Jk{j}M:=0fori:=1topM:=M+Li

return J1,J2,...,Jp,M

02

Step 2

Collection of p processors and n jobs.

tj=tome required to run job j

Load Lkof processors k = sum of times required to run all jobs assigned to processor k

Make span = maximum load over all p processors.

We are interested in minimizing the make span.

An algorithm is a c-approximation algorithm when the algorithm always finds an input T such that F(T)cF(S)where c is a fixed positive real number and S is the input that minimizes F(X).

03

Step 3

To proof: The algorithm above is a 2-approximation algorithm for the load balancing problem.

PROOF

The algorithm is a 2-approximation algorithm when F(X)represents the make span of input X and F(T)2F(S)for every input T and F(S)is the minimal make span for the input.

Let machine i have maximum load Yiand let j be the last job scheduled on machine i.

Machine i must then have had the least load when job j was being scheduled, while this load was Ti-tj.

Ti-tjTkfor all k

Let us next sum over all values of k:

pTitj=k=1pTitjk=1pTk

Divide each side of the previous inequality by p:

Titj1pk=1pTk

However, we proved L1pk=1pin one of the previous exercises:

Since Lmaxi=1,2,,ntjand TitjL.

Ti=Titj+tjL+L=2L

Thus the algorithm is a -approximation algorithm.

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Study anywhere. Anytime. Across all devices.

Sign-up for free