1 Introduction

In the field of project scheduling, a great deal of effort has been devoted over the years to renewable resources, which are able to model resources like staff or machines that are assumed to be available in a specific quantity at each point in time (or period). In this work, we consider a more general resource type, which has firstly been introduced under the term partially renewable resources in the framework of project scheduling by Böttcher et al. (1999). The corresponding problem, denoted by RCPSP/\(\pi \), is a generalization of the classical resource-constrained project scheduling problem (RCPSP). The motivation for the extension of RCPSP by partially renewable resources stems from the restrictiveness of the renewable resources in the sense that the availability for each time period has to be fixed in advance, separated from the scheduling process. This limitation is resolved by partially renewable resources that are defined over multiple time periods with a given capacity. Thereby, the resources are consumed only on the defined time periods by the activities of the project. Examples for the application of RCPSP/\(\pi \) can be found in Böttcher et al. (1999) for the flexible planning of lunch breaks, in Alvarez-Valdes et al. (2008) for the assignment of weekend work, or in Alvarez-Valdes et al. (2015) for a school timetabling problem.

In the last decades, approximation and exact solution procedures have been developed for RCPSP/\(\pi \). In Böttcher et al. (1999) and Schirmer (1999), priority rule-based methods for RCPSP/\(\pi \) are investigated. The works of Alvarez-Valdes et al. (2006, 2008, 2015) are devoted to a GRASP and a scatter search algorithm, and in Schirmer (1999) different local-search procedures are considered. The state-of-the-art approximation method for RCPSP/\(\pi \) in terms of the solution quality is given by the scatter search algorithm. This procedure makes use of a priority rule-based generation scheme to determine feasible schedules, which are iteratively combined with each other to obtain better solutions. Böttcher et al. (1999) devised the only exact solution procedure for RCPSP/\(\pi \). The branch-and-bound algorithm (BnB) is based on the enumeration scheme by Talbot and Patterson (1978) for which the authors have developed two feasibility bounds.

For the first time, Watermeyer and Zimmermann (2020) have extended RCPSP/\(\pi \) by taking minimum and maximum time lags between the activities into account (RCPSP/max-\(\pi \)). An example for this problem is the planning of a training program for an employee that consists of a theoretical and a practical course. Thereby, the theory has to be taught first, the practical course is not supposed to be conducted more than two weeks after, and at most one course should take place at a weekend day. The temporal constraints between both courses are represented by minimum and maximum time lags, while the weekend constraint is given by a partially renewable resource that is defined over all weekend days with a capacity for one course. The state-of-the-art exact solution procedure for RCPSP/max-\(\pi \) and RCPSP/\(\pi \) is provided in Watermeyer and Zimmermann (2020) by a relaxation-based BnB. The procedure progressively reduces the possible resource consumptions by the activities of the project in each branching step and solves the corresponding resource relaxations.

In this work we present a new BnB for RCPSP/max-\(\pi \) that is based on a serial schedule-generation scheme. The new enumeration approach schedules all activities of the project successively by assigning a start time to an activity in each branching step. In this way, partial schedules are augmented in the course of the enumeration until there is no feasible start time left or a complete schedule is determined.

The remainder of this paper is organized as follows. Section 2 provides a formal description of RCPSP/max-\(\pi \). In Sect. 3 we discuss the enumeration scheme of our BnB. Section 4 deals with improving techniques, and Sect. 5 describes the BnB. In Sect. 6 we present the results of a comprehensive experimental performance analysis and provide some conclusions in Sect. 7.

2 Problem description

RCPSP/max-\(\pi \) can be represented by an activity-on-node project network N with node set V, covering all activities of the project, and arc set \(E\subset V\times V\), implying the precedence relationships among them. Each activity \(i\in V\) is assigned a non-interruptible processing time \(p_i\in \mathbb {Z}_{\ge 0}\) and a resource demand \(r^d_{ik}\in \mathbb {Z}_{\ge 0}\) for each partially renewable resource \(k\in \mathcal {R}\). The temporal constraint for each activity pair \((i,j)\in E\) is specified by a start-to-start precedence relationship and arc weight \(\delta _{ij}\in \mathbb {Z}\), meaning that each temporal constraint is given by \(S_j\ge S_i +\delta _{ij}\), establishing a time lag between the start times of activities i and j. In the following we speak of a minimum time lag between activities i and j if \(\delta _{ij}\ge 0\) and say that a maximum time lag is given if \(\delta _{ji}<0\). The node set \(V{:}{=}\{0,1,\ldots ,n+1\}\) includes two fictitious activities 0 and \(n+1\), i.e., \(p_0=p_{n+1}=0\), which represent the beginning and the termination of the project, respectively. It is assumed that each project starts at time 0 and is completed before a prescribed deadline \(\bar{d}\), i.e., \(S_0=0\) and \(S_{n+1}\le \bar{d}\). In the remainder of this work, we call a vector \(S=(S_i)_{i\in V}\) with \(S_i\in \mathbb {Z}_{\ge 0}\) and \(S_0=0\) a schedule and speak of a time-feasible schedule if all temporal constraints are satisfied and \(S_{n+1}\le \bar{d}\). By \(\mathcal {S}_T\), we denote the set of all time-feasible schedules. The resource constraints of RCPSP/max-\(\pi \) are given by the resource capacities \(R_k\in \mathbb {Z}_{\ge 0}\) of all partially renewable resources \(k\in \mathcal {R}\). Thereby, the availability of each resource is only limited on a specified subset of all time periods within the entire planning horizon \(\varPi _k\subseteq \{1,2,\ldots ,\bar{d}\}\). As a consequence, only the resource consumption of an activity \(i\in V_k{:}{=}\{i\in V\, |\, r^d_{ik}>0\}\) over the time periods in \(\varPi _k\) has to be taken into account. In order to express the number of the time periods in \(\varPi _k\) an activity \(i\in V\) is in execution, we introduce the so-called resource usage \(r^u_{ik}(S_i){:}{=}|]S_i,S_i+p_i]\cap \varPi _k|\). Based on the resource usage, the resource consumption of a resource \(k\in \mathcal {R}\) by an activity \(i\in V\) follows directly with \(r^c_{ik}(S_i){:}{=}r^u_{ik}(S_i)\cdot r^d_{ik}\), so that the resource constraints can be stated by \(\sum _{i\in V} r^c_{ik}(S_i) \le R_k\) for all \(k\in \mathcal {R}\). In the following, we call a schedule S that fulfills all resource constraints a resource-feasible schedule and denote the set of all resource-feasible schedules by \(\mathcal {S}_R\). Furthermore, we say that schedule \(S\in \mathcal {S}\) is feasible with \(\mathcal {S}{:}{=}\mathcal {S}_T\cap \mathcal {S}_R\) as the set of all feasible schedules.

The objective of RCPSP/max-\(\pi \) is to determine a feasible schedule \(S^*\) with the shortest project duration among all feasible schedules \(S\in \mathcal {S}\). The corresponding problem is stated by

$$\begin{aligned} \left. \begin{array}{cccc} {Minimize } &{} \quad \quad \quad \,\, f(S) = S_{n+1}&{}&{}\\ {subject to } &{} S\in \mathcal {S} &{}&{}\\ \end{array}\right\} ({\hbox {P}}) \end{aligned}$$

with \(f:\mathcal {S}\mapsto \mathbb {R}\) as the objective function that assigns the project duration to each feasible schedule S. We call a schedule S that solves problem (P) an optimal schedule and denote the set of all optimal schedules by \(\mathcal {OS}\).

It should be noted that there also exist other approaches to model partially renewable resources by assigning multiple subsets of time periods to each of them with the advantage of a more intuitive connection to resources in real-life applications (Böttcher et al. 1999). In this work, we use the so-called normalized formulation for partially renewable resources that turned out to be more appropriate for theoretical issues since each restriction of a real-life resource is represented by exactly one partially renewable resource.

3 Enumeration scheme

In general, the enumeration scheme of a BnB specifies the procedure to construct the search tree or rather implicates how to generate all direct descendants of a search node. In the following, we present the enumeration scheme of our BnB, which is based on a serial schedule-generation procedure complemented by an unscheduling step. The concept of unscheduling is based on the work of Franck et al. (2001) that provides a serial schedule-generation scheme for RCPSP with general temporal constraints (RCPSP/max).

The construction procedure of the directed outtree corresponding to the enumeration scheme of our BnB is described in Algorithm 1. In this procedure, each enumeration node is represented by a pair \((\mathcal {C},S)\) with \(\mathcal {C}\subseteq V\) as the set of all currently scheduled activities and S as a time-feasible schedule that represents the start times \(S_i\) for all activities \(i\in \mathcal {C}\) and the earliest time-feasible start times for all not currently scheduled activities \(i\in V\setminus \mathcal {C}\). To simplify the following explanations, we use the concept of partial schedules, referring to Definition (2.6.3) in Neumann et al. (2003), to describe the start times of all currently scheduled activities for some enumeration node.

Definition 1

\(S^\mathcal {C}{:}{=}(S_i)_{i\in \mathcal {C}}\) with \(\mathcal {C}\subseteq V\) and schedule S is called a partial schedule. In case that \(S_j\ge S_i + \delta _{ij}\) for all \((i,j)\in E\cap \mathcal {C}\times \mathcal {C}\), partial schedule \(S^\mathcal {C}\) is said to be time-feasible and is termed resource-feasible if \(\sum _{i\in \mathcal {C}}r^c_{ik}(S_i)\le R_k\) for all \(k\in \mathcal {R}\). In compliance with schedules, a time-feasible and resource-feasible partial schedule \(S^\mathcal {C}\) is called feasible. \(S^{\mathcal {C}\cup \{i\}}\) with \(i\in V\setminus \mathcal {C}\) is said to be the augmentation of \(S^\mathcal {C}\) by activity i and \(S_i\) is termed time-feasible, resource-feasible or feasible if partial schedule \(S^{\mathcal {C}\cup \{i\}}\) is time-feasible, resource-feasible or feasible, respectively.

Algorithm 1 outlines the enumeration scheme of our BnB. In the initialization step, the distance matrix \(D{:}{=}(d_{ij})_{i,j\in V}\) with \(d_{ij}\) as the length of a longest path between activities i and j in project network N is calculated with the Floyd-Warshall algorithm (Ahuja et al. 1993,  Sect. 5.6). Then, the earliest and latest time-feasible schedules \( ES \) and \( LS \) are derived and the root node \((\mathcal {C},S)\) is initialized by \(\mathcal {C}{:}{=}\{0\}\) and \(S{:}{=} ES \), meaning that the project start is scheduled at time 0, so that partial schedule \(S^\mathcal {C}=(0)\) with \(S_0=0\) corresponds to the root node. For the enumeration scheme we use set \(\varOmega \) to store all generated enumeration nodes that are still to be explored, and \(\varPhi \) to gather all generated schedules during the construction procedure. Accordingly, these sets are initialized by \(\varOmega {:}{=}\{(\mathcal {C},S)\}\) and \(\varPhi {:}{=}\emptyset \).

figure a

In each iteration of Algorithm 1 some pair \((\mathcal {C},S)\) is removed from \(\varOmega \). In case that \(\mathcal {C}\ne V\), some activity \(i\in \bar{\mathcal {C}}\) from the set of all not currently scheduled activities \(\bar{\mathcal {C}}{:}{=}V\setminus \mathcal {C}\) is chosen. For this activity, all resource-feasible start times in \(\{S_i,\ldots , LS _i\}\) are determined and stored in the so-called scheduling set \(\varTheta _i\). The resource-feasibility is ensured by taking the resource consumption \(r^c_k(S^\mathcal {C}){:}{=}\sum _{j\in \mathcal {C}}r^c_{jk}(S_j)\) for each resource \(k\in \mathcal {R}_i{:}{=}\{k\in \mathcal {R}\,|\,r^d_{ik}>0\}\) of partial schedule \(S^\mathcal {C}\) into account. Afterward, based on a dominance criterion with similarities to left-shift dominance rules for renewable resources (see, e.g., Stinson et al.,  1978; Demeulemeester and Herroelen, 1992), the reduced scheduling set \(T_i\) is calculated. \(T_i\) comprises all start times from \(\varTheta _i\) with a lower resource consumption for at least one resource \(k\in \mathcal {R}_i\) compared to all lower start times in \(\varTheta _i\). The calculation of \(T_i\), which is defined by , is described in Sect. 3.1. Based on the reduced scheduling set \(T_i\), all direct descendants of enumeration node \((\mathcal {C},S)\) are generated. For each descendant node \((\mathcal {C}',S')\), some scheduling time \(t\in T_i\) is established as the start time \(S'_i\) of activity i, followed by an update of the earliest time-feasible start times for all activities by \(S'{:}{=}(\max (S_j,S'_i+d_{ij}))_{j\in V}\) if it is assumed that activity i starts at time t. Since for each start time \(t\in T_i\) the conditions \(S_j+d_{ji}\le t\) for all currently scheduled activities \(j\in \mathcal {C}\) are satisfied, in case that t is not time-feasible, there has to be at least one activity \(j\in \mathcal {C}\) with \(S_j - d_{ij} < t\). This means that the induced latest start time \( LS _i(S_j){:}{=}S_j-d_{ij}\) of activity i by some activity \(j\in \mathcal {C}\) prevents the time-feasibility of start time t. As a consequence, in order to achieve the time-feasibility of \(S'^{\,\mathcal {C}\cup \{i\}}\) with \(S'_i=t\), all currently scheduled activities \(j\in \mathcal {C}\) with \(t > LS _i(S_j)\) or rather \(S'_j > S_j\) are unscheduled by setting \(\mathcal {C}'{:}{=}\mathcal {C}\setminus \{j\in \mathcal {C}\, |\, S'_j > S_j\}\). More precisely, the unscheduling of an activity is done by removing it from the set of all currently scheduled activities \(\mathcal {C}\) of the direct ancestor node. It should be noted that \(0\in \mathcal {C}'\) is always ensured by \(t \le LS _i\) due to the definition of \(\varTheta _i\). In case that start time t is time-feasible (\(t\le \min _{j\in \mathcal {C}} LS _i(S_j)\)), activity i is scheduled at start time \(S'_i=t\) by setting \(\mathcal {C}'{:}{=}\mathcal {C}\cup \{i\}\). Finally, after the scheduling or unscheduling step, the descendant node \((\mathcal {C}',S')\) is stored in \(\varOmega \) in order to be explored in one of the following iterations. From the description of the procedure to schedule or unschedule activities it follows directly that each partial schedule \(S^\mathcal {C}\) of an enumeration node \((\mathcal {C},S)\) is feasible. Therefore, in case that some node \((\mathcal {C},S)\) with \(\mathcal {C}=V\) is removed from \(\varOmega \), schedule \(S=S^\mathcal {C}\in \mathcal {S}\) is stored in \(\varPhi \) as a candidate schedule. After all enumeration nodes have been explored, i.e., \(\varOmega =\emptyset \), Algorithm 1 terminates and returns set \(\varPhi \), which contains all candidate schedules generated in the course of the enumeration procedure.

3.1 Reduced scheduling set

This section deals with the calculation of the reduced scheduling set \(T_i\) in each branching step of Algorithm 1. For the first time, we provide a procedure to determine dominant start times from \(\varTheta _i\), while all existing schedule-generation schemes for partially renewable resources consider all start times from \(\varTheta _i\) in each scheduling step (see Schirmer, 1999; Alvarez-Valdes et al., 2006; 2008; 2015).

figure b

The procedure to calculate the reduced scheduling set from \(\varTheta _i\) is given in Algorithm 2. To simplify the representation, the definition \(\min \emptyset {:}{=}\infty \) is assumed. In the course of the procedure, variable t serves as the start time that is considered in the current iteration, while boolean variable \( element \) is used to indicate if start time t is or is not an element of \(T_i\). The algorithm starts with an empty set \(T_i\) and checks in each iteration for some start time \(t\in \varTheta _i\) if there is any start time \(\tau \in T_i\) with \(r^u_{ik}(t)\ge r^u_{ik}(\tau )\) for all \(k\in \mathcal {R}_i\). This is done in the procedure by checking for each \(\tau \in T_i\) if there is at least one resource \(k\in \mathcal {R}_i\) with \(r^u_{ik}(t)<r^u_{ik}(\tau )\). If this is the case for all start times in \(T_i\), meaning that there is no start time \(\tau \in T_i\) with \(r^u_{ik}(t)\ge r^u_{ik}(\tau )\) for all \(k\in \mathcal {R}_i\), t is added to \(T_i\). Since all start times \(t\in \varTheta _i\) are considered in an increasing order, the condition that there is no start time \(\tau \in T_i\) with \(r^u_{ik}(t)\ge r^u_{ik}(\tau )\) for all \(k\in \mathcal {R}_i\) implies that there is also no lower start time in \(\varTheta _i\) satisfying this condition. This can be verified by noticing that for each start time \(\tau \in \varTheta _i\) that has not been added to \(T_i\) in the course of Algorithm 2, there is at least one lower start time \(\tau '\in T_i\) with \(r^u_{ik}(\tau ')\le r^u_{ik}(\tau )\) for all \(k\in \mathcal {R}_i\). Finally, since for each start time \(t\in \varTheta _i\) that is not an element of \(T_i\) at the end of the procedure there is at least one earlier start time \(\tau \in \varTheta _i\) (\(\tau \in T_i\)) with \(r^u_{ik}(t)\ge r^u_{ik}(\tau )\) for all \(k\in \mathcal {R}_i\), we can state that Algorithm 2 is correct.

3.2 Correctness of the enumeration scheme

In what follows, we prove that Algorithm 1 generates at least one optimal schedule in finitely many iterations if and only if there is at least one feasible solution. It should be noted that the total correctness of Algorithm 1 follows directly from this proof since each candidate schedule is feasible, i.e., \(\varPhi \subseteq \mathcal {S}\). First of all, Theorem 1, which is based on Lemmas 1 and 2, states that the enumeration scheme generates at least the set of all so-called active schedules \(\mathcal {AS}\). In line with Neumann et al. (2000), we call a feasible schedule S active if and only if there is no feasible schedule \(S'\ne S\) with \(S'\le S\), i.e., \(S'_i\le S_i\) for all \(i\in V\). By definition, for each non-active feasible schedule there is at least one activity whose start time can be left-shifted to obtain a feasible schedule. As a consequence, there has to be at least one optimal schedule that is active for each instance with \(\mathcal {S}\ne \emptyset \), so that Theorem 1 implicates the completeness of Algorithm 1, i.e., \(\mathcal {S}\ne \emptyset \Leftrightarrow \varPhi \cap \mathcal {OS}\ne \emptyset \).

Lemma 1

Let \(T_i\) be the reduced scheduling set of \(\varTheta _i\). Then \(T_i\) contains exactly all lowest scheduling times \(t\in \varTheta _i\) that satisfy \(r^u_{ik}(t)\le r^u_{ik}(\tau )\) for any \(\tau \in \varTheta _i\) and all \(k\in \mathcal {R}_i\), i.e., \(T_i=T^\cup _i{:}{=}\bigcup _{\tau {\,\in } \varTheta _i}\{\min \{\tau '{\,\in } {\,\varTheta _i}\, |\, r^u_{ik}(\tau '){\,\le } r^u_{ik}(\tau )\text { for all } k\in \mathcal {R}_i\}\}\).

Proof

Consider any start time \(t\in T_i\). From the definition of \(T_i\) it follows directly that \(t=\min \{\tau \in \varTheta _i\, |\, r^u_{ik}(\tau )\le r^u_{ik}(t)\text { for all } k\in \mathcal {R}_i\}\), so that \(T_i\subseteq T^\cup _i\) is given. Next, let \(\tau \in \varTheta _i\) and \(t{:}{=}\min \{\tau '\in \varTheta _i\, |\, r^u_{ik}(\tau ')\le r^u_{ik}(\tau )\text { for all } k\in \mathcal {R}_i\}\) be given and assume \(t\notin T_i\). Since \(t\notin T_i\) implies \(t>\min \{\tau '\in \varTheta _i\, |\, r^u_{ik}(\tau ')\le r^u_{ik}(\tau )\text { for all } k\in \mathcal {R}_i\}\), which would contradict the assumption for t, \(T_i\supseteq T^\cup _i\) and therefore \(T_i=T^\cup _i\) follows. \(\square \)

Lemma 2

Let \(S^f\in \mathcal {S}\) be any feasible schedule and \((\mathcal {C},S)\) some node corresponding to the enumeration scheme of Algorithm 1 with \(\mathcal {C}\ne V\), \(S\le S^f\) and \(r^u_{jk}(S_j)\le r^u_{jk}(S^f_j)\) for all \(j\in \mathcal {C}\) and all \(k\in \mathcal {R}_j\). Then there is at least one direct descendant node \((\mathcal {C}',S')\) that fulfills the conditions \(S'\le S^f\) and \(r^u_{jk}(S'_j)\le r^u_{jk}(S^f_j)\) for all \(j\in \mathcal {C'}\) and all \(k\in \mathcal {R}_j\).

Proof

Let \(i\in \bar{\mathcal {C}}\) be the selected activity for the generation of the direct descendants of enumeration node \((\mathcal {C},S)\). First of all, \(S^f_i\in \varTheta _i\) can be derived from \(S_i\le S^f_i\le LS _i\) and \(r^c_k(S^\mathcal {C})+r^c_{ik}(S^f_i)\le r^c_k(S^f)\le R_k\) for all \(k\in \mathcal {R}_i\). Since \(S^f_i\in \varTheta _i\), from Lemma 1 we get \(t{:}{=}\min \{\tau \in \varTheta _i\, |\, r^u_{ik}(\tau )\le r^u_{ik}(S^f_i)\text { for all } k\in \mathcal {R}_i\}\in T_i\), so that \(t\le S^f_i\) and \(r^u_{ik}(t)\le r^u_{ik}(S^f_i)\text { for all } k\in \mathcal {R}_i\). Accordingly, considering the direct descendant node corresponding to start time t of activity i, \(S'\le S^f\) is implied by \(t\le S^f_i\) (\(t+d_{ij}\le S^f_i+d_{ij}\le S^f_j\text { for all } j\in V\)) and the conditions \(r^u_{jk}(S'_j)\le r^u_{jk}(S^f_j)\) for all \(j\in \mathcal {C'}\) and \(k\in \mathcal {R}_j\) are satisfied as well, either if activity i is scheduled (\(\mathcal {C}'{:}{=}\mathcal {C}\cup \{i\}\)) or some activities are unscheduled. \(\square \)

Theorem 1

Algorithm 1 generates all active schedules, i.e., \(\varPhi \supseteq \mathcal {AS}\).

Proof

For each active schedule \(S^a\in \mathcal {AS}\) the conditions \(S\le S^a\) and \(r^u_{jk}(S_j)\le r^u_{jk}(S^a_j)\) for all \(j\in \mathcal {C}\) and all \(k\in \mathcal {R}_j\) are satisfied with \((\mathcal {C},S)\) corresponding to the root node. Accordingly, it follows from Lemma 2 that there exists at least one path in the enumeration tree on which each node \((\mathcal {C},S)\) satisfies the conditions \(S\le S^a\) and \(r^u_{jk}(S_j)\le r^u_{jk}(S^a_j)\text { for all } j\in \mathcal {C}\text { and all }k\in \mathcal {R}_j\), respectively. Since for the generation of any direct descendant node either the start time \(S_j\) for at least one activity \(j\in \mathcal {C}\) is increased (\(S'_j>S_j\)) or some activity \(i\in \bar{\mathcal {C}}\) is scheduled (\(\mathcal {C}'{:}{=}\mathcal {C}\cup \{i\}\)), each such path has a finite length. Finally, from the property of Algorithm 1 that each generated schedule \(S\in \varPhi \) is feasible and since \(S\le S^a\) with \(S\ne S^a\) would contradict the assumption that \(S^a\) is active, we can state that Algorithm 1 generates all active schedules. \(\square \)

Finally, Lemma 3 establishes that the enumeration scheme terminates after a finite number of iterations.

Lemma 3

Algorithm 1 generates at most \((\bar{d}+1)^{|V|(\bar{d}+1)}\) enumeration nodes.

Proof

For the generation of any descendant node in the enumeration scheme of Algorithm 1 either the selected activity \(i\in \bar{\mathcal {C}}\) is scheduled or the start time \(S_j\) of any activity \(j\in \mathcal {C}\) is increased by at least one unit. Since the start time of each activity is bounded from above by \(\bar{d}+1\), an upper bound for the maximum depth of the enumeration tree is given by \(|V|(\bar{d}+1)\). Accordingly, an upper bound for the maximum number of generated nodes is given by \((\bar{d}+1)^{|V|(\bar{d}+1)}\) taking into consideration that the number of start times in \(T_i\) is bounded from above by \(\bar{d}+1\). \(\square \)

4 Improving techniques

In Watermeyer and Zimmermann (2020) it has already been shown for a relaxation-based BnB for RCPSP/max-\(\pi \) that the application of consistency tests, lower bounds , and techniques to avoid redundancies can have a great impact on the performance. In what follows, we extend our enumeration scheme to be able to use consistency tests and lower bounds from Watermeyer and Zimmermann (2020) and to apply new devised pruning techniques that are described in Sect. 4.3.

4.1 Extended enumeration scheme

For the extension of the enumeration scheme we establish a domain \(W_i\subseteq H{:}{=}\{0,1,\ldots ,\bar{d}\}\) for the start time \(S_i\) of each activity \(i\in V\). Set \(W_i\) contains all possible start times of activity \(i\in V\), i.e., \(S_i\in W_i\). In line with Definition 1 in Watermeyer and Zimmermann (2020), we call \(W{:}{=}(W_i)_{i\in V}\) with \(W_i\subseteq H\) for all \(i\in V\) and \(W_0=\{0\}\) a start time restriction and denote by \(W_i\) the start time restriction of activity \(i\in V\). In the following we speak of a W-feasible schedule S if \(S\in \mathcal {S}_T(W){:}{=}\{S\in \mathcal {S}_T\, |\, S_i\in W_i\) for all \(i\in V\}\) and say that a partial schedule \(S^\mathcal {C}\) is W-feasible if there is at least one schedule \(S'\in \mathcal {S}_T(W)\) with \(S'_i=S_i\) for all scheduled activities \(i\in \mathcal {C}\). Furthermore, in accordance with Definition 1, we say that start time \(S_i\) of some not currently scheduled activity \(i\in \bar{\mathcal {C}}\) is W-feasible exactly if augmentation \(S^{\mathcal {C}\cup \{i\}}\) is W-feasible. Therefore, if t is established as the earliest possible start time of some activity \(i\in V\), the earliest W-feasible start time of any activity \(j\in V\) is expressed by \( ES _j(W,i,t){:}{=}(\min \widetilde{\mathcal {S}}_T(W,i,t))_j\) with \(\widetilde{\mathcal {S}}_T(W,i,t){:}{=}\{S\in \mathcal {S}_T(W)\, |\, S_i\ge t\}\). In the same way, the latest W-feasible start time of an activity \(j\in V\) is given by \( LS _j(W,i,t){:}{=}(\max \widehat{\mathcal {S}}_T(W,i,t))_j\) with \(\widehat{\mathcal {S}}_T(W,i,t){:}{=}\{S\in \mathcal {S}_T(W)\, |\, S_i\le t\}\) if t is assumed to be the latest possible start time of activity \(i\in V\). In Watermeyer and Zimmermann (2020), two algorithms have been introduced that are able to determine the minimal point of \(\widetilde{\mathcal {S}}_T(W,i,t)\) and the maximal point of \(\widehat{\mathcal {S}}_T(W,i,t)\), respectively.

figure c

The extension of the enumeration scheme is given in Algorithm 3. For each enumeration node a start time restriction W is stored in addition, so that each node is given by a triple \((\mathcal {C},S,W)\). At the beginning of the algorithm, \(W_i{:}{=}\{ ES _i,\ldots , LS _i\}\) for all \(i\in V\) ensures that all feasible schedules \(S\in \mathcal {S}\) are covered by the set of all W-feasible schedules in the root node, i.e., \(\mathcal {S}_T(W)\supseteq \mathcal {S}\). In the further course of the algorithm, recalling that \(W_i\) represents the domain of start time \(S_i\), all start times in \(T_i\) of some activity \(i\in \bar{\mathcal {C}}\) are limited to \(W_i\). Accordingly, each start time \(t\in T_i\) that is assigned to activity \(i\in \bar{\mathcal {C}}\) is assured to be an element of \(W_i\). In the branching step, in order to generate a descendant node \((\mathcal {C}',S',W')\), some start time \(t\in T_i\) is established as the earliest start time of activity \(i\in \bar{\mathcal {C}}\) by setting \(S'_i{:}{=}t\). Following, the earliest W-feasible schedule \(S'\) with \(S'\ge S\) and \(S'_i\ge t\) is determined. Since \(S=(\min W_i)_{i\in V}\) is assured at the start of each iteration, the earliest W-feasible schedule with \(S'\ge S\) and \(S'_i\ge t\) is obtained by \(S'{:}{=}\min \widetilde{\mathcal {S}}_T(W,i,t)\). If there is at least one scheduled activity \(j\in \mathcal {C}\) with \( ES _j(W,i,t)>S_j\) (\(S'_j>S_j\)), which implies that \(t> LS _i(W,j,S_j)\), start time t of activity i is not W-feasible. As a consequence, all activities \(j\in \mathcal {C}\) with \(S'_j>S_j\) have to be unscheduled, so that activity i can be scheduled W-feasible at start time t in case that \(t= ES _i(W,i,t)\) (\(S'_i=t\)). It should be noted that in general, due to the breaks in W, \(S'_i=t\) is not assured even if there is no scheduled activity \(j\in \mathcal {C}\) with \(S'_j>S_j\). Accordingly, it is only possible to schedule activity i W-feasible at time t if \(S'_i=t\).

The proof of the total correctness of the extended enumeration scheme is closely related to that of Algorithm 1. In Lemma 2, only the conditions \(S^f\in \mathcal {S}_T(W)\) for node \((\mathcal {C},S,W)\) and \(S^f\in \mathcal {S}_T(W')\) for its direct descendant node \((\mathcal {C}',S',W')\) have to be considered in addition. Based on this, the completeness of Algorithm 3 follows analogously to the proof of Theorem 1, while Lemma 3, which still applies to Algorithm 3, states the total correctness.

4.2 Lower bounds and consistency tests

In this section, we shortly present lower bounds and consistency tests that have been developed in Watermeyer and Zimmermann (2020).

The first lower bound is equal to the earliest time-feasible project termination if the start time restrictions of all activities are taken into account. The corresponding lower bound is given by \( LB0 ^\pi {:}{=} ES _{n+1}(W)\) with \( ES (W){:}{=}\min \mathcal {S}_T(W)\). The second lower bound \( LBD ^\pi \) is determined in a destructive way, meaning that a hypothetical upper bound on the project duration d is increased as long as it precludes any feasible solution (Brucker and Knust , 2003). To determine the destructive lower bound \( \mathrm LBD ^\pi \) in any node \((\mathcal {C},S,W)\), a binary search is conducted on some time interval \([ LB0 ^\pi , UB -1]\) with \( \mathrm UB \) as the best solution that has been found in the course of the BnB or \(\bar{d}+1\), otherwise. In each iteration, it is checked if the sum of the minimum possible consumptions \(\min \{r^c_{ik}(\tau )\, |\, \tau \in W_i\cap [ ES _i(W), LS _i(W,n+1,d)]\}\) over all activities exceeds the capacity of at least one resource k. In this case, there cannot be any feasible schedule with \(S_{n+1}\le d\), so that \(d+1\) is established as a lower bound for the binary search. Otherwise, \(d-1\) is set as an upper bound. This procedure continues until \( LBD ^\pi \) is determined, i.e., the lowest hypothetical upper bound on the project duration that does not preclude any feasible schedule.

In general, a consistency test establishes an implicit constraint of a problem if some specified condition is satisfied. For all consistency tests we consider, these implicit constraints are unary on the start time of some activity. Accordingly, each consistency test is described by a condition and a reduction rule on the start time restriction of some activity. In line with Dorndorf et al. (2000a), each of the following consistency tests can be interpreted as a function \(\gamma \) mapping any start time restriction W to an updated start time restriction \(W'{:}{=}\gamma (W)\) with \(W'_i\subseteq W_i\) for all \(i\in V\).

The first three consistency tests are based on the temporal constraints \(S_j\ge S_i + \delta _{ij}\) for all \((i,j)\in E\) of problem (P), so that they could be applied on any project scheduling problem independent on the considered resource type. The following two consistency tests are well known and have already been applied on project scheduling problems (see, e.g., Dorndorfet al.,  2000b; Alvarez-Valdes et al., 2008). The first (second) test is based on checking for some activity pair \((i,j)\in E\) if the currently lowest (greatest) possible start time \(\underline{W}_j{:}{=}\min W_j\) (\(\overline{W}_i{:}{=}\max W_i\)) of activity j (i) is consistent with the lowest (greatest) possible start time \(\min W_i\) (\(\max W_j\)) of activity i (j) with respect to time lag \(\delta _{ij}\). The corresponding conditions and reduction rules are given as follows:

$$\begin{aligned} \begin{array}{@{}l@{\quad }l@{\quad }l} \underline{W}_j < \underline{W}_i + \delta _{ij} &{}\Rightarrow &{} W_j {:}{=} W_j\, \setminus \, [0, \underline{W}_i+\delta _{ij}[ \\ \overline{W}_i > \overline{W}_j - \delta _{ij} &{}\Rightarrow &{} W_i {:}{=} W_i\, \setminus \, ]\overline{W}_j - \delta _{ij}, \infty [ \end{array} \end{aligned}$$

In this work, both tests are gathered under the term temporal-bound consistency test.

The next consistency test, which is also based on the temporal constraints of problem (P), checks for each possible start time of some activity whether there even exists any W-feasible schedule with this start time of the activity. One pass of the so-called temporal consistency test considers all start times in the start time restrictions over all activities. The corresponding condition and reduction rule for some start time \(t\in W_i\) of an activity \(i\in V\) is given by

$$\begin{aligned} \not \exists S\in \mathcal {S}_T(W):S_i=t\quad \Rightarrow \quad W_i{:}{=}W_i\setminus \{t\}. \end{aligned}$$

Next, we deal with consistency tests that take the resource constraints of problem (P) into account. All the following tests have in common that they check for each start time of some activity if its induced resource consumption and the minimum consumptions over all other activities exceed the capacity of at least one resource. The general condition is stated by

$$\begin{aligned} \exists k\in \mathcal {R}:r^c_{ik}(t) + \sum _{j\in V_k\setminus \{i\}} \min \{r^c_{jk}(\tau )\,|\, \tau \in W^r_j\} > R_k. \end{aligned}$$

The difference between the consistency tests is given by the determination of the possible start times \(W^r_j\) for the activities \(j\in V\setminus \{i\}\). For the resource-bound consistency test, \(W^r_j\) is given by the start time restriction, i.e., \(W^r_j{:}{=}W_j\). Extensions of the resource-bound consistency test are the so-called D-interval and W-interval consistency tests that restrict the number of start times in \(W^r_j\) by taking temporal constraints into account. While the D-interval consistency test considers \(W^r_j{:}{=}W_j\cap [t+d_{ij},t-d_{ji}]\), the W-interval consistency test restricts \(W^r_j\) even more by setting \(W^r_j{:}{=}W_j\cap [ ES _j(W,i,t), LS _j(W,i,t)]\).

4.3 Pruning the enumeration tree

In this section, we present two techniques that are able to reduce the set of schedules that are explored by a node in the course of the enumeration scheme. For both methods, the branching step of Algorithm 3 is extended by a procedure that reduces the start time domain of the branching activity. It should be noted that in contrast to methods that remove generated nodes, the following techniques prune parts of the enumeration tree by adding constraints to each node in the branching step to prevent that parts of the search tree are generated at all. In a first step we develop the two pruning techniques separately from each other. Afterward, we show that the combination of both methods ensures that each part of the time-feasible region is explored exactly once in the course of the enumeration scheme.

The first technique is based on the storage of the resource usage that is induced by the selected activity and its start time in the branching step as a lower bound for all possible start times of the considered activity. In order to apply the so-called usage-preserving technique (UPT), the branching step of the extended enumeration scheme is adapted as follows. Before start time \(t\in T_i\) is established as the earliest start time of some activity \(i\in \bar{\mathcal {C}}\) in line 15 of Algorithm 3, \(W'{:}{=}W\) is initialized and \(W'_i{:}{=}\{\tau \in W'_i\, |\, r^u_{ik}(\tau )\ge r^u_{ik}(t)\) for all \(k\in \mathcal {R}_i\}\) is set. Additionally, for all further operations in line 15, start time restriction W is replaced by \(W'\). Since the application of UPT in Algorithm 3 implies for any node \((\mathcal {C},S,W)\) and any schedule \(S'\in \mathcal {S}_T(W)\) that the conditions \(S\le S'\) and \(r^u_{jk}(S_j)\le r^u_{jk}(S'_j)\) for all \(j\in \mathcal {C}\) and all \(k\in \mathcal {R}_j\) are satisfied, Corollary 1 follows.

Corollary 1

Let UPT be used in Algorithm 3, let \(S^f\in \mathcal {S}\) be any feasible schedule, and \((\mathcal {C},S,W)\) some node corresponding to the enumeration scheme of Algorithm 3 with \(\mathcal {C}{\,\ne } V\) and \(S^f\!{\,\in \,}\mathcal {S}_T(W)\). Then there is at least one direct descendant node \((\mathcal {C}',S',W')\) that fulfills the condition \(S^f\in \mathcal {S}_T(W')\).

As a consequence of Corollary 1, noticing that \(\mathcal {S}_T(W')\subseteq \mathcal {S}_T(W)\) for some node \((\mathcal {C},S,W)\) and any of its descendants \((\mathcal {C}',S',W')\), precisely \(\mathcal {S}_T(W)\) is completely explored by enumeration node \((\mathcal {C},S,W)\) and all its descendants. In other words, there is no descendant node that explores a part of the time-feasible region \(\mathcal {S}_T\) that is not a part of \(\mathcal {S}_T(W)\). It should be noted that due to the unscheduling of activities this is not assured if UPT is not applied.

The second pruning technique is based on the consideration of the resource usages of all start times in the reduced scheduling set that are lower than the established earliest start time of the selected activity in the branching step. To apply the second pruning technique, the same extensions as for the first method are made in line 15 of Algorithm 3, except for the setting of \(W'_i\) that is replaced by \(W'_i{:}{=}\{\tau \in W'_i\, |\, \not \exists \tau '\in [0,t[\,\cap \, T_i: r^u_{ik}(\tau )\ge r^u_{ik}(\tau ')\) for all \(k\in \mathcal {R}_i\}\). Accordingly, the second method removes each start time \(\tau \) from \(W'_i\) if there is at least one start time \(\tau '\) in the reduced scheduling set \(T_i\) that is lower than t and satisfies \(r^u_{ik}(\tau )\ge r^u_{ik}(\tau ')\text { for all } k\in \mathcal {R}_i\). Since this implies for each start time \(\tau \in W'_i\) that there is at least one resource \(k\in \mathcal {R}_i\) with \(r^u_{ik}(\tau )<r^u_{ik}(\tau ')\) for each \(\tau '\in [0,t[\,\cap \,T_i\), we call this method usage-limitation technique (ULT).

In what follows, we investigate the application of both pruning techniques in Algorithm 3. For this, we consider two direct descendants \((\mathcal {C}',S',W')\) and \((\mathcal {C}'',S'',W'')\) of some node in the enumeration tree. In addition, we assume that both nodes \((\mathcal {C}',S',W')\) and \((\mathcal {C}'',S'',W'')\) are generated by establishing \(t'\) and \(t''\) with \(t'<t''\) as the earliest start time of the branching activity \(i\in \bar{\mathcal {C}}\), respectively. Considering the specifications of both pruning techniques to reduce the start time restriction of the branching activity, \(W'_i\cap W''_i=\emptyset \) is given. Since \(W'_i\cap W''_i=\emptyset \) directly implies \(\mathcal {S}_T(W')\,\cap \,\mathcal {S}_T(W'')=\emptyset \), Corollary 2 follows from Corollary 1.

Corollary 2

Let UPT and ULT be used in Algorithm 3, let \(S^f\in \mathcal {S}\) be any feasible schedule, and \((\mathcal {C},S,W)\) some node corresponding to the enumeration scheme of Algorithm 3 with \(\mathcal {C}\ne V\) and \(S^f\in \mathcal {S}_T(W)\). Then there is exactly one direct descendant node \((\mathcal {C}',S',W')\) that fulfills the condition \(S^f\in \mathcal {S}_T(W')\).

Taking \(\mathcal {S}_T(W')\subseteq \mathcal {S}_T(W)\) for some node \((\mathcal {C},S,W)\) and any of its descendants \((\mathcal {C}',S',W')\) into account, from Corollary 2 it follows that each candidate schedule is generated exactly once if both pruning techniques UPT and ULT are used. Furthermore, we can state that in the course of the enumeration, each part of the time-feasible region is explored exactly once, so that any redundancy is excluded.

5 Branch-and-bound algorithm

In this section we present the general framework of our BnB that enables a wide range of different settings concerned with the construction of the enumeration tree and the application of improving techniques. The first part of this section is devoted to the search strategy of our BnB that determines the way to construct the enumeration tree. In order to provide a generic framework for the construction of the search tree, in line with Watermeyer and Zimmermann (2020), we divide the search strategy in different parts, called traversing, branching, generation, and ordering strategy.

For the traversing strategy, which determines the node to be considered next in the course of the BnB, we have implemented two alternatives. The first alternative is the well-known depth-first search (DFS), while the second one is an extension of the DFS that has been introduced by Watermeyer and Zimmermann (2020). The so-called scattered-path search (SPS) selects after a predefined time span, among all not completely explored nodes with lowest search tree level, a node with the lowest bound on the project duration. After some node has been chosen to be explored next, the branching strategy determines the activity to be considered in the branching step. For this, in a first step, the so-called eligible set \(\mathcal {E}\subseteq \bar{\mathcal {C}}\), i.e., the set of all activities that could be used for the branching step, is determined. The first alternative takes all not currently scheduled activities into consideration (\(\bar{\mathcal {C}}\)), i.e., \(\mathcal {E}{:}{=}\bar{\mathcal {C}}\). In contrast, the other two alternatives that are both based on a strict order \(\prec \) in set V, reduce the set \(\bar{\mathcal {C}}\), where \(\mathcal {E}\subseteq \{i\in \bar{\mathcal {C}}\, |\, Pred ^{\prec }(i)\subseteq \mathcal {C}\}\) holds with \( Pred ^{\prec }(i)\) as the set of all direct predecessors of activity \(i\in V\) in a precedence graph \(G^{\prec }\) with V as the node set and the covering relation \(cr(\prec )\) of the strict order as the arc set. The strict orders we use in this work have been introduced as distance order (\(\prec _{\text { D}}\)) and cycle order (\(\prec _{\text { C}}\)) in Franck et al. (2001) and Neumann et al. (2003, Sect. 2.6). For further details we refer the reader to those references. In the following, we assume that the eligible set \(\mathcal {E}\) is given. Then in the next step of the branching strategy, the activity with the best priority value \(\pi _i\) and the lowest index in set \(\mathcal {E}\) is selected for the branching step. Accordingly the branching activity is given by

$$\begin{aligned} i{:}{=}\min \{i'\in \mathcal {E}\, |\, \pi _{i'}=\underset{h\in \mathcal {E}}{\text {ext}}\ \pi _{h}\}, \end{aligned}$$

where \(\text {ext}\in \{\text {min},\text {max}\}\) indicates if lower (min) or greater (max) priority values are preferred. In what follows, we present some priority rules that have shown promising results in preliminary tests. First, we deal with priority rules that have already been discussed in the literature (see, e.g., Kolisch,  1996; Franck et al., 2001) and are concerned with the temporal constraints of the problem. These include among others the latest start time rule (LST) with \(\pi _i=\textit{LS}_i\) and the slack time rule (ST) with \(\pi _i= LS _i- ES _i\). For both priority rules we have also tested dynamic versions that take the start time restrictions and the best found solution \( UB \) into account that are given by \(\pi _i= LS ^{ UB }_i(W)\) (LSTd) and \(\pi _i= LS ^{ UB }_i(W)- ES _i(W)\) (STd) with \( LS ^{ UB }_i(W){:}{=} LS _i(W,n+1, UB -1)\). Additionally, we have implemented a dynamic version of ST (STd\(^\text {I}\)) that considers the number of start times in the start time restriction by \(\pi _i=|W_i\cap [ ES _i(W), LS ^{ UB }_i(W)]|\). Further rules are given by the total successor rule (TS) with \(\pi _i=| \mathrm Reach ^\prec (i)|\) and \( \mathrm Reach ^\prec (i)\) as the set of all successors of activity \(i\in V\) in \(G^\prec \), the path following rule (PF) with \(\pi _i=l(i)\) and l(i) as the maximal number of nodes on any longest directed path from node \(i\in V\) to \(n+1\) in project network N, and the maximal resource consumption rule (MRC) with \(\pi _i=p_i\sum _{k\in \mathcal {R}_i} r^d_{ik}\). In contrast to the priority rules from the literature, the following rules make use of the properties of the partially renewable resources. For this, the maximal possible additional resource consumption \(p_i\,r^d_{ik}\) by an activity in relation to the maximal remaining resource capacity \(\bar{R}_k\) is considered with

$$\begin{aligned} \bar{R}_k{:}{=}R_k - \sum _{i\in V_k} \underline{r}^c_{ik}(W, \mathrm LS ^{ \mathrm UB }_i(W)) \end{aligned}$$

and \(\underline{r}^c_{ik}(W,d){:}{=}\min \{r^c_{ik}(\tau ){\,:\,}|{\,:\,} \tau {\,\in \,} W_i{\,\cap \,} [ ES _i(W),d]\}\). We have tested the following two different versions. The total maximal additional relative resource consumption rule (TMAR) with

$$\begin{aligned} \pi _i=p_i \sum _{k\in \mathcal {R}_i:\bar{R}_k\ne 0}\frac{r^d_{ik}}{\bar{R}_k}\ + \sum _{k\in \mathcal {R}_i:\bar{R}_k=0} 1, \end{aligned}$$

and the average maximal additional relative resource consumption rule (AMAR) with \(\pi _i=\pi '_i/|\mathcal {R}_i|\) and \(\pi '_i\) as the priority value of TMAR.

After the branching activity has been selected for some enumeration node, the last part of the search strategy is concerned with the generation and the ordering of the direct descendants. For the generation strategy, we distinguish between the possibilities either to generate all direct descendants (all) or to restrict the number of generated nodes by a maximal value (restr), where one and the same node must possibly be explored more than once. Furthermore, we have implemented different orders in which all start times in the reduced scheduling set \(T_i\) of branching activity \(i\in \mathcal {E}\) are considered. The most intuitive alternative for this takes always the lowest start time from \(T_i\) that has not been used so far to generate a direct descendant node (LT). The other alternative assigns a priority value \(\pi _{t}\) to each start time \(t\in T_i\) and considers all start times in \(T_i\) in an order of non-decreasing priority values (PV), where ties are broken on the basis of lower start times. In what follows, we present the best priority value we have found to order the start times in \(T_i\). The corresponding priority value

$$\begin{aligned} \pi _t=\sum _{k\in \mathcal {R}_i} a_{ikt} + \frac{1}{4}\max _{k\in \mathcal {R}_i} (b_{ik}) (t- ES _i(W)) \end{aligned}$$

with

$$\begin{aligned} a_{ikt}{:}{=}{\left\{ \begin{array}{ll} r^c_{ik}(t)/\bar{R}_k, &{} \text { if }\bar{R}_k\ne 0\\ 1, &{} \text { otherwise} \end{array}\right. } \end{aligned}$$

and

$$\begin{aligned} b_{ik}{:}{=}{\left\{ \begin{array}{ll} r^d_{ik}/\bar{R}_k, &{} \text { if }\bar{R}_k\ne 0\\ 1, &{} \text { otherwise} \end{array}\right. } \end{aligned}$$

is a combination of a priority value that is highly related to the TMAR rule and a penalty term that increases the priority value in a linear fashion based on the difference between start time t and the earliest W-feasible start time \( ES _i(W)\). Finally, after all direct descendant nodes have been generated, the ordering strategy determines the order in which they are considered in the further course of the BnB. In this work, all generated descendant nodes are explored in an order of non-decreasing lower bounds on the project duration (LB), which has shown to provide good results in computational experiments.

In accordance with Watermeyer and Zimmermann (2020), we apply three different sets of consistency tests in our BnB. Set \(\varGamma ^B\) contains the temporal- and resource-bound consistency test, \(\varGamma ^D\) the temporal-bound and D-interval consistency test, and \(\varGamma ^W\) the temporal and W-interval consistency test. \(\gamma ^\alpha _\beta (W)\) denotes the start time restriction that results if all consistency tests in \(\varGamma ^\beta \) are applied on W for \(\alpha \) iterations. \(\alpha =\infty \) implies that the fixed point corresponding to \(\varGamma ^\beta \) is determined. To be able to differentiate between the possibilities for the D-interval and W-interval consistency test to use all resources or only the resources that are demanded by activity i, we use the notations \(\gamma ^\alpha _\beta (W)[\mathcal {R}]\) and \(\gamma ^\alpha _\beta (W)[\mathcal {R}_i]\).

figure d

In what follows, we outline the framework of our BnB, which is given in Algorithm 4. It should be noted that in order to simplify the presentation, we assume that a depth-first search (DFS) is used and that all direct descendants of each enumeration node are generated at once (all). Accordingly, all other alternatives for the traversing and the generation strategy are omitted. In the first part of Algorithm 4, a preprocessing step is performed on the start time restriction W, for which we calculate the fixed point of set \(\varGamma ^W\) considering all resources, meaning that \(W{:}{=}\gamma ^\infty _W(W)[\mathcal {R}]\) is set. In case that the preprocessing step cannot prove the infeasibility (\(\mathcal {S}_T(W)\ne \emptyset \)), the global lower bound \( LB ^G\) is set to \(\min W_{n+1}\), the upper bound on the minimum project duration \( UB \) is set to \(\bar{d}+1\), and the root node is initialized and put on stack \(\varOmega \). In each iteration, an enumeration node \((\mathcal {C},S,W, LB )\) is removed from stack \(\varOmega \) and it is checked if it could provide a solution with a better project duration than \( UB \), i.e., \( LB < UB \). In this case, consistency tests from set \(\varGamma ^D\) or \(\varGamma ^W\) are applied on the start time restriction W. If the consistency tests can show that the considered node and all its descendants cannot generate any feasible schedule with a better project duration than \( UB \), i.e., \(\mathcal {S}^{ UB }_T(W){:}{=}\widehat{\mathcal {S}}_T(W,n+1, UB -1)=\emptyset \), the next enumeration node in \(\varOmega \) is considered. Otherwise, based on the branching strategy, the eligible set \(\mathcal {E}\) is determined and the branching activity \(i\in \mathcal {E}\) is selected, followed by the initialization of \(\varLambda \), which is used to store all direct descendants of the considered enumeration node. In the next step, analogously to Algorithm 3, \(\varTheta _i\) and the reduced scheduling set \(T_i\) are calculated. The start times in \(T_i\) are considered in an order depending on the generation strategy. Given some start time t that has been removed from \(T_i\), t is established as the earliest start time of the branching activity. It should be noted that line 19 of Algorithm 4 can be adapted as described in Sect. 4.3 to apply the pruning techniques UPT and ULT. After the initialization (and update) of start time restriction \(W'\), the consistency tests from set \(\varGamma ^B\) are applied on \(W'\). The direct descendant node corresponding to \(W'\) is directly pruned from the enumeration tree if \(\mathcal {S}^{ UB }_T(W')=\emptyset \). Otherwise, in case that the existence of any feasible schedule in \(\mathcal {S}_T(W')\) with a better objective function value than \( UB \) cannot be excluded, it is checked if some activities have to be unscheduled or if the branching activity can be scheduled. If \(\mathcal {C}'=V\) after the scheduling of the branching activity, a new best feasible solution \(S^*{:}{=}S'\) has been found, \( UB \) is set to \(S^*_{n+1}\), and all start times in \(T_i\) that are greater than t are removed, noticing that they cannot generate any better feasible solution. Otherwise, the lower bound \( LB '\) for the descendant node is calculated by \( LB0 ^\pi \) or \( LBD ^\pi \). In case that \( LB '< UB \), the node is added to the list \(\varLambda \), which is used after the generation of all direct descendant nodes to put them on the stack \(\varOmega \) in an order of non-increasing values of their lower bounds \( LB '\). The described procedure reiterates until there is no enumeration node left to be considered, i.e., \(\varOmega =\emptyset \). In case that \( UB =\bar{d}+1\) at the end of the algorithm, we can state that there is no feasible solution, while otherwise, Algorithm 4 returns an optimal solution \(S^*\).

6 Performance analysis

In this section, we evaluate the performance of our BnB. For this, we conduct computational experiments on different benchmark sets with partially renewable resources. To provide a comprehensive investigation, we compare our procedure with all available BnB from the literature for RCPSP/max-\(\pi \) and RCPSP/\(\pi \). In a second step, we derive a priority rule-based approximation method from our new enumeration approach and evaluate its performance in comparison with the associated BnB.

The computational experiments have been conducted on a workstation with an Intel Core i7-8700 CPU with a clock pulse of 3.2 GHz and 64 GB RAM under Windows 10 on a single thread. The algorithms were all coded in C++ and compiled by the 64-bit Visual Studio 2017 C++-compiler.

6.1 Comparison of branch-and-bound algorithms

In the first part of the performance analysis, we compare our constructive BnB (CBB) with all available exact solution procedures from the literature for partially renewable resources. In the second part, we derive a schedule-generation scheme from our new enumeration approach and compare its results with those of CBB.

6.1.1 General temporal constraints

In this section, CBB is compared with the relaxation-based BnB (RBB) from Watermeyer and Zimmermann (2020) on instances with general temporal constraints. To the best of our knowledge, RBB represents the only BnB for RCPSP/max-\(\pi \) that is available in the open literature so far. For the comparison of CBB with RBB, we have conducted computational studies on a benchmark set that covers instances with \(n=10,\) 20,  50,  100,  200 real activities, all of them with 30 partially renewable resources. The benchmark set UBO\(\pi \), which is available online,Footnote 1 is an adaptation of the well-known benchmark set UBO for RCPSP/max, which has been generated by the instance generator ProGen/max (Schwindt 1996, 1998). As described in Watermeyer and Zimmermann (2020), the test sets for RCPSP/max-\(\pi \), denoted by UBO\(n\pi \), were obtained by a replacement of the renewable resources by partially renewable resources that have been generated in accordance with the procedure in Schirmer (1999, Sect. 10).

Table 1 Settings for the performance analysis
Table 2 Performance of CBB and RBB (300 s)

Table 1 provides an overview of the settings we have used for CBB in the computational experiments depending on the instance size. The settings were determined by preliminary computational tests in the same way as for RBB in Watermeyer and Zimmermann (2020). Table 1 gives the settings that have shown the best balance between the number of solved instances and instances whose solvability statuses were determined among all settings we have tested. It should be noted that we have also analyzed the performance of both BnB that were conducted with only one setting over all instances of benchmark set UBO\(\pi \). The corresponding results are given in the supplementary material of this paper (Online Resource 1). While the most terms in Table 1 are in line with Sect. 5, there are some additional specifications, which are explained in the following. The values in brackets in Table 1 give the time span for the scattered-path search, the maximal number of generated nodes in one branching step for the generation strategy, and the maximal search tree level on which the sets of consistency tests are applied. The values in parentheses indicate if lower (min) or greater (max) priority values or lower bounds are preferred. As already mentioned, Table 1 lists the settings that have shown the best balance between the number of instances that were solved and whose solvability status remained open among all settings we have tested. From Table 1 it follows that the restriction of the eligible set for the branching step in accordance with strict orders (\(\prec _{\text { D}},\prec _{\text { C}}\)) is only beneficial for greater instances. Furthermore, the computational studies reveal that resource-based priority rules are preferable for small instances to select the branching activity, whereas temporal-based or network-based priority rules are better suited for greater instances. It is also worth mentioning that SPS and the usage of priority values for the generation of direct descendant nodes (PV) have both a great impact on the performance for greater instances. Finally, taking a look on the improving techniques, Table 1 shows that it is beneficial over all instances to use UPT and to calculate the fixed point \(\gamma ^\infty _B\) in each enumeration node, while additional procedures can enhance the performance just for a few test sets.

Table 3 Comparison of the feasible solutions of CBB with RBB (300 s)

Since for the greatest instances the improving techniques of CBB have shown to result in a significant increase in the number of instances whose solvability status could not be determined, we have implemented a warm-up phase (W). For this procedure, CBB is conducted with no improving technique for n/10 seconds, followed by CBB with the settings that are given in Table 1 (CBB+W).

Table 2 shows the performance of CBB and RBB. For the performance analysis, we have used a time limit of 300 seconds. The results for RBB are taken from Watermeyer and Zimmermann (2020), where RBB has been tested on the same workstation under the same conditions as CBB. In the third column, Table 2 gives the number of instances for which the earliest start time schedule \( ES \) is not optimal (#nTriv), so-called non-trivial instances in line with Alvarez-Valdes et al. (2008). Since trivial instances can efficiently be solved to optimality, they are excluded from all investigations in the remainder of this work. The following columns list for each test set the number of instances for which an optimal solution is found and verified (#opt), infeasibility is shown (#inf), a feasible solution is found (#feas), or the solvability status remains unknown (#unk). The next columns give the average percentage deviation of the determined upper bound \( UB \) from the earliest time-feasible project termination \( ES _{n+1}\) (\(\varDelta ^{\text {lb}}\)) and the average computing time (\(\varnothing ^{\text {cpu}}\)). The percentage deviation from \( ES _{n+1}\) is defined by zero for each instance that were shown to be infeasible. For comparison purposes both measures are given in relation to the number of all non-trivial instances. The last two columns provide the average computing time over all instances that were solved to optimality (\(\varnothing ^{\text {cpu}}_{\text {opt}}\)) and have been shown to be infeasible (\(\varnothing ^{\text {cpu}}_{\text {inf}}\)). Table 2 reveals a great dominance of CBB for test sets UBO20\(\pi \), UBO50\(\pi \), and UBO100\(\pi \), whereas RBB is able to solve test set UBO10\(\pi \) in less computing time. The results for test set UBO200\(\pi \) show that CBB+W also clearly dominates RBB, while CBB is not capable to determine the solvability status for all instances without the warm-up phase. It should be noted that this result gives an important implication for constructive approximation methods for RCPSP/max-\(\pi \) that redundancies should be maintained in the solution procedure for greater instances. Since CBB+W was only able to improve the performance for UBO200\(\pi \), the corresponding results for all other test sets are omitted. A closer look at the results shows that the intractability of the instances is strongly affected by a lower resource availability and a higher number of demanded resources per activity. These results are in line with general expectations, since the described characteristics increase the interdependence between the scheduling times of the activities. It should be noted that further performance tests with a time limit of 600 s showed that the gap between CBB and RBB over all test sets remained rather unchanged and that only a few more instances were solved by both procedures, respectively.

Table 4 Impact of components on the performance for test set UBO20\(\pi \) (300 s)
Table 5 Performance on the Böttcher benchmark set (300 s)

In order to evaluate the quality of the best found solutions by CBB for which the optimality could not be verified, Table 3 provides a comparison with the best solutions of RBB. For test set UBO200\(\pi \) the results of CBB+W are considered. The first part of Table 3 gives an overview about the number of instances for which a feasible solution has been found by at least one (#\(_{\text { feas}}^{{ \cup }}\)) or by both procedures (#\(_{\text { feas}}^{{ \cap }}\)), followed by the number of instances for which only CBB (#\(_{\text { feas}}^{\text { <}}\)) or RBB (#\(_{\text { feas}}^{\text { >}}\)) was able to find a feasible solution. For the test sets UBO20\(\pi \), UBO50\(\pi \), and UBO100\(\pi \), CBB is able to find a feasible solution for more instances than RBB, where there is no instance for which only RBB detects a feasible solution. In the second part of Table 3, the quality of the feasible solutions is compared with each other. The first column gives the number of instances for which both procedures have found a feasible solution, but not both procedures could verify the optimality for (#\(_{\text { feas}}^{{ \cap ,{\mathrm{nv}}}}\)). These instances are subdivided into the number of instances with a better (#\(^{{ <}}\)), an equal (#\(^{{ =}}\)), or a worse (#\(^{{ >}}\)) found solution by CBB compared to RBB. The last two columns are concerned with the average deviations of the best found project durations by CBB from those of RBB, which are assumed to be given by \(S^{\text { CBB}}_{n+1}\) and \(S^{\text { RBB}}_{n+1}\), respectively. In the first column, the average of the absolute deviation \(S^{\text { CBB}}_{n+1}-S^{\text { RBB}}_{n+1}\) over all considered instances is given (\(\varDelta ^{\text { abs}}_{\text { RBB}}\)), while the second column depicts the average of the relative deviation \((S^{\text { CBB}}_{n+1}-S^{\text { RBB}}_{n+1}) / S^{\text { RBB}}_{n+1}\) from the best found project duration by RBB (\(\varDelta ^{\text { rel}}_{\text { RBB}}\)). The second part of Table 3 shows that CBB obtains better feasible solutions for more instances than RBB over all test sets. Furthermore, the last two columns indicate a dominance of CBB in terms of a better solution quality.

Table 6 Performance on the SAV benchmark set (300 s)

In order to illustrate the impact of the improving techniques on the performance of CBB, Table 4 shows the results for test set UBO20\(\pi \) with a time limit of 300 seconds if the search strategy in accordance with Table 1 is applied with different combinations of the given improving techniques. In the first two lines, the results of CBB are given if it is conducted without any improving technique, except that the lower bound \(\textit{LB0}^\pi \) is calculated in any enumeration node, termed basic version in the following. To investigate the benefit to calculate the reduced scheduling set \(T_i\) in each branching step, in Table 4 the results of two different basic versions of CBB are listed that consider the start times in \(\varTheta _i\) or \(T_i\), respectively. In the following lines, the improving techniques from Table 1 are individually added to the basic version of CBB. The calculation of the reduced scheduling set as well as all improving techniques enhances the performance of CBB with a significant reduction in the average deviation \(\varDelta ^\text {lb}\) and computing time \(\varnothing ^\text {cpu}\).

6.1.2 Precedence constraints

In this section we investigate the performance of CBB on RCPSP/\(\pi \) benchmark sets. To evaluate the performance, CBB is compared with RBB and the only available BnB for RCPSP/\(\pi \) (BOT), which has been developed in Böttcher et al. (1999). Since the original code for BOT could not be provided to us, we have reimplemented BOT in line with Böttcher (1995) and Böttcher et al. (1999). As preliminary tests have shown, the best results for BOT are obtained if the feasibility bounds FB1 and FB2 as described in Böttcher et al. (1999) are used. Hence, we have applied both feasibility bounds in all computational experiments on BOT.

The first benchmark set contains 2160 instances with 10 real activities (P10\(\pi \)) and 250 instances with 15, 20, 25, and 30 real activities (P15\(\pi \), P20\(\pi \), P25\(\pi \), P30\(\pi \)), respectively. All of them were generated with 30 partially renewable resources. These test sets have been used in Alvarez-Valdes et al. (2006, 2008) for a performance analysis and were provided to them by the authors of Böttcher et al. (1999). Table 5 shows the results of an experimental performance analysis on the Böttcher benchmark set with a time limit of 300 seconds. For CBB and RBB we have used the settings of test set UBO20\(\pi \), except for test set P25\(\pi \), for which we have conducted the computational tests on CBB with the settings of test set UBO50\(\pi \). Table 5 shows that both CBB and RBB dominate BOT over all instances, while only small differences are given between CBB and RBB, except that RBB tends to show lower computing times.

The second RCPSP/\(\pi \) benchmark set was generated by Schirmer (1999) and was later extended by Alvarez-Valdes et al. (2006, 2008). The test sets of Schirmer (1999) cover 960 instances with 10, 20, 30, and 40 real activities (J10\(\pi \), J20\(\pi \), J30\(\pi \), J40\(\pi \)), respectively, with 30 partially renewable resources. Later, Alvarez-Valdes et al. (2006, 2008) added a test set with 960 instances, each of them with 60 real activities (J60\(\pi \)) and 30 partially renewable resources. It should be noted that 9 instances of test set J10\(\pi \), which have been proven to be infeasible in Schirmer (1999, Sect. 10.4), could not be provided to us, so that they are not part of the performance analysis. In the following, we summarize all instances from Schirmer (1999) and Alvarez-Valdes et al. (2006, 2008) under the term SAV benchmark set. In Table 6, the results of the computational tests on the SAV benchmark set with a time limit of 300 seconds are given. As for the Böttcher instances, we have used the settings of UBO20\(\pi \) for CBB and RBB for the computational experiments, with the only exception that CBB has been conducted with the settings of UBO50\(\pi \) for test set J60\(\pi \). Table 6 reveals that both CBB and RBB outperform BOT on the SAV benchmark set. Furthermore, Table 6 shows slightly better results for CBB compared to those of RBB.

Table 7 Performance of SGS on test sets UBO10\(\pi \), UBO20\(\pi \), and UBO50\(\pi \)

6.2 Schedule-generation scheme

The enumeration approach of CBB, which is based on a serial schedule-generation scheme (SGS), can directly be used as a framework for a priority rule-based approximation method. For this, in each branching step only one of the direct descendant nodes has to be chosen in accordance with a priority rule. In what follows, we investigate the performance of a regret-based biased random sampling method that makes use of a regret measure that has been introduced by Drexl (1991) and Drexl and Grünewald (1993).

Considering the extended enumeration scheme in Algorithm 3, each activity \(i\in \mathcal {E}\) and each start time \(t\in T_i\) that could be selected in a branching step is assigned a priority value \(\pi _i\) (\(\pi _t\)).Footnote 2 For simplicity, let \(\mathcal {D}\) be the set of all candidates for each selection and s some candidate (activity i or start time t). Then, in accordance with Kolisch (1996), each candidate s is assigned a regret value

$$\begin{aligned} \rho _s{:}{=}{\left\{ \begin{array}{ll} \max \limits _{h\in \mathcal {D}}\ \pi _h - \pi _s,&{} \text { if }\text {ext}=\text {min}\\ \pi _s - \min \limits _{h\in \mathcal {D}}\, \pi _h,&{} \text { if } \text {ext}=\text {max} \end{array}\right. } \end{aligned}$$

depending on whether lower (\(\text {ext}=\text {min}\)) or greater (\(\text {ext}=\text {max}\)) priority values are preferred and a selection probability

$$\begin{aligned} \psi _s{:}{=} \frac{(\rho _s + 1)^\alpha }{\sum \limits _{h\in \mathcal {D}} (\rho _h + 1)^\alpha }. \end{aligned}$$

The eligible set \(\mathcal {E}\) and the priority values for the start times are determined in accordance with the settings for CBB. Based on preliminary tests, parameter \(\alpha \) for the calculation of the selection probability \(\psi _s\) is set to \(\alpha =2\) for \(n=10\), \(\alpha =4\) for \(10 < n \le 30\), \(\alpha =16\) for \(30 < n \le 60\), and \(\alpha =32\) for all greater instances (\(n>60\)).

Table 8 Performance of SGS on test sets UBO100\(\pi \) and UBO200\(\pi \)

Table 7 shows the performance of SGS on test sets UBO10\(\pi \), UBO20\(\pi \), and UBO50\(\pi \) for \(Z=100\) and \(Z=1000\) iterations. In order to evaluate the impact of the reduced scheduling set \(T_i\), the results for SGS are given for the case that \(\varTheta _i\) or \(T_i\) is considered for the start time selection, denoted by SGS(\(\varTheta _i\)) and SGS(\(T_i\)). Additionally, the results for SGS(\(T_i\)) are provided if the resource-bound (RB) consistency test (+RB) or the RB consistency test with the pruning technique UPT (+UPT) is applied. For comparison purposes, in the last row for each test set the results for CBB are given. The computational studies were conducted on all non-trivial instances that could not be shown to be infeasible by CBB (#inst). \(\varDelta ^\text {lb}\) and \(\varnothing ^\text {cpu}\) are given in relation to these instances, while \(\varDelta ^{\mathrm{CBB}}\) represents the average percentage deviation of the best found solution by SGS from the shortest project duration that has been determined by CBB in relation to the number of instances for which SGS was able to find a feasible solution. For this, it should be noted that all instances, for which SGS was able to determine a feasible solution, were feasibly solved by CBB as well. Finally, the last measure is given by the number of instances for which SGS was not able to find a feasible solution (#nfeas).

Table 7 shows the best results for SGS that were obtained among all priority rules for the activity selection that are described in Sect. 5. The corresponding priority rules that have been applied on test sets UBO10\(\pi \), UBO20\(\pi \), and UBO50\(\pi \) are, respectively, given by LST, LSTd, and STd\(^\text {I}\) with \(\text {ext}=\text {min}\). It can be seen from Table 7 that the calculation of the reduced scheduling set \(T_i\) always results in a better performance for SGS and that the RB consistency test is able to improve the solution procedure, but with a significant greater impact on test sets UBO10\(\pi \) and UBO20\(\pi \). This observation might be explained by the reduction of the start times that are not part of any feasible solution by the RB consistency test whose effectiveness seems to increase if less possible start times are considered. In contrast, the additional application of the pruning technique UPT could only obtain better results for small instances, while the number of instances for which no feasible solution was determined is getting greater for test set UBO50\(\pi \). The negative impact of UPT might be assumed to be caused by the reduction of redundancies that tend to increase the probability for unfavorable scheduling decisions if the number of activities is getting greater. The comparison with CBB reveals that SGS performs only reasonable on small instances (UBO10\(\pi \), UBO20\(\pi \)) if the improving techniques are applied, while the best solutions for test set UBO50\(\pi \) (+RB) deviate more than 16% on average from the solutions of CBB even if \(Z=1000\) iterations are conducted.

Due to the significant increase in the computing time, Table 8 provides the results of SGS on test sets UBO100\(\pi \) and UBO200\(\pi \) for \(Z=10\) and \(Z=100\) iterations. The priority rules ST and STd with \(\text {ext}=\text {min}\) were applied on the test sets UBO100\(\pi \) and UBO200\(\pi \), respectively. In accordance with the results for test set UBO50\(\pi \), the application of UPT leads to an increase in the number of instances for which SGS is not able to determine a feasible solution. Furthermore, the RB consistency test can at most slightly improve the performance, while the advantage of the reduced scheduling set \(T_i\) even tends to increase for greater instances. The best solutions of SGS clearly deviate from the shortest project durations determined by CBB on average, so that SGS seems to be not well suited to solve large instances.

The results of SGS on the Böttcher and SAV benchmark set show similar trends as for the test sets UBO10\(\pi \) and UBO20\(\pi \). For details, we refer the reader to the supplementary material of this paper.

In conclusion, SGS shows a reasonable performance on small instances if the RB consistency test and the pruning technique UPT are applied, while the procedures lack to improve the performance for greater instances, which might be assumed to be caused by the increase in the number of possible start times in each scheduling step. In our opinion, a promising way to improve the performance of SGS on greater instances might be to implement procedures that store information about the decisions that were made in previous iterations. One way for this might be given by adapting the construction procedure of the search tree that has been presented for CBB.

7 Conclusions

We have presented a branch-and-bound algorithm (BnB) for the resource-constrained project duration problem with partially renewable resources and general temporal constraints (RCPSP/max-\(\pi \)) that is based on a serial schedule-generation scheme. For the first time it has been shown that it is sufficient to consider only a subset of all resource-feasible start times in each branching step. By an extension of the enumeration scheme by start time domains, improving techniques from the literature could be included. Furthermore, we were able to devise new pruning techniques to prevent redundancies with a significant impact on the performance.

In a comprehensive experimental performance analysis we have compared our exact solution procedure with all BnB that are available in the open literature for partially renewable resources. The computational experiments could reveal a great dominance of our BnB for RCPSP/max-\(\pi \). The favorable performance could also be confirmed for instances that are restricted to precedence constraints with significant better results compared to the only available BnB for RCPSP/\(\pi \). In a second step, we investigated a directly derived schedule-generation scheme from our new enumeration approach. It has been shown that the approximation procedure obtains reasonable results for small instances, while a limitation for large instances became apparent.

As the computational experiments have shown, the performance of a BnB for RCPSP/max-\(\pi \) is strongly influenced by the way to enumerate the candidate solutions. Therefore, the investigation of further enumeration schemes seems to be a promising field for future research. Moreover, the experiments could demonstrate that there is a great need for new types of approximation methods that goes beyond classical priority rule-based generation schemes.