1 Introduction

As a common supply chain management practice, manufacturers take advantage of external resources to alleviate the burden of internal operations through subcontracting and outsourcing. While outsourcing externalizes some internal operations, subcontracting allows manufacturers to carry out jobs both internally and externally (Van Mieghem 1999). In this manner, subcontracting enables a manufacturer to speed up the completion times of his jobs. Instances of subcontracting practices can be found in quick-response industries characterized by volatile demand and inflexible capacities, e.g., metal fabrication industry (Parmigiani 2003), electronics assembly (Webster et al. 1997), high-tech manufacturing (Aydinliyim and Vairaktarakis 2011), textile production, and engineering services (Taymaz and Kiliçaslan 2005).

Although a considerable number of papers in the literature analyzes the subcontracting strategies in production planning and scheduling problems of manufacturers (Kamien and Li 1990; Tan and Gershwin 2004; Chen and Li 2008; Lee and Sung 2008), the subcontractors’ scheduling problems have received less attention. In reality, a subcontractor by itself faces a limited capacity while providing service to several manufacturers. Given the time-sensitive nature of subcontracting operations, the subcontractor’s schedule has critical impact on the performance of manufacturers as well as the supply chain. The lack of due attention to the subcontractors’ operations can cause significant complications in the extended supply chain. A well-documented real-life example of this issue has been reported in Boeing’s Dreamliner supply chain where the overloaded schedules of subcontractors, each working with multiple suppliers, resulted in long delays in the overall production due dates (see Vairaktarakis (2013) and the references therein).

An important feature of subcontractor’s scheduling problem is that the jobs belong to different manufacturers who are concerned with the processing of their own jobs only.

Unlike centralized systems where a single decision maker controls all the relevant decision variables and possesses all the necessary information, the agents in a decentralized system have some control over their individual decisions and/or are privately informed about some aspects of the system. Therefore, in order for the system to achieve a particular objective a mechanism is needed that motivates the agents to make their decisions and reveal their private information in a way that the system’s ultimate objective is attained indirectly. In this paper, we focus on the efficiency objective, that is, we are seeking mechanisms that result in subcontracting schedules that maximize the total savings obtained by all manufacturers. In other words, we address the problem of coordination in decentralized subcontracting systems.

The mechanisms considered in this paper are pricing and payment schemes that the subcontractor announces before the manufacturers choose their most desirable subcontracting intervals. Such mechanisms are in fact common in practice. An example is the online reservation system implemented by the Semiconductor Product Analysis and Design Enhancement (SPADE) center of the Hong Kong University of Science and TechnologyFootnote 1 wherein the semiconductor companies choose service time intervals in a first-come-first-book manner and in consideration of an announced price list for services in different time intervals.

Naturally, the design of mechanisms in the decentralized subcontracting systems must consider the utility of agents, i.e., savings due to subcontracting minus payments, as well as the subcontractor’s revenue to ensure that all parties are sufficiently motivated to participate and operate in the system.

In this paper, we study a subcontractor scheduling problem with several manufacturer agents and a single subcontractor that carries out the agents’ jobs on a single machine. Of particular interest to this paper is the scenario where a divisible job can be processed simultaneously on the manufacturer’s private machine as well as on the subcontractor’s machine. The reduction in completion time of an agent’s job obtained by such parallel processing provides monetary saving for that agent.

The paper is organized as follows. Section 2 contains a review of related work. In Sects. 3 and 4, we assume complete information and give pricing schemes that coordinate the decentralized system. That is the pricing schemes enforce a choice of subcontracting time intervals that coincides with efficient allocations of the centralized solution for every agent. In particular, Sect. 3 characterizes efficient allocations of the centralized solution. Section 4 provides sufficient conditions for the existence of coordinating pricing schemes and it introduces a family of pricing schemes that are strongly coordinating. With a strongly coordinating pricing scheme, the efficient allocations in the centralized solutions are uniquely optimal for all agents. Moreover, we show a lower bound on the total payments for any coordinating pricing scheme. Finally we show that with the appropriate choice of a single parameter, our proposed pricing schemes enable the subcontractor to obtain a total revenue anywhere between the lower bound and the maximum total savings.

In Sect. 5, we allow the true processing time of each job to be a private information of its agent and we address the intricacies resulting from agents possibly lying by reporting false processing times in order to obtain their preferred subcontracting intervals. In order to achieve efficiency, however, the subcontractor elicits the true processing times of jobs using certain mechanism. We draw upon the class of efficient and incentive compatible mechanisms and on the pivotal mechanism (Vickrey 1961; Clarke 1971; Groves 1973) in particular. The underlying reason for this choice is that the pivotal mechanism is the only efficient and incentive compatible mechanism that always results in non-negative payments from agents to the subcontractor. This is a desirable property as agents must not be paid if their jobs are processed by the subcontractor in the subcontractor scheduling problem. We obtain a simple closed-form formula for the payments in the pivotal mechanism and prove that the pivotal mechanism results in truth-telling being the unique optimal choice of all agents except the one scheduled last on the subcontractor’s machine who can possibly exaggerate his processing time without affecting anyone’s utility. This result is particularly interesting as “uniqueness of equilibrium might be thought of as the exception rather than the rule” (Jackson 2000). Since we also show that the mechanism guarantees that all agents are better off by subcontracting, we actually prove that the pivotal mechanism coordinates the decentralized subcontracting problem under private information. Finally, we show that under any coordinating mechanism, the subcontractor’s revenue is equivalent to the lower bound of that with the coordinating pricing schemes. Therefore, coordinated system under private information never generates higher total revenue for the subcontractor than that under complete information.

In Sect. 6, we address the asymmetric case where the agents obtain savings at different rates. The efficient centralized allocations in this case are more difficult to characterize. Moreover, we show that it is impossible to devise a coordinating pricing scheme in general for this case. Section 7 contains the concluding remarks.

2 Related work

The decentralized scheduling problems have been considered in cooperative and non-cooperative settings.

In the former, agents (jobs) are able to communicate and coordinate strategies. The early work of Curiel et al. (1989) studies the cost allocation problem in a cooperative game based on the perennial scheduling problem of Smith (1956). A survey of related research is given by Curiel et al. (2004).

In the non-cooperative settings agents choose their strategies individually and in competition with other agents. This paper falls in this category.

Heydenreich et al. (2007) provide an introduction to and a literature review of problems arising in the non-cooperative decentralized scheduling. One important problem pertains to determining the equilibria of individual decisions and the quality of the corresponding solution compared with that of the centralized optimal solution. The pioneering work of Koutsoupias and Papadimitriou (1999), which gave rise to the literature on price of anarchy, analyzes the worst-case performance of a decentralized scheduling system with parallel machines in comparison with that in the centralized system.

As the outcomes of a decentralized system depend on the “policies” employed to handle the agents, another important problem addresses a better design of such policies. The coordination mechanisms discussed by Christodoulou et al. (2004) seek policies which improve the performance of a decentralized parallel sequencing system—Immorlica et al. (2005) review and extend this line of research. Ideally, such policies could make the decentralized system as efficient as the centralized system. Wellman et al. (2001) study pricing schemes for a scheduling problem that could achieve this goal and show that such pricing schemes might not exist in general. Kutanoglu and Wu (1999) report similar non-existence results for another scheduling problem. Even if the existence of such pricing schemes could be proven, the problem of finding the pricing scheme might be NP-hard (Chen et al. 2004).

Private information further complicates the coordination problem. The well-known incentive compatible mechanisms draw upon payment schemes to truthfully elicit the private information of the agents. The Vickery–Clarke–Groves (VCG) mechanisms (Vickrey 1961; Clarke 1971; Groves 1973) characterize all efficient mechanisms that make truth-telling an undominated strategy of all agents. For single machine sequencing, Suijs (1996) shows that there exists no incentive compatible and individually rational mechanism that results in the total payment of zero. Nisan and Ronen (2007) propose payment schemes that guarantee a certain performance for a decentralized scheduling problem for which the payment schemes of VCG mechanisms are NP-hard to compute.

The decentralized subcontracting and outsourcing problems have also been addressed in a number of papers. Aydinliyim and Vairaktarakis (2010) study a cooperative game where coalitions of agents reschedule their reserved time intervals to obtain savings. They prove non-emptiness of the core and the convexity of the corresponding game. Cai and Vairaktarakis (2012) investigate a problem with overtime and tardiness costs where the subcontractor announces the prices of time intervals before agents book their most preferred time intervals in a first-come-first-book manner. They show the balancedness of the corresponding cooperative game and implement the VCG mechanisms to elicit the private information of agents. Bukchin and Hanany (2007) compare the costs of a scheduling system comprised of multiple capacitated agents and an uncapacitated subcontractor in decentralized and centralized systems. Qi (2012) investigates a subcontractor’s pricing problem with a single agent having multiple jobs which can be subcontracted (though not partially) to reduce the tardiness costs.

The subcontracting problem related to the one addressed in this paper was first studied by Vairaktarakis and Aydinliyim (2007) where they compare the performance in decentralized and centralized settings. Building upon the same model, Vairaktarakis (2013) analyzes the outcomes of a decentralized subcontracting system under different protocols announced by the subcontractor. However, both papers assume complete information and neither provides coordinating pricing schemes for the problem. The model considered in this paper generalizes the model of Vairaktarakis and Aydinliyim (2007) by allowing an agent to use more than one interval on the subcontractor’s machine. This generalization is critical for a coordinating pricing schemes which need to give the agents freedom in choosing how many intervals on the subcontractor’s machine to buy—the Vairaktarakis and Aydinliyim (2007) model would a priori limit this choice to at most a single interval which does not make their model adequate for the study of pricing schemes.

It is worth noticing that the models in Vairaktarakis and Aydinliyim (2007) and Vairaktarakis (2013) borrow from the concept of divisible jobs introduced in the context of job shops by Anderson (1981), and in the context of distributed computer systems scheduling by Bharadwaj et al. (1996), see also Drozdowski (2009) for a more recent review.

The distributed computer systems provide another important application area for the results obtained in this paper, where agents carry out their computations on their private machines as well as buy computational time on shared CPUs with available capacity.

3 The problem

Consider a set of agents \(N=\{1, \ldots ,n\}\). At time \(t=0\), agent \(i\in N\) has a divisible job with processing time \( p_{i}>0\).Footnote 2 Let \(p=\left( p_{1}, \ldots ,p_{n}\right) \) be the vector of processing times. We assume, except in Sect. 5, that p is given. An agent i has its own private machine to do its job in time \(p_i\), besides private machines a subcontractor is available that can process any portion of job i on its machine that can be shared by all agents. Thus, by subcontracting, agent i can reduce the completion time of its job to less than \(p_i\). Let \(T_{i}=\cup _{k=1}^{m_{i}}T_{i}^{k}\) be the total time allocated to agent i consisting of \(m_{i}\) non-overlapping subintervals \(T_{i}^{k}=[t_{i}^{k},t_{i}^{k}+\bar{t}_{i}^{k})\) where \(t_{i}^{k} \ge 0\) and \(\bar{t}_{i}^{k}> 0\) are the start time and the duration of the kth subinterval, respectively. The subintervals of agent i are indexed by the order of their start times. An allocation \(T=\{T_{i}|i\in N\}\) is a set of allocations \(T_i\) on subcontractor’s machine. Allocation T is feasible if and only if for any i, j, k,  and \(k^{\prime }\) the subintervals \([t_{i}^{k},t_{i}^{k}+\bar{t} _{i}^{k}) \) and \([t_{j}^{k'},t_{j}^{k'}+\bar{t} _{j}^{k'}) \) do not overlap. Let \({\mathfrak {T}}\) denote the set of all feasible allocations T for the agents in N.

Our model allows preemptions on subcontractor’s machine, that is the portion of a job allocated to the subcontractor’s machine (or the subcontracted part of a job) is allowed to be executed in more than one disjoint time interval on that machine. This renders our model to be more general and arguably closer to real-life than the one in Vairaktarakis and Aydinliyim (2007) where only at most one time interval on subcontractor’s machine is allowed for any subcontracted part. Consequently two main decisions need to be made for each job in the model: one is the size of the subcontracted part of a job (this part can be executed on the subcontractor’s machine simultaneously with the remaining part of the job executed on private machine—thus the term divisible jobs), the other as to how to execute the subcontracted part (this part can possibly be executed in several disjoint time intervals—thus the term preemptions on the subcontractor’s machine).

The saving obtained by agent i from an allocation \(T_i\) is calculated recursively as follows. Assume that initially, agent i uses its private machine only in the interval \([0,p_i]\), \(i\in N\). Take the earliest interval allocated to i, \(T_{i}^{1}\). If the start time \(t_{i}^{1}<p_i\), then a portion of the remainder of job i done after \(t_{i}^{1}\), i.e., \(p_i-t^{1}_{i}\), on i’s private machine can be transferred to the subcontractor. The most efficient way to do this is for agent i to split the remainder equally between its private and subcontractor’s machines, unless the duration of the interval is too short (see Fig. 1). If the duration of the interval is too short, i.e., \(\bar{t}_i^1<(p_i-t^{1}_{i})/2\), then \(T_i^1\) is fully utilized by i on the subcontractor’s machine. Therefore, by utilizing the allocated interval \(T^1_i\), agent i can reduce the finish time of its job by an amount equal to

$$\begin{aligned} \upsilon _{i}(T^1_i)=\max \left\{ \min \left\{ \frac{p_{i}-t^1_{i}}{2},\bar{t}^1_{i}\right\} ,0\right\} . \end{aligned}$$

Clearly, the allocation \(T_i\) cannot be utilized at all by agent i if \(t_{i}^{1}\ge p_i\). The saving obtained by the next interval can be calculated in the same manner considering that the new processing time of job i is \(p_i-\upsilon _{i}(T^1_i)\) on i’s private machine. Thus the saving due to the kth subinterval \(T_{i}^{k}\) to agent i is obtained recursively by

$$\begin{aligned} \upsilon _{i}(T_{i}^{k})=\max \left\{ \min \left\{ \frac{p_{i}-\sum ^{k-1}_{l=1}\upsilon _{i}\left( T_{i}^{l}\right) -t_{i}^{k}}{2},\bar{t}_{i}^{k}\right\} ,0\right\} \end{aligned}$$
(1)

total saving due to the allocation \(T_{i}\) is calculated by summing up the savings obtained by all of its subintervals:

$$\begin{aligned} \upsilon _{i}(T_i)=\sum _{k=1}^{m_{i}}\upsilon _{i}\left( T_{i}^{k}\right) . \end{aligned}$$
(2)

If \(T_{i}=\{[t_i,\bar{t}_{i})\}\) is a single interval, the Eq. (2) simplifies to \(\upsilon _{i}(T_i)=\max \left\{ \min \left\{ \left( p_{i}-t_{i}\right) /2,\bar{t}_{i}\right\} ,0\right\} .\) The total saving of a feasible allocation T is the sum of savings of all agents, that is \(\upsilon (T)=\sum _{i\in N}\upsilon _{i}(T_i).\)

Fig. 1
figure 1

Valuation in subcontracting

3.1 Characterization of efficient (centralized) allocations

The objective of the centralized problem is to find efficient allocations on the subcontractor machine for N. An efficient allocation \({\mathcal {T}}\) is a feasible allocation that maximizes the total saving, that is

$$\begin{aligned} {\mathcal {T}}\in \arg \max _{T\in {\mathfrak {T}}}\upsilon (T). \end{aligned}$$
(3)

Let \({\mathcal {T}}=\{{\mathcal {T}}_{i}|i\in N\}\) be an efficient allocation. We have the following two simple observations that hold for any efficient allocation.

Observation 1

For \(i\in N\), job i does not finish on the subcontractor’s machine later than on agent’s i private machine.

Observation 2

The subcontractor’s machine is never idle when some agent’s private machine is busy.

We now prove that all efficient allocations are non-preemptive.

Lemma 1

No efficient allocation on subcontractor’s machine is preemptive.

Proof

By contradiction. Let \({\mathcal {T}}\) be an efficient and preemptive allocation and let \(n'\le n\) be the number of agents with allocations on the subcontractor’s machine. We show that then there exists another feasible allocation with higher total saving. Suppose that \(m_i>1\) for some \(i\in N\). Without loss of generality we take the largest such i. Let \({\mathcal {T}}_{j}^{m_{j}}=[{\mathfrak {t}}_{j}^{m_j}, {\mathfrak {t}}_{j}^{m_j}+\bar{{\mathfrak {t}}}_{j}^{m_j})\) be the allocation immediately preceding \({\mathcal {T}}_{i}^{m_{i}} \). We have \(i\ne j\), and \({\mathfrak {t}}_{j}^{m_j}+\bar{{\mathfrak {t}}}_{j}^{m_j} ={\mathfrak {t}}_{i}^{m_i}\) by Observation 2. Consider the following modification: [Step 1] delay \({\mathcal {T}}_{i}^{m_{i}-1}\) by \({\mathfrak {t}}_{i}^{m_i}-({\mathfrak {t}}_{i}^{m_i-1}+ \bar{{\mathfrak {t}}}_{i}^{m_i-1} )\); speed up all the allocations between \({\mathcal {T}}_{i}^{m_{i}-1}\) and \({\mathcal {T}}_{i}^{m_{i}}\) by \(\bar{{\mathfrak {t}}}_{i}^{m_{i}-1}.\) Thus job i would be preempted one less time. By Observation 1 this modification does not change the completion time of any job. Therefore, total saving remains unchanged. [Step 2] Increase the duration of the last allocation of j by \(\bar{{\mathfrak {t}}} _{i}^{m_{i}-1}/2, \) so that by Observation 1 the private machine of agent j finishes earlier by \(\bar{{\mathfrak {t}}} _{i}^{m_{i}-1}/2\). For \(k=i, \ldots ,n'\), i.e., jobs including and after i, start the last allocation of k by \(\bar{{\mathfrak {t}}} _{i}^{m_{i}-1}/2^{k-i+1}\) later and finish it \(\min \left\{ \bar{{\mathfrak {t}}} _{i}^{m_{i}-1}/2^{k-i+2}, \bar{{\mathfrak {t}}}_{k}\right\} \) later on the subcontractor’s machine (observe that if \(\bar{{\mathfrak {t}}} _{i}^{m_{i}-1}/2^{k-i+2} \ge \bar{{\mathfrak {t}}}_{k}\) then k will no longer be executed on the subcontractor’s machine) and \(\min \left\{ \bar{{\mathfrak {t}}} _{i}^{m_{i}-1}/2^{k-i+2}, \bar{{\mathfrak {t}}}_{k}\right\} \) later on agent k private machine.

The resulting allocation is feasible. Furthermore, jobs in \(N\setminus \{j,i, \ldots ,n'\}\) complete as before Step 2, and for the jobs in \( \{j,i, \ldots ,n'\}\) the total saving increases by

$$\begin{aligned}&\frac{\bar{{\mathfrak {t}}}_{i}^{m_i-1}}{2}- \frac{\bar{{\mathfrak {t}}}_{i}^{m_i-1}}{4} - \cdots -\min \left\{ \frac{\bar{{\mathfrak {t}}}_{i}^{m_i-1}}{2^{n'-i+2}},\mathfrak { \bar{t}}_{n'}\right\} \\&\quad \ge \frac{\bar{{\mathfrak {t}}}_{i}^{m_i-1}}{2}-\frac{ \bar{{\mathfrak {t}}}_{i}^{m_i-1}}{4}- \cdots - \frac{\bar{{\mathfrak {t}}}_{i}^{m_i-1}}{ 2^{n'-i+2}} > 0. \end{aligned}$$

Hence, the alternative allocation has a higher total saving which contradicts the efficiency of \({\mathcal {T}}\). \(\square \)

The lemma excludes allocations with preemptions on subcontractor’s machine from the set of efficient allocations. This result is key for our coordinating pricing scheme in Sect. 4 since the efficient allocations with preemptions on subcontractor’s machine could make the existence of coordinating pricing scheme questionable or possibly more difficult to prove.

By Lemma 1, \(m_i=1\) for \(i\in N\) in any efficient allocation \({\mathcal {T}}\) that is \({\mathcal {T}}_{i}=[{\mathfrak {t}}_{i},{\mathfrak {t}}_{i}+ \bar{{\mathfrak {t}}}_{i})\) for \(i\in N\). Vairaktarakis and Aydinliyim (2007) observe that, for any efficient allocation \({\mathcal {T}}\) with \(m_i=1\), \(i \in N\), each job finishes simultaneously on its own private and subcontractor’s machines, that is

$$\begin{aligned} p_{i}-\bar{{\mathfrak {t}}}_{i}={\mathfrak {t}}_{i}+ \bar{{\mathfrak {t}}}_{i}\,\hbox {for}\,i\in N. \end{aligned}$$
(4)

They also show that for \(m_i=1\), \(i\in N\), the agents’ efficient allocations \({\mathcal {T}}_i\) are ordered in non-decreasing order of \(p_i\). Thus, we assume hereafter in this section and in Sect. 4 that N is arranged in the non-decreasing order of processing times. In this manner, job i would be sequenced in ith position on subcontractor’s machine. Finally, by Observation 2, there is no idle time on the subcontractor machine in efficient allocations, thus we have

$$\begin{aligned} {\mathfrak {t}}_{1}=0\,\hbox {and}\,{\mathfrak {t}}_{i}={\mathfrak {t}} _{i-1}+\bar{{\mathfrak {t}}}_{i-1}\,\hbox {for}\,i>1. \end{aligned}$$
(5)

The unique solution of the recursive equations (4) and (5) is given in the following theorem.

Theorem 1

(Efficient allocation) (Vairaktarakis and Aydinliyim 2007) For efficient allocations with \(m_i=1\) for \(i\in N\), we have

$$\begin{aligned} \bar{{\mathfrak {t}}}_{i}=\frac{p_{i}}{2}-\sum _{k=1}^{i-1} \frac{\mathfrak { \bar{t}}_{k}}{2}=\frac{p_{i}}{2}-\sum _{k=1}^{i-1} \frac{p_{k}}{2^{i+1-k}}. \end{aligned}$$
(6)

By this theorem

$$\begin{aligned} \upsilon _{i}( {\mathcal {T}})=\upsilon _{i}({\mathcal {T}}_i)=\bar{{\mathfrak {t}}}_{i} \end{aligned}$$
(7)

and thus, \(\upsilon ({\mathcal {T}})=\sum _{i\in N}\bar{{\mathfrak {t}}}_{i}.\) Equations (6) and (5) define vectors of efficient durations \(\bar{{\mathfrak {t}}}=( \bar{{\mathfrak {t}}}_{1}, \ldots ,\bar{{\mathfrak {t}}}_{n})\) and start times \({\mathfrak {t}}=( {\mathfrak {t}}_{1}, \ldots ,{\mathfrak {t}}_{n})\) on subcontractor’s machine. Finally, we let \({\mathfrak {t}}_{n+1}={\mathfrak {t}}_{n}+\bar{{\mathfrak {t}}}_{n}\) denote the completion time of the efficient allocations, i.e., the makespan of efficient allocations.

Though multiple efficient allocations exist as long as there are jobs with equal processing times, in each one of them the jobs in the same position on subcontractor’s machine start at the same time and have the same efficient durations. This observation is key to the coordinating pricing scheme developed in the next section.

4 Strongly coordinating pricing schemes

In contrast to a centralized system where allocations are chosen for the agents so as to maximize the total saving, in a decentralized system the decisions are made by the agents in a distributed fashion. Though the agents are self-interested they need, by definition of coordinating mechanism, to collectively converge to an efficient allocation. The convergence depends on a mechanism used in the collective decision making. In this section we design such a mechanism based on a pricing scheme. A pricing scheme is a function q, defined on \(t\ge 0\), which determines a price \(q(t)\ge 0\) for acquiring the time t on the subcontractor’s machine by any agent. The mechanism based on a pricing scheme q works as follows. The subcontractor announces its pricing scheme, and subsequently agent i buys \(T_i\) in a first-come-first-serve manner. The agent makes its decision so as to maximize its utility, which for a given q, and assuming quasilinear utilities, equals

$$\begin{aligned} u_{i}^{q}(T_{i})=\upsilon _{i}(T_{i})-\pi ^{q}(T_{i}), \end{aligned}$$
(8)

where

$$\begin{aligned} \pi ^{q}(T_{i})=\int _{t\in T_{i}}q(t)\mathrm{{d}}t \end{aligned}$$
(9)

is the agent i’s payment for \(T_i\) made to the subcontractor. We require q to be a locally integrable function so that (9) always exists.

Though each agent maximizes its utility with respect to q, the choice of q must ensure coordination in the decentralized system. That is q must guarantee that the agents choose their subcontracting intervals in the exact same manner as in some efficient allocation \({\mathcal {T}}\). We call such pricing schemes coordinating. Let \({\mathcal {E}}\) be the set of all efficient allocations. We formally define.

Definition 1

(Coordinating pricing scheme) The pricing scheme q is coordinating if for any \({\mathcal {T}}=({\mathcal {T}}_1, \ldots ,{\mathcal {T}}_n)\), \({\mathcal {T}}\in {\mathcal {E}}\), and any \(T=(T_1, \ldots ,T_n)\), \(T\in {\mathfrak {T}}\setminus {\mathcal {E}}\),

$$\begin{aligned} \pi ^{q}({\mathcal {T}}_{i})-\pi ^{q}(T_{i})\le \upsilon _{i}({\mathcal {T}} _{i})-\upsilon _{i}(T_{i}) \end{aligned}$$
(10)

for each \(i\in N.\) The pricing scheme q is strongly coordinating if (10) holds strictly for each \(i\in N.\)

A coordinating pricing scheme results in the situation where no agent would be worse off by choosing an efficient allocation. However, the implementation of a coordinating pricing scheme may not necessarily result in the efficiency of the system. This is due to the possibility that an agent chooses an interval which is not a part of any efficient allocation. Such a choice could hinder forthcoming agents to select their efficient allocations. Therefore, the strong coordination requires all agents to exclusively choose efficient allocations.

A natural class of pricing schemes to consider for scheduling consists of those with non-increasing q where agents have to pay a higher price for earlier intervals. When the choice of agent i consists of single interval only, i.e., \(T_i=[t_{i},t_{i}+\bar{t}_{i})\), we let \(\pi ^{q}(T_{i})=\pi ^{q}(t_{i},t_{i}+\bar{t}_{i})\). We now show that the class of non-increasing pricing schemes contain coordinating pricing schemes.

Theorem 2

(Sufficient conditions) A non-increasing pricing scheme q is coordinating if \(q(0)<1\) and the following two conditions are met:

  1. C1.

    For any \(i=2, \ldots , n\) and every \(\epsilon \), \(0<\epsilon \le \bar{{\mathfrak {t}}}_{i-1}/2\):

    $$\begin{aligned} \pi ^{q}( {\mathfrak {t}}_{i}-2\epsilon ,{\mathfrak {t}}_{i}) -\pi ^{q}( {\mathfrak {t}}_{i+1}-\epsilon ,{\mathfrak {t}}_{i+1}) \ge \epsilon ; \end{aligned}$$
    (11)
  2. C2.

    For any \(i=1, \ldots ,n-1\) and every \(\epsilon \), \(0<\epsilon \le \bar{{\mathfrak {t}}}_{i}/2\), and for \(i=n\) and every \(\epsilon \), \(0<\epsilon \le \bar{{\mathfrak {t}}}_{n}\):

    $$\begin{aligned} \pi ^{q}( {\mathfrak {t}}_{i},{\mathfrak {t}}_{i}+2\epsilon ) -\pi ^{q}( {\mathfrak {t}}_{i+1},{\mathfrak {t}}_{i+1}+\epsilon ) \le \epsilon . \end{aligned}$$
    (12)

Proof

All \({\mathcal {T}}\in {\mathcal {E}}\) define the same start times \({\mathfrak {t}}=( {\mathfrak {t}}_{1}, \ldots ,{\mathfrak {t}}_{n})\) and durations \(\bar{{\mathfrak {t}}}=( \bar{{\mathfrak {t}}}_{1}, \ldots ,\bar{{\mathfrak {t}}}_{n})\) as shown in the previous section.

The individual rationality requires that for \(0\le t<{\mathfrak {t}}_{n+1}\), q(t) must be less than 1, otherwise jobs would be either better off by not selecting the time with subcontracting price exceeding one or indifferent if the price equals one. Since q is non-increasing, the individual rationality holds if \(q(0)<1.\)

For q to be a coordinating pricing scheme, it must be that no agent can deviate from an efficient allocation and improve its utility. The first-come-first-booked order breaks ties between jobs with equal processing times, if any, and picks a unique efficient allocation \({\mathcal {T}}\) from \({\mathcal {E}}\). In \({\mathcal {T}}\) agent i has the utility \(\upsilon _{i}({\mathcal {T}}_{i}) \ -q( {\mathcal {T}}_{i}).\) The fact that \({\mathfrak {t}}_{i}+2\bar{{\mathfrak {t}}}_{i}=p_{i}\) and q is non-increasing, implies that agent i cannot choose another interval to increase its valuation and, at the same time, reduce its payment. In order to improve its utility, the agent i may be able to choose another interval to: (a) increase its valuation as well as payment such that the added valuation is greater than the additional payment, or (b) decrease its valuation as well as payment such that the saving in payment is greater than the reduction in valuation. We enforce conditions on q such that neither (a) nor (b) could possibly happen for any job.

Fig. 2
figure 2

Non-increasing pricing schemes

(a) Suppose that the agent i chooses \(T_{i }\) in a way that \(\upsilon _{i }(T_{i })-\upsilon _{i }({\mathcal {T}}_{i })=\epsilon \), for some \(\epsilon >0\). Note that this is not an option for \(i=1\). As q is non-increasing, \(T_{i }\) has the cheapest payment if it starts as late as possible. Therefore, \( T_{i }=[ {\mathfrak {t}}_{i }-2\epsilon ,{\mathfrak {t}}_{i+1 }-\epsilon ) \) is the cheapest alternative interval for agent i which results in \(\epsilon \) improvement in its valuation. Note that i cannot have negative start time, thus \(\epsilon \le {\mathfrak {t}}_i/2\). From Definition 1 it follows that for the pricing scheme q to be coordinating, it must hold for any \(i=2, \ldots , n\) and for every \(0<\epsilon \le {\mathfrak {t}}_{i }/2\) that

$$\begin{aligned} \pi ^q\left( {\mathfrak {t}}_{i }-2\epsilon ,{\mathfrak {t}}_{i+1 }-\epsilon \right) -\pi ^q\left( {\mathfrak {t}}_{i },{\mathfrak {t}}_{i+1 }\right) \ge \epsilon . \end{aligned}$$

By the definition of \(\pi ^q\) in (9), the last inequality can be rewritten as (11) (see Fig. 2). We use induction and show that the latter would be the case if for any \(i=2, \ldots , n\), (11) holds for every \(0<\epsilon \le \bar{{\mathfrak {t}}}_{i-1}/2\), i.e., the condition stated in C1. This holds trivially for \(i=2\) as \({\mathfrak {t}}_2=\bar{{\mathfrak {t}}}_1\). Fix \(i=3, \ldots ,n\) and suppose that for j, \(1\le j< i\), (11) holds for every \(\epsilon \) such that

$$\begin{aligned} 0<\epsilon \le \sum _{k=1}^{j}\bar{{\mathfrak {t}}}_{i-k}/2. \end{aligned}$$

We show that (11) holds as well for every \(\epsilon \) such that,

$$\begin{aligned} 0<\epsilon \le \sum _{k=1}^{j+1}\bar{{\mathfrak {t}}}_{i-k}/2. \end{aligned}$$

Observe that this would be the case if for every \(\epsilon ^\prime \) such that \(0< \epsilon ^\prime \le \bar{{\mathfrak {t}}}_{i-j-1}/2\) we have,

$$\begin{aligned}&\pi ^{q}\left( {\mathfrak {t}}_{i-j}-2\epsilon ^\prime ,{\mathfrak {t}}_{i-j}\right) \nonumber \\&\quad -\pi ^{q} \left( {\mathfrak {t}}_{i+1 }-\sum _{k=1}^{j}\bar{{\mathfrak {t}}}_{i-k}/2 -\epsilon ^\prime , {\mathfrak {t}}_{i+1 }- \sum _{k=1}^{j}\bar{{\mathfrak {t}}}_{i-k}/2\right) \ge \epsilon ^\prime . \end{aligned}$$
(13)

As q is non-increasing, we have

$$\begin{aligned}&\pi ^{q} \left( {\mathfrak {t}}_{i+1 }-\sum _{k=1}^{j}\bar{{\mathfrak {t}}}_{i-k}/2 -\epsilon ^\prime , {\mathfrak {t}}_{i+1 }- \sum _{k=1}^{j}\bar{{\mathfrak {t}}}_{i-k}/2\right) \\&\quad \le \pi ^{q} \left( {\mathfrak {t}}_{i-j+1}-\epsilon ^\prime ,{\mathfrak {t}}_{i-j+1}\right) \end{aligned}$$

Thus, (13) would be the case if for every \(\epsilon ^\prime \) such that \(0< \epsilon ^\prime \le \bar{{\mathfrak {t}}}_{i-j-1}/2\) we have,

$$\begin{aligned}&\pi ^{q}\left( {\mathfrak {t}}_{i-j}-2\epsilon ^\prime ,{\mathfrak {t}}_{i-j}\right) - \pi ^{q} \left( {\mathfrak {t}}_{i-j+1}-\epsilon ^\prime ,{\mathfrak {t}}_{i-j+1}\right) \ge \epsilon ^\prime . \end{aligned}$$

Condition C1 for the job \(i-j\) ensures that the latter holds. Therefore, if for any \(i=2, \ldots ,n\), (11) holds (strictly) for every \(0< \epsilon \le \bar{{\mathfrak {t}}}_{i-1 }/2\), then (11) holds (strictly) for every \(0< \epsilon \le {\mathfrak {t}}_{i }/2\).

(b) It is straightforward to see that the interval which reduces the valuation of the agent i by \(\epsilon >0\), while having the largest decrease in its payment, is \(T_{i }=\left( {\mathfrak {t}}_{i }+2\epsilon ,{\mathfrak {t}}_{i+1 }+\epsilon \right) \), as long as \(\epsilon \le \bar{{\mathfrak {t}}}_{i }\). Therefore, for q to be coordinating it must hold for every \(i=1, \ldots ,n\) and for every \(\epsilon \) such that \(0<\epsilon \le \bar{{\mathfrak {t}}}_{i }\) that,

$$\begin{aligned} \pi ^q\left( {\mathfrak {t}}_{i },{\mathfrak {t}}_{i+1 }\right) -\pi ^q\left( {\mathfrak {t}}_{i }+2\epsilon ,{\mathfrak {t}}_{i+1 }+\epsilon \right) \le \epsilon . \end{aligned}$$

By the definition of \(\pi ^q\) in (9), the last inequality can be rewritten as (12). We use induction to show that for \(i=1, \ldots ,n-1\) the latter would be the case if (11) holds for every \(0<\epsilon \le \bar{{\mathfrak {t}}}_{i }/2\), i.e., the condition stated in C2. Fix \(i=1, \ldots , n-1\) and suppose that for j, \(1\le j< i\), (12) holds for every \(\epsilon \) such that,

$$\begin{aligned} 0<\epsilon \le \min \left\{ \sum _{k=1}^{j}\bar{{\mathfrak {t}}}_{i+k-1}/2, \bar{{\mathfrak {t}}}_{i }\right\} . \end{aligned}$$

We show that (12) holds as well for every \(\epsilon \) such that,

$$\begin{aligned} 0<\epsilon \le \min \left\{ \sum _{k=1}^{j+1}\bar{{\mathfrak {t}}}_{i+k-1}/2, \bar{{\mathfrak {t}}}_{i }\right\} . \end{aligned}$$

In case \(\sum _{k=1}^{j}\bar{{\mathfrak {t}}}_{i+k-1}/2<\bar{{\mathfrak {t}}}_{i }\), observe that the latter would hold if for every \(0< \epsilon ^\prime \le \min \left\{ \bar{{\mathfrak {t}}}_{i+j}/2,\bar{{\mathfrak {t}}}_{i }\right\} \) we have,

$$\begin{aligned}&\pi ^{q}\left( {\mathfrak {t}}_{i+j} ,{\mathfrak {t}}_{i+j}+2 \epsilon ^\prime \right) \nonumber \\&\quad -\pi ^{q} \left( {\mathfrak {t}}_{i+1 }+\sum _{k=1}^{j}\bar{{\mathfrak {t}}}_{i+k-1}/2, {\mathfrak {t}}_{i+1 }+ \sum _{k=1}^{j}\bar{{\mathfrak {t}}}_{i+k-1}/2+\epsilon ^\prime \right) \nonumber \\&\quad \le \epsilon ^\prime . \end{aligned}$$
(14)

As q is non-increasing, we have

$$\begin{aligned}&\pi ^{q} \left( {\mathfrak {t}}_{i+1 }+\sum _{k=1}^{j}\bar{{\mathfrak {t}}}_{i+k-1}/2 ,{\mathfrak {t}}_{i+1 }+ \sum _{k=1}^{j}\bar{{\mathfrak {t}}}_{i+k-1}/2+\epsilon ^\prime \right) \\&\quad \ge \pi ^{q} \left( {\mathfrak {t}}_{i+j+1} ,{\mathfrak {t}}_{i+j+1}+\epsilon ^\prime \right) \end{aligned}$$

Thus, (14) would be the case if for every \(\epsilon ^\prime \) such that \(0< \epsilon ^\prime \le \min \left\{ \bar{{\mathfrak {t}}}_{i+j}/2,\bar{{\mathfrak {t}}}_{i }\right\} \) we have

$$\begin{aligned}&\pi ^{q}\left( {\mathfrak {t}}_{i+j} ,{\mathfrak {t}}_{i+j}+2\epsilon ^\prime \right) - \pi ^{q} \left( {\mathfrak {t}}_{i+j+1} ,{\mathfrak {t}}_{i+j+1}+\epsilon ^\prime \right) \le \epsilon ^\prime . \end{aligned}$$

Condition C2 for the job \(i+j\) ensures that the latter holds. Therefore, if for \(i=1, \ldots ,n-1\), (12) holds (strictly) for every \(0< \epsilon \le \bar{{\mathfrak {t}}}_{i }/2\), then (12) holds (strictly) for every \(0< \epsilon \le \bar{{\mathfrak {t}}}_{i }\). \(\square \)

The conditions in Theorem 2 are designed to make the deviations from \({\mathfrak {t}}=( {\mathfrak {t}}_{1}, \ldots ,{\mathfrak {t}}_{n})\) undesirable for all agents in the sense that the agent’s utilities would be reduced if they choose any intervals other than those defined by \({\mathfrak {t}}\). Clearly with quasilinear utilities any agent can increase its utility either by choosing an interval that either increases its valuation (saving due to reduction in completion time) or reduces its payment (see Fig. 2). With a non-increasing pricing scheme attaining both of these at the same time is impossible. Therefore, a deviation which increases (decreases) an agent’s valuation, simultaneously increases (decreases) its payment.

Only strongly coordinating pricing schemes can guarantee efficient schedules in the decentralized system. In order to introduce a family of strongly coordinating pricing schemes, we need the following technical lemma which states that the efficient duration of any job on subcontractor’s machine is not longer than twice the efficient duration of the job proceeding it.

Lemma 2

For \(i=1, \ldots ,n-1\), \(\bar{{\mathfrak {t}}}_{i}\le 2\bar{{\mathfrak {t}}}_{i+1}.\)

Proof

From (6) we get

$$\begin{aligned} \bar{{\mathfrak {t}}}_{i}-2\bar{{\mathfrak {t}}}_{i+1}&=\frac{p_{i}}{2} -\sum _{k=1}^{i-1}\frac{\bar{{\mathfrak {t}}}_{k}}{2}-p_{i+1}\\&\quad + \sum _{k=1}^{i-1}\bar{{\mathfrak {t}}}_{k}+\left( \frac{p_{i}}{2} -\sum _{k=1}^{i-1}\frac{\bar{{\mathfrak {t}}}_{k}}{2}\right) \\&=p_{i}-p_{i+1}. \end{aligned}$$

The agents in N are sequence according to non-decreasing order of processing times, thus we have \(p_{i}\le p_{i+1}\) which obtains \(\bar{{\mathfrak {t}}}_{i}\le 2\bar{{\mathfrak {t}}}_{i+1}\). \(\square \)

Note that in Lemma 2, the equality holds for jobs with equal processing times. More precisely, \(p_{i}=p_{i+1}\) if and only if \(\bar{{\mathfrak {t}}}_{i}=2 \bar{{\mathfrak {t}}}_{i+1}.\)

We are now ready to give a family of non-increasing pricing schemes that are strongly coordinating, that is, any deviation from efficient allocation by any agent results in utility loss for that agent.

Theorem 3

Consider the coefficient set \({\varvec{\kappa }}=\{\kappa _{1}, \ldots ,\kappa _{n}\}\) such that for \(i=1, \ldots ,n-1\), \(0<\kappa _{i}<\kappa _{i+1}/2\) and \(0<\kappa _{n}\le 2^{n-1}\delta /3\) where \(0<\delta \le 3/2^{n+1}\). The following pricing scheme is strongly coordinating:

$$\begin{aligned} q_{O}(t)=\left\{ \begin{array}{ll} 1-2^{i-1}\delta &{}\\ +\kappa _{i}\left[ 1-2(t-{\mathfrak {t}}_{i})/\bar{{\mathfrak {t}}}_{i}\right] &{} \text {if }{\mathfrak {t}}_{i}\le t<{\mathfrak {t}}_{i}+ \bar{{\mathfrak {t}}}_{i}, i\in N\\ 1-2^{n-1}\delta -\kappa _{n} &{} \text {if }t\ge {\mathfrak {t}}_{n}+\bar{{\mathfrak {t}}}_{n} \end{array} \right. \end{aligned}$$
(15)

Proof

The assumptions on \(\kappa \) ensure that: (a) \(q_{O}\) is non-increasing, (b) \(q_{O}(0)<1,\) and (c) \(q_{O}(t)\ge 0\) for \(t\ge 0\).

To verify (a), it suffices to consider the points of (possible) discontinuity, i.e., \(t={\mathfrak {t}}_{i+1}\) for \(i=1, \ldots ,n-1.\) There, it must hold that \(1-2^{i-1}\delta -\kappa _{i}\ge 1-2^{i}\delta +\kappa _{i+1}\) or

$$\begin{aligned} \kappa _{i}+\kappa _{i+1}\le 2^{i-1}\delta . \end{aligned}$$
(16)

By extending the assumption \(\kappa _{i}<\kappa _{i+1}/2\) we get

$$\begin{aligned} \kappa _{i}<\kappa _{n}/2^{n-i} \end{aligned}$$
(17)

for \(i=1, \ldots , n-1\). Thus, \(\kappa _{i}+\kappa _{i+1}<3\kappa _{n}/2^{n-i}\). It follows that for (16) to hold, we need

$$\begin{aligned} \kappa _{n}\le 2^{n-1}\delta /3. \end{aligned}$$
(18)

In order for (b) to hold we must have \(1-\delta +\kappa _{1}< 1\) or \(\kappa _{1}< \delta \). Note that (17) and (18) yield \( \kappa _i<2^{i-1}\delta /3\) for \(i=1, \ldots , n-1\) which implies that \(\kappa _1<\delta /3\). Thus (b) holds.

Given that \(q_O\) is non-increasing, to verify (c) we must check the non-negativity of \(q_O(t)\) at \(t\ge {\mathfrak {t}}_{n}+\bar{{\mathfrak {t}}}_{n}\). Note that from (17) we get

$$\begin{aligned} 1-2^{n-1}\delta -\kappa _{n}\ge 1-2^{n-1}\delta -2^{n-1}\delta /3. \end{aligned}$$

Hence, for (c) to hold we need \(\delta \le 3/2^{n+1}\).

We now check the conditions in Theorem 2. Observe that \(q_O\) is piecewise linear and has a constant slope in between any consecutive points of possible discontinuity.

With regard to condition C1, note that for \(0<\epsilon \le \bar{{\mathfrak {t}}}_{i-1}/2\) both \(\pi ^{q_{O}}\left( {\mathfrak {t}}_{i}-2\epsilon ,{\mathfrak {t}}_{i}\right) \) and \(\pi ^{q_{O}}\left( {\mathfrak {t}}_{i+1}-\epsilon ,{\mathfrak {t}}_{i+1}\right) \) can be obtained by calculating the areas of the corresponding trapezoids. Let \(t ^-=\lim _{\epsilon \rightarrow 0^+}(t-\epsilon )\). For any \(i=2, \ldots ,n\) we have

$$\begin{aligned}&\pi ^{q_{O}} \left( {\mathfrak {t}}_{i}-2\epsilon ,{\mathfrak {t}}_{i} \right) -\pi ^{q_{O}} \left( {\mathfrak {t}}_{i+1}-\epsilon ,{\mathfrak {t}}_{i+1} \right) \\&\quad =\frac{1}{2}2\epsilon \left[ q_O\left( {\mathfrak {t}}_{i}-2\epsilon \right) +q_O\left( {\mathfrak {t}}_{i}^-\right) \right] \\&\quad \quad -\frac{1}{2}\epsilon \left[ q_O\left( {\mathfrak {t}}_{i+1}-\epsilon \right) +q_O \left( {\mathfrak {t}}_{i+1}^-\right) \right] \\&\quad =\frac{1}{2}2\epsilon \left[ 1-2^{i-2}\delta -\kappa _{i-1} \left( 1-\frac{4\epsilon }{\bar{{\mathfrak {t}}}_{i-1}} \right) +1-2^{i-2}\delta -\kappa _{i-1} \right] \\&\quad \quad -\frac{1}{2}\epsilon \left[ 1-2^{i-1}\delta -\kappa _{i} \left( 1-\frac{2\epsilon }{\bar{{\mathfrak {t}}}_{i}} \right) +1-2^{i-1}\delta -\kappa _{i} \right] \\&\quad =\epsilon \left[ 1- 2\kappa _{i-1} \left( 1-\frac{2\epsilon }{\bar{{\mathfrak {t}}}_{i-1}} \right) +\kappa _{i} \left( 1-\frac{\epsilon }{\bar{{\mathfrak {t}}}_{i}}\right) \right] . \end{aligned}$$

From Lemma 2 we know that \(\bar{{\mathfrak {t}}}_{i-1}\le 2\mathfrak { \bar{t}}_{i}\) and consequently \(1-2\epsilon /\bar{{\mathfrak {t}}}_{i-1}\le 1- \epsilon /\bar{{\mathfrak {t}}}_{i}.\) By assumption we have \(2\kappa _{i-1}<\kappa _{i}\) which leads to the observation that for every \(0<\epsilon < \bar{{\mathfrak {t}}}_{i-1}/2\),

$$\begin{aligned} \pi ^{q_{O}} \left( {\mathfrak {t}}_{i}-2\epsilon ,{\mathfrak {t}}_{i} \right) -\pi ^{q_{O}} \left( {\mathfrak {t}}_{i+1}-\epsilon ,{\mathfrak {t}}_{i+1} \right) >\epsilon \end{aligned}$$
(19)

with regard to \(\epsilon = \bar{{\mathfrak {t}}}_{i-1}/2\) we consider two cases. If \(\bar{{\mathfrak {t}}}_{i-1}/2\ne \bar{{\mathfrak {t}}}_{i}\) then at \(\epsilon = \bar{{\mathfrak {t}}}_{i-1}/2\), (19) holds strictly as well which implies that (19) holds strictly for every \(0<\epsilon \le {\mathfrak {t}}_{i}\). Otherwise, if \(\bar{{\mathfrak {t}}}_{i-1}/2=\bar{{\mathfrak {t}}}_{i},\) then at \(\epsilon = \bar{{\mathfrak {t}}}_{i-1}/2\), (19) holds as equality. However, this requires that \(p_{i-1}=p_{i}\) which corresponds to an alternative efficient allocation wherein job i is allocated with the interval allocated to job \(i-1\). Hence, the choice of any earlier intervals for a given agent i which is not part of an efficient allocation results in loss of utility for that agent. Also, for jobs with equal processing times the choice of an earlier alternative efficient intervals does not alter the utility to the corresponding agents.

With regard to condition C2, note that for \(0<\epsilon \le \bar{{\mathfrak {t}}}_{i}/2\) both \(\pi ^{q_{O}}\left( {\mathfrak {t}}_{i} ,{\mathfrak {t}}_{i}+2\epsilon \right) \) and \(\pi ^{q_{O}}\left( {\mathfrak {t}}_{i+1} ,{\mathfrak {t}}_{i+1}+\epsilon \right) \) can also be obtained by calculating the areas of the corresponding trapezoids. for any \(i=1, \ldots ,n-1\) we have

$$\begin{aligned}&\pi ^{q_{O}} \left( {\mathfrak {t}}_{i},{\mathfrak {t}}_{i}+2\epsilon \right) -\pi ^{q_{O}} \left( {\mathfrak {t}}_{i+1},{\mathfrak {t}}_{i+1}+\epsilon \right) \\&\quad =\frac{1}{2}2\epsilon \left[ q_O\left( {\mathfrak {t}}_{i}\right) +q_O\left( {\mathfrak {t}}_{i}+2\epsilon \right) \right] \\&\quad \quad - \frac{1}{2}\epsilon \left[ q_O\left( {\mathfrak {t}}_{i+1}\right) +q_O\left( {\mathfrak {t}}_{i+1}+\epsilon \right) \right] \\&\quad =\frac{1}{2}2\epsilon \left[ 1-2^{i-1}\delta +\kappa _{i}+1-2^{i-1}\delta +\kappa _{i} \left( 1-\frac{4\epsilon }{\bar{{\mathfrak {t}}}_{i}} \right) \right] \\&\quad \quad -\frac{1}{2}\epsilon \left[ 1-2^{i}\delta +\kappa _{i+1}+1-2^{i}\delta +\kappa _{i+1} \left( 1-\frac{2\epsilon }{\bar{{\mathfrak {t}}}_{i+1}} \right) \right] \\&\quad =\epsilon \left[ 1+2\kappa _{i} \left( 1-\frac{2\epsilon }{\bar{{\mathfrak {t}}} _{i}} \right) -\kappa _{i+1} \left( 1-\frac{\epsilon }{\bar{{\mathfrak {t}}}_{i+1}} \right) \right] . \end{aligned}$$

From Lemma 2 we know that \(\bar{{\mathfrak {t}}}_{i}\le 2\mathfrak { \bar{t}}_{i+1}\) and consequently \(1-2\epsilon /\bar{{\mathfrak {t}}}_{i}\le 1-\epsilon /\bar{{\mathfrak {t}}}_{i+1}.\) By assumption we have \(\kappa _{i}<\kappa _{i+1}/2\). Therefore, for \(0<\epsilon < \bar{{\mathfrak {t}}}_{i-1}/2\) we would have

$$\begin{aligned} \pi ^{q_{O}} \left( {\mathfrak {t}}_{i} ,{\mathfrak {t}}_{i}+2\epsilon \right) -\pi ^{q_{O}} \left( {\mathfrak {t}}_{i+1} ,{\mathfrak {t}}_{i+1}+\epsilon \right) <\epsilon \end{aligned}$$
(20)

If \(\bar{{\mathfrak {t}}}_{i}/2\ne \bar{{\mathfrak {t}}}_{i+1}\) then the latter also holds for \(\epsilon =\bar{{\mathfrak {t}}}_{i}/2\). In case of \(\bar{{\mathfrak {t}}}_{i}/2=\bar{{\mathfrak {t}}}_{i+1},\) (20) would hold as equality for \(\epsilon = \bar{{\mathfrak {t}}}_{i}/2\). However, this requires \(p_{i}=p_{i+1}\) which implies the existence of an alternative efficient allocation. Hence, the choice of any later intervals for a given agent i which is not part of an efficient allocation results in the loss of utility for that agent. Also, for jobs with equal processing times the choice of a later alternative efficient intervals does not alter the utility to the corresponding agents.

Considering the above, we conclude that \(q_O\) is a coordinating pricing scheme where for any \({\mathcal {T}}\in {\mathcal {E}}\) and every \(T\in {\mathfrak {T}}\setminus {\mathcal {E}}\), it holds for all \(i\in N\) that \( \pi ^{q}({\mathcal {T}}_{i})-\pi ^{q}(T_{i})< \upsilon _{i}({\mathcal {T}} _{i})-\upsilon _{i}(T_{i}) \). \(\square \)

To see how the pricing scheme introduced in Theorem 3 can coordinate the subcontractor scheduling problem first note that for all agents with unequal processing times, corresponding efficient allocations are exclusively the best choices of subcontracting intervals. For agents with equal processing time jobs, however, the best choices are multiple. Nevertheless, \(q_{O}\) would result in the situation where the number of best choices for the jobs with equal processing times are exactly the same as the number of those jobs. Therefore, a first-come-first-serve rule would result in strict coordination of individual choices.

4.1 Subcontractor’s revenue with coordinating pricing schemes

Let \(\varPi ^{q}=\sum _{i\in N}\pi ^{q}(T_{i})\) be the total payment from agents to the subcontractor under the pricing schemes q. We call \(\varPi ^{q}\) the subcontractor’s revenue under q. In this section we characterize the range of \(\varPi ^{q}\) with q being a coordinating pricing scheme.

The coordinating pricing schemes introduced in Theorem 3 can extract (almost) all of the total saving \(\upsilon ({\mathcal {T}})\) from the agents by selecting \(\delta \) small enough which is shown in the following theorem.

Theorem 4

\(\varPi ^{q_{O}}=\upsilon ({\mathcal {T}})-\delta \sum _{i\in N}2^{i-1}\bar{{\mathfrak {t}}}_{i}.\)

Proof

For every \(i\in N\) we have,

$$\begin{aligned} \pi ^{q_{O}}\left( {\mathcal {T}}_{i}\right)= & {} \bar{{\mathfrak {t}}}_{i}\left( 1-2^{i-1}\delta +\kappa _{i}+1-2^{i-1}\delta +\kappa _{i}-2\kappa _{i}\right) /2\\= & {} \bar{{\mathfrak {t}}}_{i}\left( 1-2^{i-1}\delta \right) . \end{aligned}$$

Therefore \(\varPi ^{q_{O}}=\sum _{i\in N}\ \bar{{\mathfrak {t}}} _{i}-\delta \sum _{i\in N}2^{i-1}\bar{{\mathfrak {t}}}_{i}\). \(\square \)

Hence, the total payments can be made arbitrary close to the maximum possible which is the total saving \(\upsilon ({\mathcal {T}})\).

We now provide a lower bound for the total subcontractor’s revenue attainable under any coordinating pricing scheme. We show in Corollary 1 that this bound is an upper bound on the subcontractor’s revenue attainable by any coordinating mechanism with private information.

Theorem 5

(Lower bound) For any coordinating pricing scheme q, we have \(\varPi ^{q}\ge \sum _{i\in N}\bar{{\mathfrak {t}}}_{i}\left( 1-1/2^{n-i}\right) .\)

Proof

Let \({\mathcal {T}}\in {\mathcal {E}}\) be an efficient allocation. If q is coordinating, then for all \(i\in N\) there is no \(T_{i}\) which results in higher utility than \({\mathcal {T}}_{i}\). In particular, for any agent \(i=2, \ldots ,n,\) the following deviation from efficient allocation should not be profitable: construct \(T_{i}\) by removing the last \(\epsilon >0\) interval at the end of \({\mathcal {T}}_{i}\) and add instead another interval with duration \( 2\epsilon \) starting at time \({\mathfrak {t}}_{i}-2\epsilon \) (to have feasible allocations it must be that \(\epsilon \le {\mathfrak {t}}_i/2\)). With the new allocation, i finishes \(\epsilon \) units of time earlier, i.e., \(\upsilon _{i}({\mathcal {T}}_{i})-\upsilon _{i}(T_{i})=-\epsilon \). To make this deviation unprofitable, the condition in (10) requires that

$$\begin{aligned} \pi ^{q}\left( {\mathfrak {t}}_i-2\epsilon ,{\mathfrak {t}}_i\right) -\pi ^{q}\left( {\mathfrak {t}}_{i+1}-\epsilon ,{\mathfrak {t}}_{i+1}\right) \ge \epsilon . \end{aligned}$$
(21)

We construct a pricing scheme \(q_L\) which satisfies the above condition for every \(i=2, \ldots ,n\) and every \(0<\epsilon \le {\mathfrak {t}}_i/2\), and has the lowest possible total revenue.

Let \(q_L(t)=0\) for \(t\ge {\mathfrak {t}}_{n}\). Observe that in the latter range \(q_L\) has the lowest possible prices, so under \(q_L\) the agent n pays 0 for its efficient allocation. The condition in (21) for \(i=n\) and any \(0<\epsilon \le {\mathfrak {t}}_n/2\) requires that

$$\begin{aligned} \pi ^{q_L}\left( {\mathfrak {t}}_n-2\epsilon ,{\mathfrak {t}}_n\right) \ge \epsilon . \end{aligned}$$
(22)

To obtain the cheapest pricing scheme we require \(q_L\) to yield \(\pi ^{q_L}\left( {\mathfrak {t}}_n-2\epsilon ,{\mathfrak {t}}_n\right) = \epsilon \) for every \(0<\epsilon \le \bar{{\mathfrak {t}}}_{n-1}/2\). In particular for \(\epsilon =\bar{{\mathfrak {t}}}_{n-1}/2\) we get \(\pi ^{q_L}\left( {\mathfrak {t}}_{n-1}, {\mathfrak {t}}_n\right) = \bar{{\mathfrak {t}}}_{n-1}/2\). This means that under \(q_L\) the agent \(i=n-1\) pays \(\bar{{\mathfrak {t}}}_{n-1}/2\).

Next, the condition (21) for agent \(i=n-1\) and every \(0<\epsilon \le {\mathfrak {t}}_{n-1}/2\) requires that

$$\begin{aligned} \pi ^{q_L}\left( {\mathfrak {t}}_{n-1}-2\epsilon ,{\mathfrak {t}}_{n-1}\right) -\pi ^{q_L}\left( {\mathfrak {t}}_{n}-\epsilon ,{\mathfrak {t}}_{n}\right) \ge \epsilon . \end{aligned}$$
(23)

To obtain the cheapest pricing scheme we can consider \(q_L\) to be such that (23) holds as equality for every \(0<\epsilon \le \bar{{\mathfrak {t}}}_{n-2}/2\). In this case, for \(\epsilon =\bar{{\mathfrak {t}}}_{n-2}/2\) we get

$$\begin{aligned} \pi ^{q_L}\left( {\mathfrak {t}}_{n-2},{\mathfrak {t}}_{n-1}\right) -\pi ^{q_L}\left( {\mathfrak {t}}_{n}-\bar{{\mathfrak {t}}}_{n-2}/2 ,{\mathfrak {t}}_{n}\right) = \bar{{\mathfrak {t}}}_{n-2}/2 . \end{aligned}$$
(24)

By Lemma 2, we know that \(\bar{{\mathfrak {t}}}_{n-2}/2\le \bar{{\mathfrak {t}}}_{n-1}\) so \({\mathfrak {t}}_{n}-\bar{{\mathfrak {t}}}_{n-2}/2\ge {\mathfrak {t}}_{n-1}\). Hence we have \(\pi ^{q_L}\left( {\mathfrak {t}}_{n}-\bar{{\mathfrak {t}}}_{n-2}/2 ,{\mathfrak {t}}_{n}\right) =\bar{{\mathfrak {t}}}_{n-2}/4\) and eventually

$$\begin{aligned} \pi ^{q_L}\left( {\mathfrak {t}}_{n-2},{\mathfrak {t}}_{n-1}\right) = 3\bar{{\mathfrak {t}}}_{n-2}/4 . \end{aligned}$$
(25)

The latter implies that agent \(i=n-2\) under \(q_L\) pays \(\bar{{\mathfrak {t}}}_{n-2}(3/4)\) to the subcontractor.

By induction on i it is easily verifiable that under the pricing scheme that satisfies the condition (21) and has the lowest possible price, every agent \(i\in N\) pays an amount equal to \(\bar{{\mathfrak {t}}}_i(1-1/2^{n-i})\) to the subcontractor. Thus for every coordinating pricing scheme q, it must be the case that \(\varPi ^q\ge \sum _{i\in N}\bar{{\mathfrak {t}}}_{i}\left( 1-1/2^{n-i}\right) \). \(\square \)

We close with the observation that the lower bound in Theorem 5 is attainable by the following pricing scheme

$$\begin{aligned} q_{L}(t)=\left\{ \begin{array}{l@{\quad }l} 1-1/2^{n-i} \qquad &{} \text {if }{\mathfrak {t}}_{i}\le t<{\mathfrak {t}}_{i+1},i\in N; \\ 0 &{} \text {if }t\ge {\mathfrak {t}}_{n}. \end{array} \right. \end{aligned}$$
(26)

Clearly \(q_{L}\) is non-increasing, and coordinating. To see the latter we check the conditions in Theorem 2: C1 holds since we have \(\left( 1-1/2^{n-i+1}\right) 2\epsilon -\left( 1-1/2^{n-i}\right) \epsilon =\epsilon \). Also, we have \(\left( 1-1/2^{n-i}\right) 2\epsilon -\left( 1-1/2^{n-i-1}\right) \epsilon =\epsilon \). Thus C2 holds as \(\left( 0\right) 2\epsilon -\left( 0\right) \epsilon \le \epsilon \). Clearly, \(q_L(0)<1\).

Finally we get \(\varPi ^{q_{L}}\left( {\mathcal {T}}\right) =\sum _{i\in N}\bar{{\mathfrak {t}}}_{i}\left( 1-1/2^{n-i}\right) .\)

5 Private processing times

Section 4 shows how to coordinate a set of self-interested agents through a coordinating pricing scheme under the assumption that the vector of true processing times p is given and known to the subcontractor. In this section, we relax this assumption by allowing true processing times to be private information of agents. Thus reporting an untruthful processing time by an agent can deceive the subcontractor who consequently moves the agent’s job in the sequence of jobs in efficient allocations which can potentially increase the agent’s time saving or reduce his payment.

This section presents a mechanism that guarantees that the agents are always better off by reporting their true processing times, and that they are also better off by participating in the subcontracting—such mechanism is refereed to as the coordinating mechanism for the subcontractor scheduling problem under private information. Finally, the section calculates the amount the subcontractor forfeits to the agents to extract the true processing times from them.

We draw upon mechanism design theory (Nisan 2007; Jackson 2000) and introduce a payment scheme that motivates agents to report true processing times knowing the subcontractor’s intention to maximize the total savings.

A pricing scheme in Sect. 4 determines payments made by agents to the subcontractor for time intervals that they choose to utilize on the subcontractor’s machine. In this section the payments are made for reporting particular processing times by the agents to the subcontractor. Formally, each agent reports a processing time \(r_{i}\) from its individual processing time space \(P_{i}\subset {\mathbb {R}}_+\). We use \(p_i\) to denote the true processing time of agent i. Let \(P=P_{1}\times \cdots \times P_{n}\) be the processing time space of all agents.

Definition 2

A mechanism M is defined by a \((n+1)\)-tuple \((f^M,\pi ^M _{1}, \ldots ,\pi ^M _{n})\) consisting of an allocation function \(f^M:P\rightarrow {\mathfrak {T}}\) , and a payment scheme \(\pi ^M :P\rightarrow {\mathbb {R}}^{n}\).

Given a vector of reported processing times r and the sequence in which the agents report them (to break ties in the allocation), the payment scheme of a mechanism determines the monetary amount \(\pi ^M_i(r)\) that \(i\in N\) pays in return for receiving the allocation prescribed for i by \(f^M\).

With quasilinear utilities, a mechanism M would result in the utility

$$\begin{aligned} u^M_{i}\left( f^M(r)\right) =\upsilon _{i}\left( f^M(r)\right) -\pi ^M_{i}(r) \end{aligned}$$
(27)

for \(i\in N\).

The subcontractor is seeking to allocate the subcontracting intervals efficiently, thus we focus on mechanisms whose allocation functions yield efficient allocations, i.e., \(f^M\equiv {\mathcal {T}}\). We call such mechanisms efficient.

We concentrate on incentive compatible mechanism since they have the potential to motivate the agents to report their true processing times.

Definition 3

A mechanism M is incentive compatible if for every reported processing time vector \(r=(r_1, \ldots ,r_n)\) and for every agent \(i\in N\)

$$\begin{aligned} u^M_{i}\left( f^M\left( p_i,r^{-i}\right) \right) \ge u^M_{i} \left( f^M(r)\right) , \end{aligned}$$
(28)

where \(r^{-i}\) is the vector r without its ith coordinate.

Although incentive compatibility implies that agents are not better off by lying about their true processing times, it does not generally imply that the agents are better off by reporting their true processing times—there could generally exist untruthful agent reports that result in the same utility as the truthful ones. Therefore, unfortunately, agents may generally choose to be untruthful after all even with the incentive compatible mechanisms. This is generally the case for VCG mechanisms, in particular the pivotal mechanism, which characterize the class of efficient and incentive compatible mechanisms for quasilinear utilities (Green and Laffont 1977). However, we show later in Theorem 6 that for the subcontractor scheduling problem studied in this paper the pivotal mechanism makes the agents always better off by reporting their true processing times.

5.1 Payment scheme

We draw upon the VCG mechanisms to obtain a desirable payment scheme for the subcontractor scheduling problem. The payment scheme for VCG mechanisms is defined as follows

$$\begin{aligned} \pi _{i}^{{\text {VCG}}}(r)=h_{i}\left( r^{-i}\right) -\sum _{j\in N\setminus \{i\}}\upsilon _{j}\left( {\mathcal {T}}(r)\right) , \end{aligned}$$

where \(h_{i}\) is a function independent of agent i’s reported processing time \(r_i\). Among the class of VCG mechanisms, the pivotal mechanism with

$$\begin{aligned} h_{i}\left( r^{-i}\right) =\sum _{j\in N\setminus \{i\} }\upsilon _{j}\left( {\mathcal {T}}\left( r^{-i}\right) \right) \end{aligned}$$
(29)

guarantees that all payments from the agents to the mechanism are non-negative. Here \( {\mathcal {T}}(r^{-i})\) is an efficient allocation for the set of jobs excluding job i and for processing time vector r. Thus, the payment by pivotal mechanism for \(i\in N\) equals

$$\begin{aligned} \pi _{i}^{PM}(r)=\sum _{j\in N\setminus \{i\}}\left[ \bar{{\mathfrak {t}}}_{j}\left( r^{-i}\right) - \bar{{\mathfrak {t}}}_{j}(r)\right] , \end{aligned}$$
(30)

where \(\bar{{\mathfrak {t}}}_{j}(r)\) is the duration of subcontracting time allocated to j by the efficient (optimal) allocation for the reported r and \(\bar{{\mathfrak {t}}}_{j}(r^{-i})\) is the duration of subcontracting time allocated to j by the efficient allocation for the reported \(r^{-i}\) that excludes i.

By (30) the payment \(\pi _{i}^{PM}(r)\) charged by the pivotal mechanism to agent i is the total subcontracting time that could have been allocated to all other agents had not i asked for subcontracting and reported \(r_i\). It follows from the characterization of efficient solutions that the exclusion of an agent i reporting \(r_i\) would only affect the agents that follow i in \({\mathcal {T}}(r)\). Let \(\sigma \) be the permutation of jobs in \({\mathcal {T}}(r)\) and let [i], for \(i\in N\), be the position of i in \({\mathcal {T}}(r)\).

Lemma 3

For all \(i\in N\), we have

$$\begin{aligned} \pi _{i}^{PM}(r)=\bar{{\mathfrak {t}}}_{i}(r)\left( 1-1/2^{n-[i]}\right) . \end{aligned}$$
(31)

Proof

We start by showing that for any \(i,j\in N\), we have \(\bar{{\mathfrak {t}}} _{j}(r^{-i})-\bar{{\mathfrak {t}}}_{j}(r)=0\) if \([j]<[i]\) and \(\bar{{\mathfrak {t}}} _{j}(r^{-i})-\bar{{\mathfrak {t}}}_{j}(r)= \bar{{\mathfrak {t}}}_{i}(r)/2^{[j]-[i]}\) if \([j]>[i].\)

By (6) \(r_{i}\) does not appear in \(\mathfrak { \bar{t}}_{j}(r)\) for \([j]<[i]\). Therefore, \(\bar{{\mathfrak {t}}}_{j}(r^{-i})-\bar{{\mathfrak {t}}}_{j}(r)=0\) for \([j]<[i]\).

If \([j]>[i]\), then the exclusion of i affects the duration of allocated time to jobs j without altering the relative position of other jobs. By (4) and (5), we have

$$\begin{aligned} \bar{{\mathfrak {t}}}_j(r)=\frac{1}{2}\left( r_j-\left[ {\mathfrak {t}}_i(r) +\bar{{\mathfrak {t}}}_i(r)+\sum _{[i]<[k]<[j]} \bar{{\mathfrak {t}}}_k(r)\right] \right) \end{aligned}$$

and

$$\begin{aligned} \bar{{\mathfrak {t}}}_j\left( r^{-i}\right) =\frac{1}{2}\left( r_j -\left[ {\mathfrak {t}}_i(r)+\sum _{[i]<[k]<[j]} \bar{{\mathfrak {t}}}_k\left( r^{-i}\right) \right] \right) \end{aligned}$$

Thus

$$\begin{aligned}&\bar{{\mathfrak {t}}}_j\left( r^{-i}\right) -\bar{{\mathfrak {t}}}_j(r)\\&\quad = \frac{1}{2}\left( \bar{{\mathfrak {t}}}_i(r)-\sum _{[i]<[k]<[j]} \left[ \bar{{\mathfrak {t}}}_k\left( r^{-i}\right) -\bar{{\mathfrak {t}}}_k(r)\right] \right) \end{aligned}$$

By induction on \([j]-[i]\) we obtain \(\bar{{\mathfrak {t}}} _{j}(r^{-i})-\bar{{\mathfrak {t}}}_{j}(r)= \bar{{\mathfrak {t}}}_{i}(r)/2^{[j]-[i]}\) if \([j]>[i]\).

Based on the above observation, the total payment in (30) becomes

$$\begin{aligned} \pi _{i}^{PM}(r)= & {} \sum _{[k]>[i]}\bar{{\mathfrak {t}}}_{i}(r)/2^{[k]-[i]}\\= & {} \bar{{\mathfrak {t}}}_{i}(r)\sum _{[k]>[i]}1/2^{[k]-[i]}\\= & {} \bar{{\mathfrak {t}}}_{i}(r)\left( 1-1/2^{n-[i]}\right) . \end{aligned}$$

\(\square \)

5.2 Coordinating meachanism

Lemma 3 provides a closed-form formula for the pivotal mechanism payments. With these payments, each agent pays an amount directly proportional to the duration of its allocation on subcontractor’s machine and inversely proportional to its order in the sequence of jobs on subcontractor’s machine. Therefore if an agent announces a shorter than true processing time, which could possibly precipitate its position in the sequence and thus result in the agent’s higher time saving, then the agent pays more. We show that as a result of this misrepresentation, the agent’s utility decreases. At the same time, we show that reporting longer than true processing time reduces agent’s utility as well, unless the agent comes in the last position in the sequence. This position is special since it neither incurs any payment by (31) nor it affects any other agent. Therefore, whether the agent in this position lies or not is irrelevant. Alternatively, one can assume that the longest job always belongs to the subcontractor—this dummy job could represent the continuation of subcontractor’s operations. Consequently, the mechanism enforces agents to report their actual processing time which we now formally prove.

Theorem 6

Let \(r=(r_1, \ldots , r_n)\) be the reported processing times and let \(p_i\) be true processing time of agent i. Then \(u_{i}^{PM}( {\mathcal {T}}(p_i,r^{-i}))> u_{i}^{PM}({\mathcal {T}}(r))\), provided that \(p_i\ne r_i\) and i is not in the last position of \({\mathcal {T}}(r)\).

Proof

Assume \(p_i\ne r_i\in P_i\) for some agent i. Let \(p=(p_{i},r_{-i})\). Suppose job i is in position h and l in efficient solutions \({\mathcal {T}}(p)\) and \({\mathcal {T}}(r)\), respectively, and assume \(l\ne n\). By (27), (31), (7), and (4), for \(p_i\), the utility of agent i is

$$\begin{aligned} u_{i}^{PM}({\mathcal {T}}(p))= & {} \frac{p_{i}-{\mathfrak {t}}_{i}\left( p\right) }{2 }-\frac{p_{i}-{\mathfrak {t}}_{i}\left( p\right) }{2}\left( 1-\frac{1}{2^{n-h}} \right) \nonumber \\= & {} \frac{p_{i}-{\mathfrak {t}}_{i}\left( p\right) }{2}\frac{1}{2^{n-h}}. \end{aligned}$$
(32)

There are two cases for \(r_{i}\): (a) \(r_{i}>p_{i}\), and (b) \(r_{i}<p_{i}.\)

(a) With \(r_{i}>p_{i}\) we have

$$\begin{aligned} u_{i}^{PM}({\mathcal {T}}(r))=&\max \left\{ \frac{p_{i}-{\mathfrak {t}} _{i}\left( r\right) }{2},0\right\} \nonumber \\&-\frac{r_{i}- {\mathfrak {t}}_{i}\left( r\right) }{2}\left( 1-\frac{1}{2^{n-l }}\right) , \end{aligned}$$
(33)

where \(n>l \ge h\) and \({\mathfrak {t}}_i(r)\) is the start time of job i in \({\mathcal {T}}(r)\).

Suppose \(l = h\). In this case we have \({\mathfrak {t}}_{i}(r)={\mathfrak {t}}_{i}(p)\). Since \(h<n\), it directly follows from (32) and (33) that \(u_{i}^{PM}({\mathcal {T}}(r))<u_{i}^{PM}({\mathcal {T}} (p)).\)

Next, suppose \(l > h\). Let \(\sigma (k)\) be the job in position k in \({\mathcal {T}}(p)\). By (4) and (5) and induction on \(l-h\) we have,

$$\begin{aligned} {\mathfrak {t}}_{i}\left( r\right)= & {} {\mathfrak {t}}_{i}\left( p\right) +\sum _{k=h+1}^{l }\frac{r_{\sigma (k)}- {\mathfrak {t}}_{i}\left( p\right) }{2^{l +1-k}}\\= & {} \frac{r_{\sigma (l)}}{2}+ \cdots +\frac{r_{\sigma (h+1)}}{2^{l -h}}+\frac{{\mathfrak {t}}_{i}\left( p\right) }{2^{l -h}} \end{aligned}$$

Using the fact that \(r_{\sigma (k)}\ge p_i\) for \(k\ge h\) we get

$$\begin{aligned} {\mathfrak {t}}_{i}\left( r\right)\ge & {} \sum _{k=h+1}^{l}\frac{p_i}{2^{l+1-k}}+\frac{{\mathfrak {t}}_i(p)}{2^{l-h}} =p_i-\frac{p_i}{2^{l-h}}+\frac{{\mathfrak {t}}_i(p)}{2^{l-h}} \end{aligned}$$
(34)

For a contradiction assume \(u_{i}^{PM}({\mathcal {T}}(r))\ge u_{i}^{PM}( {\mathcal {T}}(p))\), i.e., by (32) and (33) assume that

$$\begin{aligned}&\max \left\{ \frac{p_{i}-{\mathfrak {t}}_{i}\left( r\right) }{2} ,0\right\} -\frac{r_{i}-{\mathfrak {t}}_{i}\left( r\right) }{2}\left( 1-\frac{1}{2^{n-l }}\right) \\&\quad \ge \frac{p_{i}- {\mathfrak {t}}_{i}\left( p\right) }{2}\frac{1}{2^{n-h}}. \end{aligned}$$

If \(p_{i}-{\mathfrak {t}}_{i}\left( r\right) \le 0\), then the contradiction readily follows. Otherwise, suppose \(p_{i}-{\mathfrak {t}}_{i}\left( r\right) >0.\) Then, we have

$$\begin{aligned} \frac{p_{i}-{\mathfrak {t}}_{i}\left( r\right) }{2}-\frac{ r_{i}-{\mathfrak {t}}_{i}\left( r\right) }{2}\left( 1-\frac{ 1}{2^{n-l }}\right) \ge \frac{p_{i}-{\mathfrak {t}} _{i}\left( p\right) }{2}\frac{1}{2^{n-h}}. \end{aligned}$$

The last inequality simplifies to

$$\begin{aligned} 2^{l -h}\left[ r_{i}-{\mathfrak {t}}_{i}\left( r\right) \right] -\left[ p_{i}-{\mathfrak {t}}_{i}\left( p\right) \right] \ge 2^{n-h}\left[ r_{i}-p_{i}\right] . \end{aligned}$$

Using (34), note that the last inequality remains valid if \({\mathfrak {t}}_i(r)\) is replaced with \(p_i-p_i/2^{l-h}+{\mathfrak {t}}_i(p)/2^{l-h}\). The inequality then simplifies to \(2^{l -h}\left[ r_{i}-p_{i}\right] \ge 2^{n-h}\left[ r_{i}-p_{i}\right] \). This is a contradiction since we have \(2^{l -h}<2^{n-h}\). Thus \(u_{i}^{PM}({\mathcal {T}}(r))<u_{i}^{PM}({\mathcal {T}} (p))\) for \(r_i>p_i\).

(b) With \(r_{i}<p_{i}\) we have

$$\begin{aligned} u_{i}^{PM}({\mathcal {T}}(r))=&\frac{r_{i}-{\mathfrak {t}} _{i}\left( r\right) }{2} -\frac{r_{i}- {\mathfrak {t}}_{i}\left( r\right) }{2}\left( 1-\frac{1}{2^{n-l }}\right) \nonumber \\ =&\frac{r_{i}- {\mathfrak {t}}_{i}\left( r\right) }{2}\frac{1}{2^{n-l }}, \end{aligned}$$
(35)

where \(1\le l \le h\).

Suppose \(h = l\). Then we have \({\mathfrak {t}}_{i}(r)={\mathfrak {t}}_{i}(p)\), and it follows from (32) and (35) that \(u_{i}^{PM}({\mathcal {T}}(r))<u_{i}^{PM}({\mathcal {T}} (p)).\)

Next, suppose \(1\le l < h\). By (4) and (5) and induction on \(h-l\)

$$\begin{aligned} {\mathfrak {t}}_{i}\left( p\right)= & {} {\mathfrak {t}}_{i}\left( r\right) +\sum _{k=l}^{h-1}\frac{r_{\sigma (k)}- {\mathfrak {t}}_{i}\left( r\right) }{2^{h-k}}\\= & {} \frac{r_{\sigma (h-1)}}{2}+ \cdots +\frac{r_{\sigma (l)}}{2^{h-l}}+\frac{{\mathfrak {t}}_{i}\left( r\right) }{2^{h-l}}. \end{aligned}$$

Using the fact that \(r_{\sigma (k)}\le p_i\) for \(k\le h\) we get

$$\begin{aligned} {\mathfrak {t}}_{i}\left( p\right)\le & {} \sum _{k=1}^{h-1}\frac{p_i}{2^{h-k}}+\frac{{\mathfrak {t}}_i(r)}{2^{h-l}} =p_i-\frac{p_i}{2^{h-l}}+\frac{{\mathfrak {t}}_i(r)}{2^{h-l}} \end{aligned}$$
(36)

For a contradiction assume \(u_{i}^{PM}({\mathcal {T}}(r))\ge u_{i}^{PM}( {\mathcal {T}}(p))\) or, by (32) and (35),

$$\begin{aligned} \frac{r_{i}- {\mathfrak {t}}_{i}\left( r\right) }{2}\frac{1}{2^{n-l }}\ge \frac{p_{i}- {\mathfrak {t}}_{i}\left( p\right) }{2}\frac{1}{2^{n-h}}. \end{aligned}$$

The last simplifies to

$$\begin{aligned} r_{i}-{\mathfrak {t}}_{i}\left( r\right) \ge 2^{h-l}[ p_{i}-{\mathfrak {t}}_{i}\left( p\right) ]. \end{aligned}$$

Using (36), the last inequality remains valid if \({\mathfrak {t}}_i(p)\) is replaced with \(p_i-p_i/2^{h-l}+{\mathfrak {t}}_i(r)/2^{h-l}\). The inequality then simplifies to \(r_{i}\ge p_{i}\) which is a contradiction. Thus \(u_{i}^{PM}({\mathcal {T}}(r))<u_{i}^{PM}({\mathcal {T}} (p))\) for \(r_i<p_i\). \(\square \)

Finally, to ensure agents’ participation in subcontracting, the efficient mechanism M must satisfy the strict individual rationality condition requiring that for all agents, truth-telling results in positive utility, irrespective of the reported processing times of other agents. That is, for every \(r=(r_1, \ldots ,r_i=p_i, \ldots ,r_n)\) and all \(i\in N\), \(u^M_{i}({\mathcal {T}}(r))>0\). The efficient mechanism \(({\mathcal {T}},\pi ^{PM})\) satisfies the strict individual rationality condition since, by (27), (31) and (7), we have \(u_{i}^{PM}({\mathcal {T}}\left( r\right) )=\bar{{\mathfrak {t}}}_{i}(r)/2^{n-[i]}>0,\) for \(r_i=p_i\).

Thus we showed the mechanism \(({\mathcal {T}},\pi ^{PM})\) guarantees, by Theorem 6, that the agents are always better off by reporting their true processing times, and that, by strict individual rationality, they are better off by participating in the subcontracting. Therefore the mechanism coordinates the subcontractor scheduling problem under private information.

One possible disadvantage of coordination based on mechanism design, the VCG mechanisms in particular, is that this coordination is implicitly centralized—the efficient schedule is computed by the subcontractor and then reported to the agents. Although distributed implementations of the pivotal mechanism where the schedule is determined by the self-interested agents themselves are beyond the scope of this paper, we refer the reader to Parkes and Shneidman (2004) where guidelines for the distributed implementations of the VCG mechanisms are proposed.

5.3 Subcontractor’s revenue with coordinating mechanisms

The payment scheme \(\pi ^{PM}\) provides the subcontractor with a positive revenue for any given r. Let us define \(\varPi ^{PM}(r)=\sum _{i\in N}\pi _{i}^{PM}(r)\) as the total payment from agents to the subcontractor in pivotal mechanism. By Theorem 6 all agents except the last in \({\mathcal {T}}(r)\) report their true processing times while the last one pays nothing to the subcontractor regardless of his report. Therefore, we focus on the subcontractor’s revenue for the true processing times p.

Although the subcontractor’s services result in the total savings of \(\upsilon ({\mathcal {T}}\left( p\right) )\) for all agents, it follows from Lemma 3 that the mechanism \(({\mathcal {T}},\pi ^{PM})\) can only achieve revenue \(\varPi ^{PM}(p)\ \) for the subcontractor which is always less than \(v({\mathcal {T}}\left( p\right) )\). In fact, instances can be found for which the ratio of subcontractor’s revenue to total savings obtained via subcontracting, i.e., \(\varPi ^{PM}(p)/\upsilon ({\mathcal {T}}\left( p\right) )\), is arbitrarily close to zero. For example, consider a set of two jobs with \(p_{1}=2\) and \(p_{2}=101\). Despite having a total saving of 51, we have \(\pi _{1}^{PM}=0.5\) and \(\pi _{2}^{PM}=0\) resulting in the ratio \(\upsilon ({\mathcal {T}}\left( p\right) )/ \varPi ^{PM}(p)<0.01\).

Nevertheless, Moulin (1986) shows that if for all agents it holds that \(\min _{T}\upsilon _{i}(T)=0\)—which is the case in subcontractor’s subcontracting problem with divisible jobs—then among all efficient, incentive compatible, and individually rational mechanisms, the pivotal mechanism generates the highest total payment. Therefore, the subcontractor cannot gain a higher revenue from any other efficient, incentive compatible, and individually rational mechanisms than it does from \(({\mathcal {T}},\pi ^{PM})\). Thus, by the juxtaposition of Lemma 3 and Theorem 5 we get the following observation.

Corollary 1

Subcontractor’s revenue with any efficient, incentive compatible, and individually rational mechanisms under private information never exceeds that with a coordinating pricing scheme under complete information.

However, the construction of a coordinating pricing scheme q requires the knowledge of true processing times p, thus the difference \(\varPi ^q(p)-\varPi ^{PM}(p)\) may be considered as the amount the subcontractor forfeit to the agents to extract the true processing times from them.

6 Asymmetric valuations

We now relax the assumption of symmetric valuations and assume that the value of a unit time saving for agent i is \(w_{i}\). Let \(w=(w_{i}|i\in N).\) The saving to agent i resulting from the allocation T thus equals

$$\begin{aligned} \upsilon _{i}^{w}(T)=w_{i}\upsilon _{i}(T). \end{aligned}$$
(37)

The total saving for all agents is defined as the sum of individual savings, that is \(\upsilon ^{w}(T)=\sum _{i\in N}\upsilon _{i}^{w}(T)\). The efficient allocation is \({\mathcal {T}}=\arg \max _{T}\upsilon ^{w}(T) \). Unlike the symmetric case where each job in N is allocated a non-empty interval on subcontractor’s machine, in asymmetric case efficient allocations may exclude some jobs from the subcontractor’s schedule. Let \({\mathcal {I}}=\{i\in N| \bar{{\mathfrak {t}}}_{i}>0\}\) be the set of jobs that receive non-empty allocations, and \({\mathcal {O}}=\{i\in N|\bar{{\mathfrak {t}}}_{i}=0\}\) the set of jobs that receive no such allocations. We denote the cardinality of \({\mathcal {I}}\) with l.

In the remainder of this section, we focus on coordinating pricing schemes in situations with asymmetric valuations. In these situations, any coordinating pricing scheme q meets the following conditions: for \({\mathfrak {t}}_{i }\le t<{\mathfrak {t}}_{i+1 }\) it holds that \(q(t)<w_{ i }\), that is, it is required that subcontracting price across the allocation of job i do not exceed its unit saving from subcontracting.

We show by a counterexample that it is generally impossible to construct coordinating pricing schemes in the asymmetric case. Without loss of generality we assume \({\mathcal {I}}=\{1, \ldots ,l\}\) and that the jobs are sequenced in efficient solutions by their index order.

Theorem 7

There exists no coordinating pricing scheme in the asymmetric valuation case.

Proof

To construct coordinating pricing schemes, we must ensure that agents would not benefit by deviating from the efficient allocations. In particular, deviations of the similar type as in Theorem 5 must be unprofitable for any agent who receives non-zero allocations on the subcontractor’s machine. That is for every \(i =2, \ldots ,l\) and every \(0<\epsilon <{\mathfrak {t}}_{i }\) it must hold that,

$$\begin{aligned} q\left( {\mathfrak {t}}_{i}-2\epsilon ,{\mathfrak {t}}_{i}\right) -q ( {\mathfrak {t}}_{i+1}-\epsilon ,{\mathfrak {t}}_{i+1}) \ge w_{i}\epsilon . \end{aligned}$$
(38)

Consider the following example. There are four jobs \(p=(p_{1}=6,p_{2}=18,p_{3}=19,p_{4}=25)\) with \(w= (w_{1}=9,w_{2}=2,w_{3}=12,w_{4}=11).\) The unique efficient allocation is \({\mathcal {I}}=\{1,3,4\}\) with \({\mathcal {T}}_{1}=[0,3)\), \({\mathcal {T}}_{3}=[3,11)\), \({\mathcal {T}} _{4}=[11,18),\) and \({\mathcal {O}}=\{2\}\). For any coordinating pricing scheme, we must have \(q(t)>2\) for \(0\le t<18\) so that job 2 would not be able to choose any interval on subcontractor’s machine.

The condition in (38) for job \(i=4\) and \(\epsilon =0.25\) requires that,

$$\begin{aligned} q\left( 10.5,11\right) -q ( 17.75,18) \ge 2.75. \end{aligned}$$
(39)

Considering that we need \(q(t)>2\) for \(0\le t<18\), it must be that \(q ( 17.75,18)> 0.5\) and consequently \(q\left( 10.5,11\right) > 3.25\).

The condition in (38) for job \(i=3\) and \(\epsilon =0.5\) requires that,

$$\begin{aligned} q\left( 2,3\right) -q ( 10.5,11) \ge 6. \end{aligned}$$
(40)

We already know that \(q\left( 10.5,11\right) > 3.25\) thus it must be that \(q\left( 2,3\right) > 9.25\). This implies that in the cheapest coordinating pricing scheme, agent 1 must pay 9.25 for acquiring the time interval [2, 3) on subcontractor’s machine. However, since the valuation of agent 1 is only 9, this means that he would be better off by not accepting that interval. This contradicts the fact that q is coordinating. Therefore, in situations with asymmetric valuations, coordinating pricing schemes may be impossible to find. \(\square \)

7 Final remarks and conclusions

We studied the decentralized subcontractor scheduling problem under complete and private information. We designed the coordinating pricing schemes in case of complete information and studied the range of subcontractor’s revenue for these schemes. Our coordinating pricing schemes are piecewise linear and non-increasing.

We also devised a mechanism that is incentive compatible, individually rational, and efficient in case of private information. The mechanism is based on the pivotal mechanism and it is moreover coordinating. Another desirable property of the mechanism, that immediately follows from Theorem 6, is Envy-Freeness (Foley 1967) which is defined as the condition where no agent prefers another agent’s allocation to its own, that is \(u_{i}({\mathcal {T}}_{i}(p))\ge u_{i}({\mathcal {T}}_{j}(p))\) for all j and all i. The mechanism produces the highest subcontractor revenue among efficient, incentive compatible, and individually rational mechanisms.

For the asymmetric case, we showed that the coordination through pricing schemes is not always possible.

An open problem is the complexity of finding the efficient allocations for the asymmetric case.

Several other extensions are possible for this problem: job’s release dates and due dates, setup times required for subcontractor to prepare for processing different jobs, and transportation costs for transportation from and to manufacturers. Finally, the divisibility of jobs can be altered by requesting that only certain parts of jobs with fixed durations can be subcontracted. We leave these issues for future research.