320 likes | 486 Views
Group strategy proof mechanisms via primal-dual algorithms (Cost Sharing). Martin P ál Éva Tardos. c* ( U ) = cost of. c* ( ) = cost of. U = { , , , , }. c* ( S ) – cost of optimal infrastructure for users in S. often NP-hard to compute. Our setting.
E N D
Group strategy proof mechanisms via primal-dual algorithms(Cost Sharing) Martin Pál Éva Tardos Cost sharing & Approximation
c*(U) = cost of c*() = cost of U = {,,,,} c*(S) – cost of optimal infrastructure for users in S often NP-hard to compute Our setting Universe U of (selfish) users Users want to benefit from shared infrastructure cost function c*() Cost sharing & Approximation
Approximate Cost Recovery: ΣiU pi ≥ c*(U) user shares cost Competitiveness: ΣiS pi ≤ c*(S) for any SU: no overpayment p+p+p+p+p ≥ c( ) p+p+p≤ c( ) often empty for games of interest Sharing the cost Known as core in game theory Cost sharing & Approximation
need to recompute tree & payments! Modeling the users ui – value of service for i User may say NO if pi>ui util(i) = ui – pi if i gets service 0 otherwise Cost sharing fn: ξ : 2UU + ξ(S,i) – share of user i, if set S served ξ(U, ) ≤ ξ(U-, ) • cross-monotonic: for iSTU • ξ(S,i) ≥ ξ(T,i) Cost sharing & Approximation
ui cost share The Moulin&Shenker mechanism • S := U • repeat • ask each user i • “is ξ(S,i)≤ ui ?” • drop all iS who say NO • until all iS say YES • Output: set S; prices pi = ξ(S,i) Theorem: [Moulin&Shenker]: ξ(.) cross-monotonic mechanism group strategyproof Cost sharing & Approximation
Known cross-monotonic functions • Exact cross-monotonic sharing exists if c*() submodular • [Moulin&Shenker 98] • Exact cost sharing for spanning tree • [Kent&Skorin-Kapov 96], [Jain&Vazirani 01] • Any other games for which cross-mono sharing exists? implies 2-approx. cost sharing for Steiner tree Cost sharing & Approximation
Our results General method for generating competitive, cross-monotonic cost shares using primal-dual algorithms Used our method to construct a cost sharing fn for: Metric Facility Location Single Sink Rent or Buy recovers 1/3 of cost recovers 1/15 of cost competitive, cross-monotonic constructive proof gives an approximation algorithm Cost sharing & Approximation
Approximation algorithms • Primal-dual approximation for Facility Location • [Jain&Vazirani99] , [Mahdian,Ye&Zhang 02], [Mettu&Plaxton 00] • Approximation for Single Sink Rent or Buy [Karger&Minkoff 00], [Meyerson&Munagala 00] • [Swamy&Kumar 02], [Gupta,Kumar&Roughgarden 03] Cost sharing & Approximation
Single Sink Rent or Buy U is a set of users. r is the sink (root) node. graph G with edge lengths ce. 1) Find a path from each user to sink. 2) Rent or Buy each edge. Rent: pay ce for each path using e Buy: pay M ce Goal: minimize rental + buying cost. Cost sharing & Approximation
Facility Location F is a set of facilities. U is a set of users. cij is the distance between any i and j in U F. (assume cij satisfies triangle inequality) fi: cost of facility i Cost sharing & Approximation
Facility Location 1) Pick a subset F’ of facilities to open 2) Assign every client to an open facility Goal: Minimize the sum of facility and assignment costs: ΣiF’fi + ΣjS c(j,σ(j)) Cost sharing & Approximation
cost shares Existing facility location algorithms.. each user j raises its j j pays for connection first, then for facility if facility paid for, declared open (possibly cleanup phase in the end) =5 =5 =6 Cost sharing & Approximation
...do not yield cross-monotonic shares previously, ()=6 with , ()=8 helped to stop earlier failed to help =3 =3 =8 Cost sharing & Approximation
Ghost shares After i freezes, continue growing its ghosti ghosts keep growing forever =3 =3 =5.5 Fact: Shares i are cross-monotonic. Pf: more users more ghosts facilities open sooner i can stop growing earlier Cost sharing & Approximation
q tq ≤tp/3 r tr ≤tq/3 Constructing a solution (1) Sp: set of users contributing to p at time of opening – “contributor set” tp: time of opening facility p tp Sp p facility p is well funded, if j≥tp/3 for every jSp Close down all facilities that are not well funded Lemma: For every facility p there is a nearby well funded facility r s.t. dist(p,r) ≤ 2(tp- tr) Cost sharing & Approximation
well-funded open p r q ≤ ≤2(tp- tr) ≤2tr Constructing a solution (2) Problem: user contributing to multiple well-funded facilities Solution: close all of them but one (process by increasing tp) tp Sp p Lemma: For every well funded facility p there is a nearby open q such that dist(p,q) ≤ 2tp tq Sq q Cost sharing & Approximation
tp Sp p well-funded open p r q ≤ ≤2(tp- tr) ≤2tr Summing up Every open facility is well funded, i.e. can be paid for by Sp. We do not lose much on assignment cost by closing facilities. Cost shares pay for 1/3 of the cost of the solution. Theorem: There is a cross-monotonic cost sharing function for facility location that recovers 1/3 of cost. Cost sharing & Approximation
Plan of attack for Rent or Buy • Gather clients into groups • (often done by a facility location algorithm) • Build a Steiner tree on the gathering points Jain&Vazirani gave cost sharing fn for Steiner tree Have cost sharing for facility location Why not combine? Cost sharing & Approximation
“One shot” algorithm • Generate gathering points and build a Steiner tree at the same time. • Allow each user to contribute only to the least demanding (i.e. largest) cluster he is connected to. • not clear if the shares can pay for the tree Cost sharing & Approximation
Conclusions General method for generating competitive, cross-monotonic cost shares using primal-dual algorithms. Used our method to construct a cost sharing fn forFacility Location & Single Sink Rent or Buy. Other problems admitting cross-mono cost sharing? Steiner Forest? Covering problems? Impossibility results? Cost sharing & Approximation
*** *** The End *** *** The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. The End. Cost sharing & Approximation
Cost shares Each Steiner component C needs $1/second for growth. Maintenance cost of C split among users connected User connected to multiple components pays only to largest component User connected to root stops paying j =∫ fj(t) dt Cost sharing & Approximation
Growing ghosts Grow a ball around every user uniformly When M or more balls meet, declare gathering point Each gathering point immediately starts growing a Steiner component When two components meet, merge into one Cost sharing & Approximation
Well funded p q ≤tp1 ≤tp ≤tp1 ... tp tp1 ≤ j tq j≤tp/3 healthy c(p,q’) ≤tp q’ Building a solution Open all healthy well funded facilities Assign each client to closest facility Fact 1: for every facility p, there is an open facility q within radius 2tp. c(p,q) ≤2(tp-tq) c(q,q’)≤2 tq Cost sharing & Approximation
Cost Sharing • Internet: many independent agents • Not hostile, but selfish • Willing to cooperate, if it helps them Cost sharing & Approximation
4 3 4 2 2 3 ? 3 1 0 4 4 2 4 3 ? 3 2 3 ? Cost shares Cost shares Steiner tree: how to split cost Cost sharing & Approximation
Steiner tree: how to split cost OPT( ) = 3 OPT( ) = 5 p( ) = 5-3 = 2 No “fair” cost allocation exists! Cost sharing & Approximation
ΣjS pj ≤ c*(S) (competitiveness) ΣjS pj ≥ c(S)/β (approx. cost recovery) Desirable properties of mechanisms • ΣjS pj=c*(S) • (budget balance) • Only people in S pay • (voluntary participation) • No cheating, even in groups • (group strategyproofness) • If uj high enough, j guaranteed to be in S • (consumer sovereignity) Cost sharing & Approximation
Cost sharing function • ξ : 2UU ℛ • ξ(S,j) – cost share of user j, given set S • Competitiveness: ΣjSξ(S,j)≤c*(S) • Cost recovery: c(S)/β≤ΣjSξ(S,j) • Voluntary particpiation: ξ(S,j) = 0 if jS • Cross-monotonicity: for jST • ξ(S,j) ≥ ξ(T,j) Cost sharing & Approximation
Cost recovery To prove cost recovery, we must build a network. Steiner tree on all centers would be too expensive select only some of the centers like we did for facility location. Need to show how to pay for the tree constructed. Cost sharing & Approximation
Paying for the tree We selected a subset of clusters so that every user pays only to one cluster. But: users were free to chose to contribute to the largest cluster – may not be paying enough. Solution: use cost share at time t to pay contribution at time 3t. Cost sharing & Approximation
Thank you! The last slide • x-mono cost sharing known only for 3 problems so far • Do other problems admit cross-mono cost sharing? • Covering problems? Steiner Forest? • Negative result: SetCover – no better than Ω(n) approx • Applications of cost sharing to design of approximation algorithms. Cost sharing & Approximation