Minimizing Response time in Broadcast Scheduling Nikhil Bansal Don Coppersmith and Maxim Sviridenko.

Slides:



Advertisements
Similar presentations
On allocations that maximize fairness Uriel Feige Microsoft Research and Weizmann Institute.
Advertisements

Solving IPs – Cutting Plane Algorithm General Idea: Begin by solving the LP relaxation of the IP problem. If the LP relaxation results in an integer solution,
LIAL HORNSBY SCHNEIDER
Approximation Algorithms Chapter 14: Rounding Applied to Set Cover.
1 EE5900 Advanced Embedded System For Smart Infrastructure Static Scheduling.
Approximation Algorithms for Capacitated Set Cover Ravishankar Krishnaswamy (joint work with Nikhil Bansal and Barna Saha)
Online Scheduling with Known Arrival Times Nicholas G Hall (Ohio State University) Marc E Posner (Ohio State University) Chris N Potts (University of Southampton)
Bounds on Code Length Theorem: Let l ∗ 1, l ∗ 2,..., l ∗ m be optimal codeword lengths for a source distribution p and a D-ary alphabet, and let L ∗ be.
An Optimal Lower Bound for Buffer Management in Multi-Queue Switches Marcin Bieńkowski.
N. Bansal 1, M. Charikar 2, R. Krishnaswamy 2, S. Li 3 1 TU Eindhoven 2 Princeton University 3 TTIC Midwest Theory Day, Purdue, May 3, 2014.
Scheduling with Outliers Ravishankar Krishnaswamy (Carnegie Mellon University) Joint work with Anupam Gupta, Amit Kumar and Danny Segev.
Greedy Algorithms Basic idea Connection to dynamic programming Proof Techniques.
1 Better Scalable Algorithms for Broadcast Scheduling Ravishankar Krishnaswamy Carnegie Mellon University Joint work with Nikhil Bansal and Viswanath Nagarajan.
June 3, 2015Windows Scheduling Problems for Broadcast System 1 Amotz Bar-Noy, and Richard E. Ladner Presented by Qiaosheng Shi.
An O(1) Approximation Algorithm for Generalized Min-Sum Set Cover Ravishankar Krishnaswamy Carnegie Mellon University joint work with Nikhil Bansal (IBM)
1 Approximation Algorithms for Demand- Robust and Stochastic Min-Cut Problems Vineet Goyal Carnegie Mellon University Based on, [Golovin, G, Ravi] (STACS’06)
CPSC 689: Discrete Algorithms for Mobile and Wireless Systems Spring 2009 Prof. Jennifer Welch.
Randomized Algorithms and Randomized Rounding Lecture 21: April 13 G n 2 leaves
Network Design Adam Meyerson Carnegie-Mellon University.
Online Algorithms for Network Design Adam Meyerson UCLA.
Approximation Algorithms
Online Oblivious Routing Nikhil Bansal, Avrim Blum, Shuchi Chawla & Adam Meyerson Carnegie Mellon University 6/7/2003.
Zoë Abrams, Ashish Goel, Serge Plotkin Stanford University Set K-Cover Algorithms for Energy Efficient Monitoring in Wireless Sensor Networks.
Job Scheduling Lecture 19: March 19. Job Scheduling: Unrelated Multiple Machines There are n jobs, each job has: a processing time p(i,j) (the time to.
Integer Programming Difference from linear programming –Variables x i must take on integral values, not real values Lots of interesting problems can be.
Linear Programming Relaxations for MaxCut Wenceslas Fernandez de la Vega Claire Kenyon -Mathieu.
Review of Reservoir Problem OR753 October 29, 2014 Remote Sensing and GISc, IST.
1 Introduction to Approximation Algorithms Lecture 15: Mar 5.
(work appeared in SODA 10’) Yuk Hei Chan (Tom)
A General Approach to Online Network Optimization Problems Seffi Naor Computer Science Dept. Technion Haifa, Israel Joint work: Noga Alon, Yossi Azar,
Approximation Algorithms: Bristol Summer School 2008 Seffi Naor Computer Science Dept. Technion Haifa, Israel TexPoint fonts used in EMF. Read the TexPoint.
Minimizing Flow Time on Multiple Machines Nikhil Bansal IBM Research, T.J. Watson.
Daniel Kroening and Ofer Strichman Decision Procedures An Algorithmic Point of View Deciding ILPs with Branch & Bound ILP References: ‘Integer Programming’
1/24 Algorithms for Generalized Caching Nikhil Bansal IBM Research Niv Buchbinder Open Univ. Israel Seffi Naor Technion.
1 The Santa Claus Problem (Maximizing the minimum load on unrelated machines) Nikhil Bansal (IBM) Maxim Sviridenko (IBM)
Decision Procedures An Algorithmic Point of View
Approximation Algorithms for Stochastic Combinatorial Optimization Part I: Multistage problems Anupam Gupta Carnegie Mellon University.
Online Oblivious Routing Nikhil Bansal, Avrim Blum, Shuchi Chawla & Adam Meyerson Carnegie Mellon University 6/7/2003.
Round and Approx: A technique for packing problems Nikhil Bansal (IBM Watson) Maxim Sviridenko (IBM Watson) Alberto Caprara (U. Bologna, Italy)
Speed Scaling to Manage Energy and Temperature Nikhil Bansal (IBM Research) Tracy Kimbrel (IBM) and Kirk Pruhs (Univ. of Pittsburgh)
Approximating Minimum Bounded Degree Spanning Tree (MBDST) Mohit Singh and Lap Chi Lau “Approximating Minimum Bounded DegreeApproximating Minimum Bounded.
1 Introduction to Approximation Algorithms. 2 NP-completeness Do your best then.
1 Server Scheduling in the L p norm Nikhil Bansal (CMU) Kirk Pruhs (Univ. of Pittsburgh)
Packing Rectangles into Bins Nikhil Bansal (CMU) Joint with Maxim Sviridenko (IBM)
A Maiden Analysis of Longest Wait First Jeff Edmonds York University Kirk Pruhs University of Pittsburgh.
Minimizing Stall Time in Single Disk Susanne Albers, Naveen Garg, Stefano Leonardi, Carsten Witt Presented by Ruibin Xu.
Integer Programming Li Xiaolei. Introduction to Integer Programming An IP in which all variables are required to be integers is called a pure integer.
1/19 Minimizing weighted completion time with precedence constraints Nikhil Bansal (IBM) Subhash Khot (NYU)
Linear Program Set Cover. Given a universe U of n elements, a collection of subsets of U, S = {S 1,…, S k }, and a cost function c: S → Q +. Find a minimum.
A polylog competitive algorithm for the k-server problem Nikhil Bansal (IBM) Niv Buchbinder (Open Univ.) Aleksander Madry (MIT) Seffi Naor (Technion)
OR Chapter 8. General LP Problems Converting other forms to general LP problem : min c’x  - max (-c)’x   = by adding a nonnegative slack variable.
Lecture.6. Table of Contents Lp –rounding Dual Fitting LP-Duality.
Unique Games Approximation Amit Weinstein Complexity Seminar, Fall 2006 Based on: “Near Optimal Algorithms for Unique Games" by M. Charikar, K. Makarychev,
Algorithms for Path-Planning Shuchi Chawla (CMU/Stanford/Wisconsin) 10/06/05.
Non-Preemptive Buffer Management for Latency Sensitive Packets Moran Feldman Technion Seffi Naor Technion.
Multicast Pull Scheduling Kirk Pruhs. The Big Problem Movie Distribution Database Replication via Internet Harry Potter Book Download Software Download.
1 Approximation Algorithms for Generalized Min-Sum Set Cover Ravishankar Krishnaswamy Carnegie Mellon University joint work with Nikhil Bansal and Anupam.
Ben Moseley Sungjin Im Goals of Talk  Make you aware of/interested in broadcast sched  Highlight known results, key open questions, some recent results.
1 Approximation Algorithms for Generalized Scheduling Problems Ravishankar Krishnaswamy Carnegie Mellon University joint work with Nikhil Bansal, Anupam.
Instructor: Shengyu Zhang 1. Optimization Very often we need to solve an optimization problem.  Maximize the utility/payoff/gain/…  Minimize the cost/penalty/loss/…
Approximation Algorithms based on linear programming.
Linear program Separation Oracle. Rounding We consider a single-machine scheduling problem, and see another way of rounding fractional solutions to integer.
Chapter 6. Large Scale Optimization
András Sebő and Anke van Zuylen
Integer Programming (정수계획법)
On Approximating Covering Integer Programs
Chapter 6. Large Scale Optimization
An Optimal Lower Bound for Buffer Management in Multi-Queue Switches
Presentation transcript:

Minimizing Response time in Broadcast Scheduling Nikhil Bansal Don Coppersmith and Maxim Sviridenko

2 Problem Statement Collection of pages 1,2,…,n at a broadcast server (satellite) Requests r 1,…,r m Request r i : [page p i, arrival time a i ] Many requests may arrive at a time slot. Server transmits 1 page per time slot. Page p broadcast at time t, satisfies all outstanding requests for p that arrived at time <t Given a schedule, let b i denote when r i is satisfied Response Time: b i – a i Goal: Find broadcast schedule to Minimize average response time (  i (b i – a i )) / m

3 Problem Statement Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,32,3 Total Response Time = t=0 Requests Pages {1,2,3}

4 Problem Statement Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,32,3 Total Response Time = t=0 Requests Pages {1,2,3}

5 Problem Statement Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,3 Total Response Time = t=0 Requests Pages {1,2,3}

6 Problem Statement Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,32,3 Total Response Time = t=0 Requests Pages {1,2,3}

7 Problem Statement Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,32,3 Total Response Time = = t=0 Requests Pages {1,2,3}

8 Problem Statement Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,32,3 Total Response Time = = t=0 Requests Avg=1.5 Pages {1,2,3}

9 NP-Hard: [Erlebach, Hall 02] Resource augmentation: Can transmit s>1 pages per time slot. s-speed, c-approx: If max I Alg s (I)/Opt 1 (I) · c 3-speed, 3-approx [Kalyanasundaram et al 00] 6-speed, 1-approx [Erlebach, Hall 02] 2-speed, 2-approx & 4-speed, 1-approx [Gandhi et al 02] 2-speed, 1-approx [Gandhi et al 02] (1+  )-speed, O(1/  )-approx [B., Charikar, Khanna, Naor 05] Resource augmentation vs No speed-up Requests (1,2) ( 3,4) (5,6) … Speed 2: Avg resp time = O(1) Speed 1: O(n)

10 NP-Hard: [Erlebach, Hall 02] Resource augmentation: Can transmit s>1 pages per time slot. s-speed, c-approx: If max I Alg s (I)/Opt 1 (I) · c 3-speed, 3-approx [Kalyanasundaram et al 00] 6-speed, 1-approx [Erlebach, Hall 02] 2-speed, 2-approx & 4-speed, 1-approx [Gandhi et al 02] 2-speed, 1-approx [Gandhi et al 02] (1+  )-speed, O(1/  )-approx [B., Charikar, Khanna, Naor 05] Without speedup: Trivial O(n) approximation, Round Robin O(n 1/2 ) approximation [B., Charikar, Khanna, Naor 05] O(log 2 n/log log n) approximation [B., Coppersmith, Sviridenko 06]

11 Previous Work (Online Case) Round Robin: Trivial O(n) competitive Most outstanding requests, Longest Wait First ? Any deterministic alg:  (n) competitive [Kalyanasundaram et al 00] Any randomized alg:  (n 1/2 )- competitive B-Equi : 4-speed, 4-competitive [Edmonds, Pruhs 02] Longest Wait First : 6-speed, O(1)-compet. [Edmonds, Pruhs 04] Minimize Max resp time: O(1) approx [Bartal, Muthukrishnan 00] Throughput Maximization: 3/4 approx [Gandhi et al 02]

12 In this talk Average Response time minimization : Offline Setting a) 3-speed, 3-approximation b) (1+  )-speed, O(1/  )-approximation 1-speed, O(n 1/2 ) approximation c) O(log 2 n/ log log n) approximation (all via a natural LP relaxation)

13 The IP Formulation Key decision variable: : Whether page p transmitted at time t ? How to express response time of a request ?

14 Time-indexed IP formulation n t p : # requests for page p that arrive at time t

15 LP Solution : probability page p broadcast at t’ : probability, request for p at t, satisfied at t’>t For request (p,t), contribution to LP starting t’ = t+1, … until 1 unit of page p seen request for green p=1 p=2 p=3

16 Idea for 3-speed, 3-approximation For each page p, mark intervals where cumulative amount of page transmitted by LP = 1/3 If can ensure that one transmission of page p during each such interval => 3 approximation Simple greedy algorithm (EDF type) ensures this.

17 More careful analysis for 2-speed For each page p, mark intervals where cumulative amount of page transmitted by LP = 1/2 Even if one transmission within each interval Some requests may end up paying much more than LP. Some additional ideas give 2-speed, O(1) approx

18 Idea for O(n 1/2 ) approx : probability page p broadcast at t’ : probability, request for p at t, satisfied at t’>t For request (p,t), contribution to LP starting t’ = t+1, … until 1 unit of page p seen request for green Observation: If transmit p at t’ with prob, Expected response time = contribution to LP

19 Idea for O(n 1/2 ) approx Simple observation: Consider page p, choose  2 [0,1) uniformly at random Mark times where cumulative page p transmitted thus far first becomes ¸ i+  for i=0,1,2,…  1+  2+  For any request for p E  [cost] = LP cost Pr [p scheduled at time t = ]

20 Rounding Procedure (Tentative) For each page p, choose  p 2 [0,1) u.a.r Tentative Schedule: Schedule p wherever cumulative amount first exceeds i+  p, for i=0,1,… E[ # of tentative pages at any time] · 1 E[ cost of tentative schedule] = Opt LP cost.

21 Tentative ! Proper Schedule Greedily assign tentatively scheduled pages to a free time slot in the future Tentative transmission at t, pushed ahead by Backlog(t) Will show Backlog(t) = O(n 1/2 ) on average

22 Analysis Backlog(t) = max x<t Tentative pages in [x,t) – (t-x) t

23 Analysis Backlog(t) = max x<t Tentative pages in [x,t) – (t-x) E[backlog(t)] = O(n 1/2 ) If (1+  )-speed, E[Backlog(t)] = O(1/  ) In interval J=[x,t], if LP has l(p) amount of page p, then tentative schedule has d l(p) e w/ prob frac(l(p)) or b l(p) c w/ prob 1- frac(l(p)) Size(J) =  p l(p) |Tentative pages in J – Size(J)| = O(n 1/2 ) [Standard deviation]

24 Overview Good Pseudo-schedule (each request satisfied “locally”). But, Independent rounding for each page p. Backlog = O(n 1/2 ) when pages 1…n merged.

25 Attempt 1 Why choose the offset  p independently for each page p. Perhaps a better dependent way? No. An ½ integral LP instance with O(n 1/2 ) backlog no matter what offsets chosen. Intuitively, choosing offsets is not useful because choice of  p determines all future transmissions of page p.

26 Need to abandon locality!

27 Idea for improved approximation 1) Relax the locality requirement for tentative schedules 2) Ensure that combining individual schedules for each page does not produce a large backlog.

28 When can we violate locality? 0.5 Non-local: Requests here not satisfied locally. Region1 Region 2 However Not a problem if: If region 1 and region 2 had similar # of requests for page p Problem only if: Much fewer requests in region 2 than region 1 Suppose transmit here

29 Blocks For each page p, partition time into Blocks B(p,i) Can choose offset  (p,i) for B(p,i) u.a.r in [0,1] B(p,i) B(p,i+1) Expected cost for any request · 3 ¢ wait in LP t t’

30 Semi-Local Schedules In each block B(p,i) if choose offset  (p,i) u.a.r 2 [0,1] Tentative (semi-local) Schedule: Cost · 3 times Opt cost In each block B(p,i), LP transmits ¼ log(T+n) units of page p  (p,1)  (p,2)  (p,3)  (p’,1)  (p’,2)

31 Semi-Local Schedules We will form a semi-local tentative schedule by choosing offsets  (p,i) for each block B(p,i) But, we will not do it randomly. Though low cost, it has high =  (n 1/2 ) backlog, when all pages combined.  (p,1)  (p,2)  (p,3)  (p’,1)  (p’,2)

32 Issue to address How to determine offsets  (p,i) ? Will solve a sequence of LP’s Can choose offsets such that 1) Cost of pseudo-schedule · 3 OPT 2) Backlog O( log 2 (T+n)) Will imply: 3 OPT + log 2 (T+n) approximation

33 Basic Idea Original LP constraint: For each time unit, 1 cumulative unit of page transmitted. Relax it: Suppose only want 10 units of page in each group of 10 time units. If solution integral : Great! Backlog <=

34 Basic Idea Original LP constraint: For each time unit, 1 cumulative unit of page transmitted. Relax it: Suppose only want 10 units of page in each group of 10 time units. If only 50% variables integral: Still Great! Recurse: Backlog <= 20 ¢ log T

35 LP for choosing offsets B(p,i) B(p,i+1) What offset  (p,i) to choose for block B(p,i) ? Assume  (p,i) 2 { j  } j=1,2,…,1/  Define variable x(p,i,j) s.t. x(p,i,j) = 1 iff  (p,i) = j  Let R(B(p,i,j)) = contribution to total cost if  (p,i) is j  ( coefficients of objective function )

36 Minimize  p  i  j R(B(p,i,j)) x(p,i,j)  j x(p,i,j) = 1 8 Blocks B(p,i)  p  i  j c(p,i,j,t) x(p,i,j) = 1 8 time t c(p,i,j,t) =1 iff offset j  for B(p,i) implies page p at time t Number of constraints = |Blocks | + |time units| A LP soln with · |Blocks| + |time units| non-zero vars If some x(p,i,j) fractional, ¸ 2 non-zero variables for B(p,i) Suppose |time units| < |Blocks|/2 … ¸ 50% good blocks |Blocks| ¼ (T+n)/ log (T+n) LP for choosing offsets

37 Minimize  p  i  j R(B(p,i,j)) x(p,i,j)  j x(p,i,j) = 1 8 Blocks B(p,i)  p  i  j c(p,i,j,H) x(p,i,j) = Size(H) 8 intervals H c(p,i,j,H) : units of page p in H if choose offset j for B(p,i) Main Idea: Relax Constraints ¸ 50% of blocks have an x(p,i,j)=1 Remove these blocks and Repeat for O(log (T+n)) steps... H: Intervals of 5 log (T+n) time slots

38 Overview of Algorithm Each recursion adds O(log (T+n)) to backlog Final solution: 3 Opt + O(log 2 (T+n)) Can improve overall guarantee slightly to O(log 2 (T+n)/log log (T+n)) Can show wlog T = poly (n)

39 Concluding Remarks Best known integrality gap Open: Is there an O(1) approximation? Online Case: Best known: 4-speed, 4-competitive [Edmonds, Pruhs 02] Is there a (1+  )-speed, O(1)-competitive algorithm?

40 Questions?

41 Minimize  p  i  j R(B(p,i,j)) x(p,i,j)  j x(p,i,j) = 1 8 Blocks B(p,i)  p  i  j c(p,i,j,H) x(p,i,j) = Size(H) 8 intervals H | constraints| = |blocks| + |intervals| · (T+n)/log(T+n) + (T+n)/ 5 log(T+n) f + i · |constraints| (Basic LP soln) f/2 + i ¸ |blocks| i ¸ |blocks| – 2 |intervals| ¸ 0.5 |blocks| At least 50% blocks removed i: variables set to 1 f: non-zero fractional variables

42 Cable Repair Problem Day 0 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123

43 Cable Repair Problem Day 0 Day 1 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123 Day 1: Visit Town 1 Total Wait = 2 +

44 Cable Repair Problem Day 0 Day 1 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123 Day 1: Visit Town 1 Total Wait = Day 2: Visit Town 3 Day 2

45 Cable Repair Problem Day 0 Day 1 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123 Day 1: Visit Town 1 Total Wait = Day 2: Visit Town 3 Day 2 Day 3: Visit Town 2

46 Cable Repair Problem Day 0 Day 1 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123 Day 1: Visit Town 1 Total Wait = Day 2: Visit Town 3 Day 2 Day 3: Visit Town 2 Day 4: Visit Town 1

47 Cable Repair Problem Day 0 Day 1 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123 Day 1: Visit Town 1 Avg. Wait = ( )/ 14 Day 2: Visit Town 3 Day 2 Day 3: Visit Town 2 Day 4: Visit Town 1

48 Traveling Repairman with release times Collection of requests r 1,…,r m Request r i = ( Vertex v i, time t i ) A vertex may submit more than 1 request. If repairmen visits v at time t it satisfies all outstanding requests at v made before time t. Goal: Minimize average waiting time to satisfy request. Considerably harder! Very restricted case: All distances are 1. Also referred to as broadcast scheduling problem.

49 Broadcast Scheduling Problem Collection of pages 1,2,…,n at a broadcast server (satellite) Requests r 1,…,r m Request r i : [page p i, arrival time a i ] Many requests may arrive at a time slot. Server transmits 1 page per time slot. Page p broadcast at time t, satisfies all outstanding requests for p that arrived at time <t If request r i satisfied at b i Response Time: b i – a i Goal: Find broadcast schedule to Minimize average response time (  i (b i – a i )) / m

50 Example Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,32,3 Total Response Time = t=0 Requests Pages {1,2,3}

51 Example Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,32,3 Total Response Time = t=0 Requests Pages {1,2,3}

52 Example Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,3 Total Response Time = t=0 Requests Pages {1,2,3}

53 Example Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,32,3 Total Response Time = t=0 Requests Pages {1,2,3}

54 Example Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,32,3 Total Response Time = = t=0 Requests Pages {1,2,3}

55 Example Response Time of r i = b i – a i b i : time r i satisfied a i : arrival time of r i Broadcasting page p at time t satisfies all outstanding requests for p that arrive at <t. 1,1,232,32,3 Total Response Time = = t=0 Requests Avg=1.5 Pages {1,2,3}

56 NP-Hard: [Erlebach, Hall 02] Resource augmentation: Can transmit s>1 pages per time slot. s-speed, c-approx: If max I Alg s (I)/Opt 1 (I) · c 3-speed, 3-approx [Kalyanasundaram et al 00] 6-speed, 1-approx [Erlebach, Hall 02] 2-speed, 2-approx & 4-speed, 1-approx [Gandhi et al 02] 2-speed, 1-approx [Gandhi et al 02] (1+  )-speed, O(1/  )-approx [B., Charikar, Khanna, Naor 05] Without speedup: Trivial O(n) approximation, Round Robin O(n 1/2 ) approximation [B., Charikar, Khanna, Naor 05] O(log 2 n/log log n) approximation [B., Coppersmith, Sviridenko]

57 Previous Work (Online Case) Any deterministic alg:  (n) competitive [Kalyanasundaram et al 00] Any randomized alg:  (n 1/2 )- competitive B-Equi : 4-speed, 4-competitive [Edmonds, Pruhs 02] Longest Wait First: 6-speed, O(1) compet. [Edmonds, Pruhs 04]

58 In this talk Approximation Algorithms without Resource Augmentation. a) O(n 1/2 ) approximation [B., Charikar, Khanna, Naor 05] b) O(log 2 n/ log log n) approximation [B., Coppersmith, Sviridenko]

59 Time-indexed IP formulation n t p : # requests for page p that arrive at time t

60 LP Solution : amount of page p broadcast at t’ : request for p at t, amount satisfied at t’>t For request (p,t), contribution to LP starting t’ = t+1, … until 1 unit of page p seen request for green tt+1t+2 … p=1 p=2 p=3

61 LP Solution : amount of page p broadcast at t’ : request for p at t, amount satisfied at t’>t For request (p,t), contribution to LP starting t’ = t+1, … until 1 unit of page p seen request for green tt+1t+2 … p=1 p=2 p=3

62 Rounding Procedure First obtain a tentative schedule. May assign more than one page to a time slot.

63 Rounding Procedure Greedily assign tentatively scheduled pages to a free time slot in the future First obtain a tentative schedule. May assign more than one page to a time slot. Final Cost: Cost of tentative schedule + distance moved

64 Rounding Procedure (Tentative) Consider page p, choose  2 [0,1) uniformly at random Mark times where cumulative page p transmitted thus far in LP solution first becomes ¸ i+  for i=0,1,2,…  1+  2+ 

65 Rounding Procedure (Tentative) Consider page p, choose  2 [0,1) uniformly at random Mark times where cumulative page p transmitted thus far in LP solution first becomes ¸ i+  for i=0,1,2,… For any request for page p E  [cost] = LP cost Pr [p scheduled at time t] = request for green For request (p,t), contribution to LP =

66 Rounding Procedure (Tentative) For each page p, choose  p 2 [0,1) u.a.r Tentative Schedule: Schedule p wherever cumulative amount first exceeds i+  p, for i=0,1,… E[ # of tentative pages at any time] = 1 E[ cost of tentative schedule] = Opt LP cost.

67 Tentative ! Proper Schedule Greedily assign tentatively scheduled pages to a free time slot in the future Tentative transmission at t, pushed ahead by Backlog(t) Backlog(t) =  (n 1/2 ) on average

68 Analysis Backlog at time t : No more than b, if every interval [t-x,t] has at most x+b pages assigned to it. t

69 Expected Backlog  (n 1/2 ) Consider interval [t-x,t] If LP schedules l(p) amount of page p, Tentative schedule has d l(p) e w/ prob frac(l(p)) or b l(p) c w/ prob 1- frac(l(p)) Example: If LP sends 10.3 units of page 1, tentative schedule has 11 pages with prob pages with prob 0.7 x =  p l(p) Interval [t-x,t] has x § O(n 1/2 ) pages (standard deviation)

70 Overview & Local Schedules Tentative Schedule: Each request, satisfied “locally” Random offset  p for page p Backlog O(n 1/2 ) Unfortunately, there are examples where any “local” schedule has backlog  (n 1/2 ) Local schedules very restricted request for green

71 How does this apply here? We reduced our problem to determining offset \alpha(p,i) for each block B(p,i) Write an LP to determine \alpha(p,i) Suppose \alpha x(p,i,j) Block B(p,i) contains at most 2 log T units of page p. So, number of blocks \geq T/2\log T Need 1 offset per block,

72 How to choose the offsets? Suppose we partition time into intervals of size 3. Tentative schedule with Property: Any interval of size 3 is assigned at most 3 transmissions. Then Backlog at most 6.

73 LP for choosing offsets B(p,i) B(p,i+1) Write an LP for choosing offsets for each block B(p,i) x(p,i,j) =1 : If offset = j/(n+T) 2 for block B(p,i) j 2 [1,(n+T) 2 ] Partition time into intervals with 5 log (T+n) time slots each. Constraint: Each interval has exactly 5 log (T+n) pages assigned in the tentative schedule. Constraints More than 50% blocks have some x(p,i,j)=1.

74 Overview of Algorithm Solve the LP. Remove the blocks that have x(p,i,j)=1. Shrink the problem. O(log (T+n)) iterations of the process Each step adds O(log (T+n)) to the backlog. Final solution: 3 Opt + O(log 2 (T+n)) Can remove dependence on T. And improve guarantee to O(log 2 (n)/log log (n))

75 Concluding Remarks Best known integrality gap 28/27 ¼ Open: Is there an O(1) approximation?

76 Questions?

77 Our Approach For each page p, partition time into blocks B(p,i) Cumulative page p broadcast during B(p,i) 2 [log(T+n),2 log(T+n)] We will choose offsets  (p,i) 2 [0,1] for each B(p,i), such that 1) Cost of pseudo schedule <= 3 LP cost 2) Any interval of size t has [ t – O(log 2 n), t+ O(log 2 n)] pages assigned in the pseudo-schedule B(p,i) B(p,i+1)

78 Minimize  p  i  j R(B(p,i,j)) x(p,i,j)  j x(p,i,j) = 1 8 Blocks B(p,i)  p  i  j c(p,i,j,t) x(p,i,j) = 1 8 time t c(p,i,j,t) =1 iff offset j  for B(p,i) implies page p at time t Choosing each offset uniformly (x(p,i,j) =  ) Feasible with value <= 3 LP 1 cost If solution integral … we would be done! Backlog = 0 LP for choosing offsets

79 Minimize  p  i  j R(B(p,i,j)) x(p,i,j)  j x(p,i,j) = 1 8 Blocks B(p,i)  p  i  j c(p,i,j,H) x(p,i,j) = Size(H) 8 intervals H c(p,i,j,H) : units of page p in H if choose offset j for B(p,i) Relax constraints: Main Idea: Relax Constraints If integral solution, then Backlog = O(log (T+n)) Can show ¸ 50% of blocks have an x(p,i,j)=1 Remove these blocks and Repeat for O(log (T+n)) steps... Intervals of 5 log (T+n) time slots

80 Our Approach For each page p, partition time into blocks B(p,i) Schedule is local within each block B(p,i) We will choose offsets  (p,i) 2 [0,1] for each B(p,i), such that 1) Cost of pseudo schedule <= 3 LP cost 2) Any interval of size t has [ t – O(log 2 (T+n)), t+ O(log 2 (T+n))] pages assigned in the pseudo-schedule B(p,i) B(p,i+1)

81 Analysis Backlog(t) = max x<t Tentative pages in [x,t) – (t-x) ¸ trivial · x: last time when backlog = 0 t

82 Idea for O(n 1/2 ) approx : amount of page p broadcast at t’ : request for p at t, amount satisfied at t’>t For request (p,t), contribution to LP starting t’ = t+1, … until 1 unit of page p seen request for green Observation: If transmit p at t’ with prob, Expected response time = contribution to LP

83 Minimize  p  i  j R(B(p,i,j)) x(p,i,j)  j x(p,i,j) = 1 8 Blocks B(p,i)  p  i  j c(p,i,j,H) x(p,i,j) = Size(H) 8 intervals H c(p,i,j,H) : units of page p in H if choose offset j for B(p,i) Relax constraints: Main Idea: Relax Constraints If integral solution, then Backlog = O(log (T+n)) Can show ¸ 50% of blocks have an x(p,i,j)=1 Remove these blocks and Repeat for O(log (T+n)) steps... Intervals of 5 log (T+n) time slots

84 Minimize  p  i  j R(B(p,i,j)) x(p,i,j)  j x(p,i,j) = 1 8 Blocks B(p,i)  p  i  j c(p,i,j,t) x(p,i,j) = 1 8 time t c(p,i,j,t) =1 iff offset j  for B(p,i) implies page p at time t Choosing each offset uniformly (x(p,i,j) =  ) Feasible with value <= 3 LP 1 cost If solution integral … we would be done! Backlog = 0 LP for choosing offsets

85 Cable Repair Problem Day 0 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123

86 Cable Repair Problem Day 0 Day 1 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123 Day 1: Visit Town 1 Total Wait = 2 +

87 Cable Repair Problem Day 0 Day 1 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123 Day 1: Visit Town 1 Total Wait = Day 2: Visit Town 3 Day 2

88 Cable Repair Problem Day 0 Day 1 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123 Day 1: Visit Town 1 Total Wait = Day 2: Visit Town 3 Day 2 Day 3: Visit Town 2

89 Cable Repair Problem Day 0 Day 1 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123 Day 1: Visit Town 1 Total Wait = Day 2: Visit Town 3 Day 2 Day 3: Visit Town 2 Day 4: Visit Town 1

90 Cable Repair Problem Day 0 Day 1 Repairman serves n towns ; requests arrive arbitrarily Can visit exactly 1 town a day Can serve all outstanding requests, in that town Goal: Minimize average wait 123 Day 1: Visit Town 1 Avg. Wait = ( )/ 14 Day 2: Visit Town 3 Day 2 Day 3: Visit Town 2 Day 4: Visit Town 1

91 Idea for 3-speed, 3-approximation For each page p, mark intervals where cumulative amount of page transmitted by LP = 1/3 If can ensure that one transmission of page p during each such interval => 3 approximation Simple greedy algorithm (EDF type) ensures this.

92 More careful analysis for 2-speed For each page p, mark intervals where cumulative amount of page transmitted by LP = 1/2 Even if one transmission within each interval Some requests may end up paying much more than LP. Some additional ideas give 2-speed, O(1) approx

93 Minimize  p  i  j R(B(p,i,j)) x(p,i,j)  j x(p,i,j) = 1 8 Blocks B(p,i)  p  i  j c(p,i,j,H) x(p,i,j) = Size(H) 8 intervals H | constraints| = |blocks| + |intervals| · (T+n)/log(T+n) + (T+n)/ 5 log(T+n) f + i · |constraints| (Basic LP soln) f/2 + i ¸ |blocks| i ¸ |blocks| – 2 |intervals| ¸ 0.5 |blocks| At least 50% blocks removed i: variables set to 1 f: non-zero fractional variables

94 Local Approach => Backlog =  (n 1/2 ) If requests satisfied locally => above type of solutions only All choices for offsets are bad A 1,…,A n ½ {1,2,…,n} |A i | = n/2 For any {-1,+1} coloring  of {1,2,…,n} some | A i  | > n 1/2 Half Integral LP 0.5 Even Slots

95 Defining blocks B(p,i)B(p,i+1) t r(p,t) : LP wait time for request for page p, that arrives at t Tail of B(p,i) Tail of B(p,i) : Interval when last 1 unit of page p transmitted by LP Intuitively, allows us to move request arriving at t’ to t. Every interval that transmits >= log(T+n) units of p, has such t. r(p,t) · 2 r(p,t’) for all t’ in tail of B(p,i)