We consider a job-scheduling problem arising on cloud systems and in broadcasting networks, where the goal is to optimally utilize a limited amount of a resource (e.g., cloud servers, bandwidth, or storage capacity) available along a given time interval. The resource is utilized by a set of weighted jobs. The processing of a job consists of several contiguous stages, each having a specific length and a specific resource-demand, such that the set of demands forms a decreasing sequence. Each job is associated with a release time and a deadline, defining the time interval in which it can be processed. Some notable applications for this scenario include progressive download, QuickStart and prefetching methods, hierarchical image reconstruction, and routine security and maintenance tasks. The goal is to find a feasible schedule of a maximum-weight subset of the jobs. In a feasible schedule, at any time, the total amount of resource allocated to the active jobs does not exceed the available amount of resource. Since this problem is NP-hard already for highly restricted inputs, we focus on obtaining approximation algorithms and heuristics and present a comparative study among them. Our main result, the first constant-factor approximation algorithm for the problem, generalizes the state of art for the fundamental problem of resource constrained real-time scheduling, to scenarios where jobs may have dwindling resource requirements. Our empirical study shows that this algorithm is in fact nearly optimal for realistic inputs.
[1]
Reuven Bar-Yehuda,et al.
A unified approach to approximating resource allocation and scheduling
,
2001,
JACM.
[2]
Richard E. Ladner,et al.
Optimal Delay for Media-on-Demand with Pre-loading and Pre-buffering
,
2006,
SIROCCO.
[3]
Cynthia A. Phillips,et al.
Off-line admission control for general scheduling problems
,
2000,
SODA '00.
[4]
Dror Rawitz,et al.
Using fractional primal-dual to schedule split intervals with demands
,
2005,
Discret. Optim..
[5]
Joseph Naor,et al.
A Truthful Mechanism for Value-Based Scheduling in Cloud Computing
,
2013,
Theory of Computing Systems.
[6]
Sudipto Guha,et al.
Approximating the Throughput of Multiple Machines in Real-Time Scheduling
,
2002,
SIAM J. Comput..
[7]
Henrique S. Malvar.
Fast progressive image coding without wavelets
,
2000,
Proceedings DCC 2000. Data Compression Conference.
[8]
F. Spieksma.
On the approximability of an interval scheduling problem
,
1999
.
[9]
Rina Panigrahy,et al.
Heuristics for Vector Bin Packing
,
2011
.
[10]
Dror Rawitz,et al.
Using fractional primal-dual to schedule split intervals with demands
,
2006,
Discret. Optim..
[11]
D. Atkin.
OR scheduling algorithms.
,
2000,
Anesthesiology.