# **ADAPTRA:** Straggler-Resilient Hybrid-Parallel Training with Pipeline Adaptation

Tianyuan Wu<sup>†</sup>,<sup>\*</sup> Lunxi Cao<sup>†</sup>,<sup>\*</sup> Hanfeng Lu<sup>†</sup>, Xiaoxiao Jiang<sup>†</sup>, Yinghao Yu<sup>§</sup>, Siran Yang<sup>§</sup>, Guodong Yang<sup>§</sup>, Jiamang Wang<sup>§</sup>, Lin Qu<sup>§</sup>, Liping Zhang<sup>§</sup>, Wei Wang<sup>†</sup> <sup>†</sup>Hong Kong University of Science and Technology <sup>§</sup>Alibaba Group

#### Abstract

arXiv:2504.19232v1 [cs.DC] 27 Apr 2025

Training large Deep Neural Network (DNN) models at scale often encounters straggler issues, mostly in communications due to network congestion, RNIC/switch defects, or topological asymmetry. Under advanced pipeline parallelism, even minor communication delays can induce significant training slowdowns. This occurs because (1) slow communication disrupts the pipeline schedule, creating cascading "bubbles" in a domino effect, and (2) current GPU kernel scheduling is susceptible to head-of-line blocking, where slow communication blocks subsequent computations, further adding to these bubbles. To address these challenges, we present ADAPTRA, a straggler-resilient training system with two key optimizations. First, it optimally adapts the pipeline schedule in the presence of stragglers to absorb communication delays without inducing cascading bubbles, using a simple yet effective algorithm guided by an analytical model. Second, upon detecting slow communication, ADAPTRA offloads communication operations from GPU to host memory and utilizes CPU-side RDMA for data transfer. This eliminates head-of-line blocking as subsequent computation kernels can be scheduled immediately on GPUs. Together, these optimizations effectively reduce pipeline stalls in the presence of communication stragglers, improving the training iteration time by  $1.2-3.5 \times$  in our experiments under various settings.

## 1 Introduction

The rise of large Deep Neural Network (DNN) models has ushered in the golden age of Artificial Intelligence, leading to breakthroughs in applications that would have been considered science fiction even a few years ago [1,14,32,42,46,50]. Training large DNN models typically requires combining tensor, data, and pipeline parallelism strategies across thousands of GPUs [21, 30, 40, 52], where providing high-throughput, low-latency communication is critical to enhancing the training performance [5, 10, 26].

However, at this scale, communication stragglers, manifested as slow links with extended pairwise transmission delays, are frequent [11, 34] and can have a significant performance impact [8, 35, 48]. Particularly in multi-tenant environments, jobs occupying a large number of GPUs frequently



Figure 1: GPT-2 14B training performance on 8 nodes (one H800 GPU per node) with 8-stage PP, where minor communication delays between PP stages trigger dependency bubbles and blocking stalls, causing significant slowdowns in 1F1B and ZeroBubble (ZB) pipelines.

suffer from communication-induced slowdowns during life cycles [5,48]. These stragglers originate predominantly from transient network congestion [5,48] but can also persist due to hardware defects (e.g., RNIC or switch failures) or network topological asymmetry [49]. The presence of communication stragglers, even on a single link, slows down the entire training job due to frequent synchronizations necessitated by hybrid-parallelism strategies, causing up to 90% throughput degradation in production clusters [8,35,48].

Production systems mainly focus on detecting communication stragglers in large-scale training [5, 8, 11, 48] and rely on traffic load balancing at flow or packet level to alleviate network congestion [3, 9, 13, 23]. However, these approaches are *agnostic* to the parallelism strategies of the training job and cannot effectively mitigate the straggler impacts on job performance. As illustrated in Figure 1, with pipeline parallelism (PP), even minor communication delays between two PP stages can result in significant training slowdowns, which grow rapidly as the delay increases. Our study identifies two issues that contribute to this large slowdown, with their impacts shown in Figure 1.

First, given sophisticated data dependencies in a PP schedule (e.g., Gpipe [17], 1F1B [29] and ZeroBubble [33]), a single communication straggler, when exceeding a certain threshold, can set off a domino effect, triggering *cascading bubbles* (i.e., GPU idle periods) that propagate across subsequent stages (Figure 5-bottom). These bubbles, which we call *dependency bubbles*, cause severe misalignment within the pipeline, disrupting its entire schedule.

Second, existing GPU kernel scheduling is susceptible to

<sup>\*</sup>Equal contribution.

| Execution Plan: [F1, Send-F1, F2, Send-F2, F3, Send-F3, F4,] |                 |           |       |                                                  |       |      |     |      |     |      |      |
|--------------------------------------------------------------|-----------------|-----------|-------|--------------------------------------------------|-------|------|-----|------|-----|------|------|
| Comm                                                         | w/o comm. delay |           |       | I w/ comm. delay                                 |       |      |     |      |     |      |      |
| Stream                                                       | F1              | F2 F3     | F4    |                                                  | F1    | F2   | BS2 | F3   | BS4 | F4   |      |
|                                                              |                 | Send-F1   |       |                                                  |       | Send | -F1 |      |     |      |      |
| Comm.                                                        |                 | Send      | -F2   | i                                                |       |      | BS1 | Send | -F2 |      |      |
| Streams                                                      |                 |           | Send- | F3 I                                             |       |      |     |      | BS3 | Send | I-F3 |
|                                                              |                 |           |       |                                                  |       |      |     |      |     |      |      |
| Blockin                                                      | g Stalls        | Blocked K | ernel | Root                                             | Cause |      |     |      |     |      |      |
| BS1&3                                                        | Send-F2&F3      |           |       | Queuing: the previous comm. kernel not finished. |       |      |     |      |     |      |      |
| BS2&4                                                        |                 | F3&F4     |       | It is blocked by its predecessor comm. kernel.   |       |      |     | el.  |     |      |      |
|                                                              |                 |           |       |                                                  |       |      |     |      |     |      |      |

Figure 2: Head-of-line blocking due to sequential kernel scheduling: slow comm. blocks subsequent comp.

*head-of-line blocking*, where slow communication can block subsequent computation. To illustrate this, we refer to Figure 2. Once a PP schedule is determined, a low-level kernel execution plan is generated accordingly, in which communication and computation operations are interleaved to overlap communication latency (e.g., F1, Send-F1, F2, Send-F2, ...). The GPU scheduler *sequentially schedules* operations following this plan. However, in the presence of a slow link, a communication operation cannot be scheduled immediately as previous communication operations are still queued up, pending for transmission. This blocks the scheduling of subsequent computation operations, introducing additional *blocking stalls* to the pipeline (Figure 2-right), which in turn triggers more bubbles, further aggravating training slowdowns.

Eliminating dependency bubbles and blocking stalls requires dynamically adapting the pipeline schedule with framework support, which remains lacking in existing systems. For instance, Falcon [48] simply reassigns slow links from communication-heavy DP groups to communication-light PP groups, without addressing subsequent pipeline bubbles. Recycle [12] and Oobleck [19] pre-compute a pipeline reconfiguration plan for handling GPU failures. However, communication stragglers cannot be addressed using a pre-computed plan as pipeline adaptation must be made dynamically based on the changing straggler magnitude.

In this paper, we present ADAPTRA, a straggler-resilient system for efficient hybrid-parallel training. It addresses dependency bubbles and blocking stalls caused by slow communications with two key designs.

**Straggler-resilient pipeline adaptation.** We show analytically that a pipeline schedule (e.g., 1F1B [29] or ZeroBubble [33]) can tolerate slow communication up to a certain threshold without triggering cascading bubbles in a domino effect. This threshold is in proportion to the *slackness* between adjacent PP stages, defined as the *difference of the number of forward operations* scheduled in the two stages during the warm-up phase. Larger slackness enhances the pipeline's resilience to a longer communication delay. Based on this, ADAPTRA initially generates a ZeroBubble schedule [33] that maximizes the minimum inter-stage slackness under memory and configuration constraints. It then monitors communication delays between PP stages. When the delay exceeds the tolerance threshold (given by our analytical model),

it quickly reacts by adapting the pipeline schedule to increase the inter-stage slackness of the slow link, eliminating all or most straggler-induced dependency bubbles.

Decoupled data plane. ADAPTRA further employs a fullydecoupled data plane to address head-of-line blocking of GPU kernel scheduling and the resulting blocking stalls. Upon detecting communication stragglers, the system transparently switches to a delegation mode, in which it offloads PP communications from GPU to host memory and uses dedicated delegate processes to perform data transfer via CPU-side RDMA. ADAPTRA chooses to bypass the more efficient GPU-direct RDMA due to three design imperatives. First, it completely decouples PP communications from GPU execution, preventing slow communication from blocking subsequent GPU computations. Second, optimally adapting pipeline schedule in the presence of stragglers may require storing more activations than GPU memory can hold, where offloading to host memory becomes necessary. Third, given that PP schedule only requires light to moderate communications (compared to DP and TP), the performance overhead introduced by offloading can be minimized with system-level optimizations. This design additionally enables RNIC fault tolerance: upon detecting a RNIC failure, the system reroutes traffics through remaining healthy RNICs via the delegation path, obviating the need for checkpoint-and-restart failovers.

We implemented ADAPTRA on top of the Megatron-LM [30,40] training framework, using ZeroBubble [33] as the base pipeline schedule to achieve the best performance. We evaluated ADAPTRA using GPT-2 models of varying sizes, from 7B to 140B parameters, on H800 clusters. Compared to state-of-the-art straggler mitigation solutions, ADAPTRA reduces the average training iteration time by  $1.2-3.5 \times$  under various network latency conditions. In a large-scale deployment involving 128 H800 GPUs, ADAPTRA consistently delivers high training throughput in the presence of frequent communication stragglers, outperforming the baselines by  $1.41 \times$  while resilient to RNIC failures.

## 2 Background and Motivation

#### 2.1 Hybrid-Parallel DNN Training

The increasing scale of Deep Neural Networks (DNNs), driven by empirical scaling laws [22], has led to state-ofthe-art models with hundreds of billions of parameters [1, 11, 14, 26, 38, 42, 50]. Training such large models requires high-performance computing (HPC) clusters comprising tens of thousands of GPUs [21, 30, 34], leveraging advanced parallelization strategies in three primary forms.

**Data parallelism (DP)** distributes identical model replicas across GPU groups, with each replica processing a subset of the input data (mini-batches) concurrently [30, 36, 40]. Synchronization is performed at the end of each iteration via all-reduce operations, often spanning multiple GPU nodes interconnected through high-speed networks such as RDMA over Infiniband (IB) [13,21,34].

**Tensor parallelism (TP)** partitions individual tensors (e.g., weight matrices) within model layers across multiple GPUs [40,52]. While this technique parallelizes linear algebra operations within layers, it incurs significant communication overhead due to frequent reduce-scatter and all-reduce operations during forward and backward passes. Consequently, TP is typically restricted to single-node deployments with high-bandwidth GPU interconnects (e.g., NVLink).

**Pipeline parallelism (PP)** divides the model into sequential layer groups (*stages*) assigned to different GPUs [17, 30, 52]. Mini-batches are further split into micro-batches that flow through these stages in a pipelined manner, enabling parallel processing across stages. PP requires lower network bandwidth than DP/TP by communicating only activations and gradients at layer boundaries. However, it can suffer from reduced training throughput due to pipeline dependencies and bubbles (idle slots) as the number of stages increases. Modern PP implementations like 1F1B [29] and ZeroBubble (ZB) [33] address these issues, with ZB achieving bubble-free execution at the expense of increased memory footprint.

#### 2.2 Reliability Issues

Training large DNN models over extended periods face reliability challenges, primarily manifested through *crash failures* and still-functioning but slow *stragglers* [8, 11, 19, 21, 47, 48, 50]. These issues stem from hardware failures, software errors, or resource contention, with even a single affected component disrupting the entire distributed training.

**Crash failures.** Crash failures have been extensively analyzed in recent studies [11, 12, 16, 19, 20, 28, 44, 47, 49]. Meta and ByteDance report that faulty GPUs and RNICs are the leading causes, accounting for 40% and 10% of failures, respectively [11, 16]. To address this, researchers have developed *fault-resilient solutions* for hybrid-parallel training, including (1) optimized checkpoint-and-restart mechanisms to minimize recovery overhead [28, 47] and (2) exploiting PP's functional redundancy to reduce checkpointing [12, 19, 44].

**Stragglers.** Stragglers—manifested as slow computation or communication—represent another major reliability concern in large-scale DNN training [8, 11, 48]. Prior studies [21, 48] indicate that *computation stragglers*, typically caused by GPU thermal throttling or hardware defects, are relatively rare ( $\sim 0.5\%$  occurrence) and short-living (usually recovering in 10 minutes). These incidents can be efficiently addressed by adjusting the parallelization of GPU devices [24, 48]. In contrast, *communication stragglers*, predominantly due to network congestion, are more frequent and persistent, often lasting for hours [5, 48]. In Alibaba's production multi-tenant clusters, over 36% of jobs using >50% GPUs experience slow-



Figure 3: Iteration time growth under different per packet delays, where DP is more communication-sensitive to PP.

downs from communication issues [5]. In extreme cases, such stragglers can reduce training throughput by up to 90% [48].

Communication stragglers may occur on cross-node links between DP groups (DP straggler) or between PP stages (PP straggler), but not in TP groups, as TP communications are confined to intra-node, high-bandwidth, and stable NVLinks [5,48]. Compared to PP stragglers, DP stragglers can have a more pronounced impact on performance, as DP's all-reduce operations incur substantial communication costs and are bottlenecked by the slowest link in the all-reduce ring [6, 15, 24, 48, 54].

To illustrate this effect, we train a GPT2-7B model on 8 nodes (each with one H800 GPU) by configuring a (2 DP, 4 PP) ZeroBubble pipeline using Megatron-LM [30]. We manually inject a per-packet delay of 0.125/0.25/0.375 ms (corresponding to 10/20/30 ms inter-PP stage latency) into a designated cross-node link (400 Gbps IB). As shown in Figure 3, when this link is part of the DP communication group, iteration time increases by up to  $8.04 \times .$  In contrast, when the same link is assigned for PP communication, the slowdown is limited to  $\leq 2.24 \times .$  Motivated by these findings, recent work [48] proposes mitigating DP stragglers by reconfiguring the parallelization scheme to assign slow links to PP stages instead of DP groups. While this approach effectively converts a DP straggler to a PP straggler, it still results in significant slowdowns, which remain open to address.

#### **3** Impact Analysis and Challenges

In this section, we systematically investigate how inter-stage communication stragglers lead to substantial pipeline stalls. Our investigation focuses on ZeroBubble (ZB) pipeline scheduling [33]—a generalized, fine-grained PP scheduling scheme that subsumes common approaches like 1F1B [29] as special cases. As illustrated in Figure 4, ZB eliminates pipeline bubbles by decomposing backward pass into two independent operators, backward input (*B*) and backward weight (*W*), then precisely orchestrating their execution. This generalized design encapsulates diverse pipeline behaviors, ensuring the broad applicability of our findings. In the following, we identify two critical delay propagation mechanisms: (1) domino effect of cascading bubbles due to PP's vulnerable dependency chains (§3.1) and (2) head-of-line blocking stalls due to sequential GPU kernel scheduling (§3.2).



Figure 4: An ideal straggler-free ZeroBubble [33] pipeline with 4 stages and 12 microbatches, completing in 390 ms.

#### **3.1** Domino Effect of Cascading Bubbles

Pipeline parallelism orchestrates stage execution with strict data dependencies. In ZB scheduling, these dependencies manifest through two key constraints: (1) a forward operator ( $F_j$ ) in stage  $S_i$  requires completion of  $F_j$  in preceding stage  $S_{i-1}$ ; (2) backward operators  $B_j$  and  $W_j$  in  $S_i$  must be scheduled after  $B_j$  completion in subsequent stage  $S_{i+1}$ . The presence of communication stragglers between stages  $S_i$  and  $S_{i+1}$  introduces additional latency  $c_i$ , with two immediate impacts: (1) forward operators  $B_j$  and  $W_j$  in  $S_i$  must follow the completion of  $B_j$  in  $S_{i+1}$  plus the delay  $c_i$ .

We quantify the straggler impacts on pipeline schedules through simulations of a 4-stage pipeline processing 12 microbatches, with uniform operator execution time (F = B = W =10 ms). Figure 4 shows the ideal straggler-free ZB schedule completing in 390 ms with zero bubbles. Figure 5 depicts the resulting schedules in the presence of communication delays of 10 and 20 ms between stages 0 and 1. A 10 ms delay introduces a linear slowdown, extending the execution time from 390 to 400 ms. However, further increasing the delay to 20 ms results in a *non-linear growth* of pipeline stall to 440 ms. This occurs because the 20 ms delay pushes the first backward  $B_1$  and subsequent  $F_8$  in  $S_0$  back to t = 110 ms, creating a bubble in  $S_1$ . This bubble propagates downstream, triggering cascading pipeline stalls in subsequent stages.

Extending our analysis, Figure 8 examines various ZB pipelines with different slackness parameters  $\Delta_i$  (defined in §4.1). For each pipeline schedule, we gradually increase the communication delays between adjacent stages and depict in Figure 8 the resulting pipeline delays (left) and bubble rates (right). These results empirically demonstrate that localized communication delays exceeding a certain threshold create cascading dependency bubbles in a domino effect, leading to significant global pipeline stalls.

## 3.2 Head-of-Line Blocking Stalls

Communication stragglers further degrade pipeline performance through low-level GPU kernel scheduling anomalies, manifested as *head-of-line blocking stalls*. To demonstrate this problem, we conduct a GPT2-7B training experiment



Figure 5: ZeroBubble schedule under  $c_0 = 10/20$  ms delay between stage 0 and 1. Increasing  $c_0$  from 0 to 10 ms only prolongs iteration time T by 10 ms, while an additional 10 ms delay introduces a 40 ms growth in T.

across four nodes (one H800 GPU per node), under a ZB schedule of(1 TP, 1 DP, 4 PP). We inject a 30 ms delay between PP stages 0 and 1 using NCCL network plugin. Figure 6 illustrates the profiled kernel execution result using NVIDIA Nsight Systems [31].

**Blocking stalls.** Given a pipeline schedule, a training framework (e.g., Megatron-LM [30], TorchTitan [25]) generates a *fixed execution plan* that interleaves computation (F, B, W) and communication operations, including send/recv-forward (SF/RF) and send/recv-backward (SB/RB). This execution plan maximizes computation-communication overlap through a carefully ordered operation scheduling sequence (e.g.,  $[F_1, SF_1, F_2, SF_2, ...]$  in Figure 6). The kernel scheduler sequentially launches these operations following this predetermined order. However, delayed communication operations stall subsequent computation operations, creating unexpected bubbles. In Figure 6, the delayed  $SF_2$  blocks the launching of  $F_4$  in stage 0, despite it being ready to execute after  $F_3$ .

Root cause analysis. Blocking stalls arise when NCCL's transmission queue fills, which may disrupt CUDA's asynchronous execution. This is because each NCCL send/recv launches a GPU kernel to enqueue data transfers, which are handled asynchronously by a dedicated backend thread. Under slow links, the queue builds up as pending transfers outpace actual data transmission. The launching of subsequent communication kernels (e.g., SF<sub>3</sub>) hence blocks-they do not return control to the kernel scheduler until the queue space becomes available. This in turn prevents the CUDA scheduler from launching following computation kernels (e.g.,  $F_4$  is blocked until  $SF_3$  returns control, which itself waits on  $SF_2$ ), thus creating head-of-line (HOL) blocking stalls in computation. Notably, CUDA multi-streaming fails to mitigate this issue because all streams within a GPU context share the same NCCL communicator and transmission queue.



Figure 6: Slow communication  $(SF_2)$  induces HOL blocking stalls  $(F_4)$  due to sequential GPU kernel scheduling.

# 3.3 Which Layer to Optimize?

Our analysis reveals that communication stragglers degrade pipeline performance through two mechanisms: dependency bubbles and HOL blocking stalls (see Figure 1 for quantitative contributions). Addressing these issues requires careful considerations of optimization layers within the system stack.

**Network-level optimizations**, such as ECMP [3, 13, 43] or packet spraying [9, 23], balance traffic at the flow or packet level. While effective for general congestion reduction, these approaches are *agnostic* to training semantics (e.g., parallelism strategies and communication patterns) and cannot prioritize critical communications over less sensitive transfers, nor can they address HOL blocking stalls. Also, even state-of-the-art load balancing techniques cannot eliminate network congestion, especially in multi-tenant clusters [2, 5].

Effective straggler mitigation requires framework-level optimizations, leveraging training semantics such as pipeline schedule, operator dependencies, and communication patterns. This semantic insight enables targeted mitigation strategies, such as pipeline adaptation and blocking-free kernel scheduling-none of these can be implemented in the network layer. However, existing reliability enhancement mechanisms for training frameworks are ineffective in addressing communication stragglers under pipeline parallelism. For instance, Malleus [24] exclusively targets computation stragglers without considering slow communications. XPUTimer [8] provides production-grade straggler detection yet lacks integrated mitigation mechanisms. Falcon [48] reassigns slow links from DP groups to PP stages, but fails to resolve resulting PP stragglers. Recycle [12] and Oobleck [19] rely on static pipeline reconfiguration plans to handle GPU failures, lacking adaptability to dynamic network conditions.

# 4 Straggler-Resilient Pipeline Adaptation

ADAPTRA is a system that effectively mitigates communication stragglers for hybrid-parallel training with two key designs: (1) a straggler-resilient pipeline adaptation algorithm that dynamically adapts the pipeline schedule to minimize dependency bubbles (§3.1), and (2) a fully-decoupled data plane eliminating HOL blocking stalls (§3.2).

| Notation   | Explanation                                         |
|------------|-----------------------------------------------------|
| Si         | The <i>i</i> <sup>th</sup> pipeline stage.          |
| S          | Total number of pipeline stages.                    |
| Ν          | Total number of microbatches.                       |
| t          | Execution time of a single operation $F/B/W$ .      |
| $c_i$      | Communication latency between $S_i$ and $S_{i+1}$ . |
| Т          | The overall pipeline execution time.                |
| $x_i$      | Number of warm-up forwards in stage $S_i$ .         |
| $\Delta_i$ | Slackness between stages $S_i$ and $S_{i+1}$ .      |
| δ          | Simulator's time step size.                         |

Table 1: Notations in the quantitative analysis and algorithms.

In this section, we describe the first design component, the pipeline adaptation algorithm, where *we assume no HOL blocking stalls*—which is guaranteed by our second design in §5. We first analytically quantify the accumulated pipeline delays caused by a slow link between PP stages (§4.1). Driven by this analytical result, we design the pipeline adaptation algorithm, including warm-up scheduling (§4.2) and full pipeline scheduling (§4.3). Key mathematical notations are summarized in Table 1 to guide subsequent analysis.

#### 4.1 Quantitative Delay Analysis

**Key insight.** In §3.1, we empirically demonstrate that communication delays exceeding a certain threshold induce disproportionately significant pipeline stalls through cascading bubbles. We further develop an analytical model to quantify this effect. Our analysis identifies the *slackness* of a pipeline as the key structural resilience to communication delays, informally defined as *the difference of the warm-up forward counts in two adjacent stages*. Intuitively, the more warm-up forward operators the pipeline schedules in stage  $S_i$  than in  $S_{i+1}$ , the larger slackness it provides between the two stages, which can be utilized to "absorb" more dependency bubbles caused by inter-stage communication delays.

Analysis. To prove this result, we base our analysis on ZeroBubble (ZB) pipeline scheduling, as it is a more generalized design encapsulating common approaches like 1F1B as special cases without backward weight (W) costs. Our analytical findings are hence broadly applicable to 1F1B and other pipeline scheduling approaches.

In a ZB schedule, each pipeline stage operates through three phases (Figure 4): (1) the **warm-up phase** containing a configurable number of forward-only (*F*) operations, (2) the **steady phase** containing a mixture of forward (*F*), backward input (*B*), and backward weight (*W*) operations, and finally (3) the **cool-down phase** containing the remaining backward weight (*W*) computations. For ease of presentation, we assume all three operations *F*, *B* and *W* have a uniform execution time ( $t^F = t^B = t^W = t$ ). Nonetheless, our analysis extends to a more general heterogeneous setting. Let  $x_i$  be the number of forward operations scheduled in stage  $S_i$  during the warm-up phase, aka *warm-up forward count*. The following lemma shows that  $x_i$  is monotonically decreasing, with the proof given in the Appendix.



Figure 7: Analysis of accumulated pipeline delay with  $\Delta_i = 2$ .

**Lemma 1** (Monotonic warm-up) For any pipeline schedule, the warm-up forward count is non-increasing over stages, i.e.,  $x_i \ge x_{i+1}$  for all i = 0, 1, ..., S - 1.

We formally define the slackness between stages  $S_i$  and  $S_{i+1}$  as  $\Delta_i = x_i - x_{i+1}$ , which is guaranteed non-negative by Lemma 1. The following theorem identifies the slackness as the key structural resilience to communication delays.

**Theorem 1** (Delay resilience) Let  $c_i$  be the communication delay between stages  $S_i$  and  $S_{i+1}$ . The accumulated pipeline delay caused by  $c_i$  is  $\Theta(c_i)$  if  $c_i \leq (\Delta_i - 1)t$  but amplifies to  $\Theta\left(\frac{Nc_i}{\Delta_i+1}\right)$  if  $c_i > (\Delta_i - 1)t$ , where t is the operation execution time (i.e.,  $t^F = t^B = t^W = t$ ).

**Proof:** By the Lemma,  $\Delta_i$  is non-negative, so we can prove this theorem by considering the following two cases.

Case 1:  $c_i \leq (\Delta_i - 1)t$ . For any two *adjacent B*, *F* operations  $B_{i,a}, F_{i,b}$  in  $S_i$  (e.g.,  $B_1, F_6$  in the figure), we can find its corresponding operations  $B_{i+1,a}, F_{i+1,b}$  in  $S_{i+1}$ , and define the *feasible interval I<sub>i</sub>* as the interval between the end of  $B_{i+1,a}$  and the start of  $F_{i+1,b}$ . During the steady phase, this interval is inherently  $2\Delta_i t$  in an ideal no-delay scenario (Figure 7 (a)). To absorb the communication delay, the total execution time of the following operations must not exceed  $I_i$ : (1) sending  $B_{i,a}$  back to  $S_i$ , (2) calculation of  $B_{i,a}$  and  $F_{i,b}$  in  $S_i$ , and (3) sending  $F_{i,b}$  to  $S_{i+1}$  (costs  $2c_i + 2t$  in total).

Therefore,  $c_i \leq (\Delta_i - 1)t$  ensures that the  $2\Delta_i t$  interval is larger than the  $2c_i + 2t$  cost. Thus, the delay  $c_i$  is fully absorbed without propagating bubbles to subsequent operations (Figure 7 (b)). The accumulated delay is therefore bounded by  $\Theta(c_i)$ , as no cascading stalls occur.

*Case 2:*  $c_i > (\Delta_i - 1)t$ . For this case, the pipeline incurs cascading bubbles as illustrated in Figure 7 (c). This is due to each feasible interval *I* should be expanded from  $2\Delta_i$  to  $2c_i + 2t$  to fit the communication and computation operations. This expansion postpones a group of  $2\Delta_i + 2$  operations by  $2c_i$ , and the delay will accumulate to the subsequent group of operations. Therefore, for a pipeline with *N* operations, the overall delay will be  $\Theta\left(\frac{Nc_i}{\Delta_i+1}\right)$ , as each group of  $\Delta_i + 1$  operations contributes  $c_i$  to the total.

Theorem 1 essentially states that a pipeline with slackness  $\Delta_i$  can tolerate a communication delay up to  $(\Delta_i - 1)t$  without triggering cascading bubbles. This result can be extended to a more general setting where the execution times of *F*, *B* and



Figure 8: Simulated delay and bubble rate using different  $\Delta_i$  for a pipeline with N = 30 microbatches and t = 10 ms.

#### Algorithm 1 Initial Planning

**Require:** Number of pipeline stages S, available GPU memory capacity M, per-activation memory  $M^F$ .

**Ensure:** Initial warm-up forward counts  $\{x_0, \ldots, x_{S-1}\}$ .

1: **function** GETINITWARMUPFWDS $(S, M, M^F)$ 2:  $x_{\max} = \lfloor \frac{M}{M^F} \rfloor$ ▷ Calculate max #activations on GPU.  $\triangleright$  First stage holds  $x_{max}$  forwards. 3:  $x_0 \leftarrow x_{\max}$  $\Delta_{\text{avg}} \leftarrow \left\lfloor \frac{x_{\text{max}}-1}{S-1} \right\rfloor$ 4: 5:  $r \leftarrow (x_{\max} - 1) \mod (S - 1)$ 6: for  $i \leftarrow 1$  to S - 1 do  $\triangleright$  *Calculate*  $\Delta_{i-1}$  *and*  $x_i$  *recursively.* 7: 8:  $\Delta_{i-1} \leftarrow \Delta_{\text{avg}} + 1$  if  $i \leq r$  else  $\Delta_{\text{avg}}$ 9:  $x_i \leftarrow x_{i-1} - \Delta_{i-1}$ 10: **return**  $\{x_0, ..., x_{S-1}\}$ 

W are non-uniform. In this case, communication delay  $c_i$  will not introduce cascading bubbles *if and only if* 

$$t_i^F + t_i^B + 2c_i \le \Delta_i (t_{i+1}^F + t_{i+1}^B), \tag{1}$$

where  $t_i^F$  and  $t_i^B$  denote the execution time of forward *F* and backward input *B* operations in stage *i*, respectively. When there are multiple slow links, the accumulated delay is simply the summation of all stragglers' individual contributions.

Figure 8 empirically verifies our analytical findings in simulations: as the communication delay  $c_i$  grows beyond the threshold  $(\Delta_i - 1)t$ , the accumulated pipeline delay sharply increases, aligning with that predicted by Theorem 1.

#### 4.2 Orchestrating Warm-up Forwards

Our previous analysis indicates that enhancing the pipeline's resilience to communication delays requires configuring a larger slackness between two stages. However, doing this comes at a cost of increased memory footprint, as more forward activations are maintained on device. We design pipeline scheduling algorithms that optimally orchestrate warm-up forwards in each stage (i.e.,  $x_i$ ), maximizing the straggler resilience under the memory constraint. Our algorithms include two strategies: (1) *initial planning* for pipeline initialization and (2) *dynamic adaptation* for reconfiguring the pipeline in response to straggler presence. We next explain how the two strategies orchestrate warm-up forwards in each stage, followed by constructing the full-pipeline schedule in §4.3.

**Initial planning.** During pipeline initialization, the system assumes no knowledge of stragglers. As they can occur on any link between two stages, the best strategy is to *maximize* 

#### Algorithm 2 Dynamic Adaptation

| Requir        | e: Number of pipeline stages S, per-stage forward/backward                                                                                    |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| tim           | es $\{t_i^F\}, \{t_i^B\}$ , inter-stage communication delays $\{c_i\}$ .                                                                      |
| Ensure        | : Adapted warm-up forward counts $\{x_0, \ldots, x_{S-1}\}$ .                                                                                 |
| 1: <b>fur</b> | <b>iction</b> GETADAPTEDWARMUPFWDS( $S, \{t_i^F\}, \{t_i^B\}, \{c_i\}$ )                                                                      |
| 2:            | ▷ The last stage holds only one warm-up forward.                                                                                              |
| 3:            | $x_{S-1} \leftarrow 1$                                                                                                                        |
| 4:            | $\triangleright$ Calculate $\Delta_i$ and $x_i$ backward-recursively.                                                                         |
| 5:            | for $i \leftarrow S - 2$ to 0 do                                                                                                              |
| 6:            | ▷ Ensure bubble absorption by Equation 1.                                                                                                     |
| 7:            | $\Delta_i \leftarrow \min\left(N - 2S, \max\left(\left\lceil \frac{t_i^F + t_i^B + 2c_i}{t_{i+1}^F + t_{i+1}^B}\right\rceil, 2\right)\right)$ |
| 8:            | $x_i \leftarrow x_{i+1} + \Delta_i$                                                                                                           |
| 9:            | return $\{x_0,, x_{S-1}\}$                                                                                                                    |

the minimum inter-stage slackness within the pipeline, i.e., max min<sub>i</sub>  $\Delta_i$ . This is equivalent to configuring a pipeline that uniformly maximizes each  $\Delta_i$  under GPU memory constraints. Algorithm 1 shows how this can be achieved. It first computes the maximum number of forward activations that a GPU can maintain in memory, all of which are assigned to stage 0 (lines 2 and 3). With  $x_0$  determined, it then computes the warm-up forward counts in subsequent stages to ensure that  $x_i$ 's are monotonically decreasing (Lemma 1) with as balanced slackness  $\Delta_i$  as possible (lines 4 to 9). The generated pipeline provides the maximum uniform delay resilience.

**Dynamic adaption.** Upon detecting a communication delay exceeding the tolerance threshold (given by Equation 1), the system reconfigures the pipeline to increase the slackness between the affected stages, aiming to "absorb" as many bubbles as possible. At this point, *memory constraints can be relaxed* as ADAPTRA offloads activations to host memory—which provides significantly larger space than the device memory—and uses CPU-side RDMA for data transfer to eliminate HOL blocking stalls (details in §5). Therefore, the optimal strategy is to maximize  $\Delta_i$ , under virtually no memory limit.

Algorithm 2 implements this strategy. Starting backward from the last stage requiring only one warm-up forward (line 3), it recursively computes the desired warm-up count  $x_i$  in the preceding stage (for-loop). Specifically, it uses profiled per-stage compute times and communication delays to determine the minimum required slackness  $\Delta_i$  for all *i* using Equation 1, ensuring that  $\Delta_i$  is large enough to absorb the observed delay while clipping it by N - 2S to preserve enough forwards for other stages' warm-up (line 7). Once  $\Delta_i$ is computed,  $x_i$  easily follows (line 8).

#### 4.3 Full-Pipeline Orchestration

With the warm-up forward count determined in each stage, we now construct the complete pipeline execution schedule. Optimally orchestrating all operator executions across stages and microbatches formulates a mixed-integer linear programming (MILP) problem [14, 33] and is NP-hard [45]. We hence turn to an efficient heuristic that sequentially generates a pipeline schedule following its execution timeline, discretized into multiple time steps. At each time step, the algorithm does two things: (1) simulating pipeline execution and (2) making new scheduling decisions.

**Simulation.** First, it keeps track of the execution of previously scheduled operators (F/B/W) and updates their states in each stage—similar to running a discrete-time simulation. It also maintains a list of *schedulable operators* for each stage and updates it accordingly (e.g., an *F* becomes schedulable in stage  $S_i$  after its upstream *F* completes in  $S_{i-1}$ ).

Operator selection. Second, for each idle stage, the algorithm makes new scheduling decisions based on the updated system state. It chooses an operator from the schedulable list following a two-phase operator selection policy. During the warm-up phase, each stage  $S_i$  executes only forward operators until reaching the assigned quota  $x_i$  (computed by Algorithm 1 or 2), ensuring the desired straggler resilience. After all warmup forwards complete, the stage transitions into a steady phase, in which it selects operators from the schedulable list in a priority order of B > F > W. Specifically, backward input operators (B) are prioritized to immediately free activation memory and propagate dependencies upstream; forwards (F)are selected next, as they generate single downstream dependencies; backward weight (W) operators have the lowest priority, since they do not generate further dependencies and can be scheduled opportunistically.

**Optimality and complexity.** We will show in §7.4 that this simple heuristic generates pipeline schedules that closely approximate the optimum–obtained by solving an MILP problem–when the simulation is configured with a finegrained step size  $\delta$ . In terms of the complexity, let  $t_o$  be the longest operator execution time, i.e.,  $t_o = \max_i(t_i^F, t_i^B, t_i^W o)$ . The algorithm completes in at most  $3NS[t_o/\delta]$  steps, as each operator (of which there are 3N per stage over S stages) is scheduled at most once per  $\delta$  interval. Each step involves S constant-time policy evaluations, resulting in an overall complexity of  $O(NS^2[t_o/\delta])$ .

## 5 Decoupled Data Plane via Comm. Delegation

The effectiveness of the aforementioned pipeline adaptation algorithms (§4)—our first key design—is contingent on *eliminating head-of-line (HOL) blocking stalls*. In this section, we start with a straw man solution and illustrate its ineffectiveness (§5.1). We then present our second key design to eliminate HOL blocking stalls (§5.2), which additionally provides fault tolerance to RNIC failures (§5.3).

#### 5.1 Straw Man Solution

Recall in §3.2 that HOL blocking is caused by sequential launching of communication and subsequent computation operations (Figure 6). Therefore, the key to avoiding HOL



Figure 9: Naively adopting NCCL-based opportunistic communication [4,41] solves the blocking issue, but introduces severe interference to computation.

blocking is to *decouple slow communication operations from the compute sequence*, thereby ensuring that all compute kernels can be launched without a delay.

A straw man solution is *opportunistic communication* [4, 41]. It delegates communication operations to some dedicated processes, allowing the main training process to concentrate on computation. These dedicated communication processes asynchronously retrieve data from shared buffers and transmit it to adjacent pipeline stages via GPU-direct RDMA using NCCL. However, this approach introduces significant interference to computation. As illustrated in Figure 9, overlapping computation and communication results in substantial kernel execution slowdowns. For instance, stage-1's backward operation  $(B_2)$  increases from 31 ms to 61.9 ms when overlapped with  $SB_1$ . Our profiling reveals that, although this approach closes the kernel launch gaps, the runtime of individual kernels is greatly prolonged: a GEMM kernel that typically finishes in 110 us is stretched to 2 ms under interference. As a result, despite being blocking-free, the pipeline's end-to-end performance ends up no better than sequential execution.

# 5.2 CPU-based Communication Delegation

Key idea. While the NCCL-based straw man introduces severe interference, its delegation paradigm remains validprovided we can avoid such interference. This inspires us to offload activation and gradient transfers from the GPU to host memory upon straggler detection, and perform send/receive operations using dedicated CPU-side delegate processes to avoid interfering GPU computation. This design enables three key benefits. First, it fully decouples communication operations from GPU kernel scheduling, preventing slow communication from stalling GPU computation operations (blocking-free). Second, offloading activation and gradients to the host lifts the GPU memory pressure, enabling orchestrating a memory-intensive pipeline schedule with more warmup forwards and larger slackness for enhanced straggler resilience (i.e., virtually no memory constraint in Algorithm 2). *Third*, it additionally provides RNIC fault tolerance: in case of GPU-side RNIC failures, the host RNICs serves as a backup.

Design. In our design, the delegated communication path is ac-



Figure 10: CPU-delegated data transmission path.

tivated only upon the detection of communication delays. For each type of communication (e.g., send-forward), the framework launches multiple CPU communication processes, each with its own transmission queue. This multi-queue design ensures that the total data consumption rate keeps pace with the data production rate of computation. For example, if the GPU produces 8 activations per second while each communication delegate can consume only 2 per second, at least 4 sending queues are needed to avoid blocking and queue buildup.

Figure 10 illustrates the data transmission path. ① The receiver delegates eagerly fetch data from remote peers during training. The training process ② retrieves input data from a receiver queue in a *round-robin* manner and ③ copies it to GPU. The GPU ④ computes the results, which are ⑤ copied back to host and ⑥ enqueued into the corresponding sender queue. ⑦ Finally, the sender delegates send the results via CPU-side RDMA.

**Optimizing Data transfer.** As our design bypasses GPUdirect RDMA (GDR) and utilizes a slower CPU-side RDMA, reducing the overhead of data movement between the host and the GPU becomes critical. To minimize this overhead, we design a fine-grained data pipeline with optimized CUDA kernels which move data asynchronously and only report to the training process when the data is ready.

Specifically, our optimization creates a pinned shared memory buffer for each delegate, which allows faster GPU data access than pageable memory through DMA and zero additional data copy between the delegate and the training processes during IPC. For each replica of a communication type (e.g., send-forward), both its training process and itself can access a piece of pinned shared memory. When sending forward or backward, as shown in Figure 11, the training process initiates two sequential cudaMemcpy() operations in the same CUDA stream. It first ① copies data from GPU to host and then ② sets a copy completion signal to guarantee data integrity. After checking the signal, the delegate process ③ ensures copy completion and ④ sends data via RDMA.

When receiving forward or backward, as shown in Figure 12, once ① data is received from remote via RDMA, ② the delegate process sets a signal in shared memory indicating data ready. ③ Meanwhile, the training process checks this signal through busy waiting. After confirming, two sequential



Figure 11: Optimized data transfer for sending data.



Figure 12: Optimized data transfer for receiving data.

cudaMemcpy() operations are initiated to first ④ copy data from host to GPU, followed by ⑤ setting a signal in GPU memory to acknowledge data copy completion. Once the training process ⑥ sees this data ready signal, the subsequent compute operators can ⑦ consume this data safely.

### 5.3 Handling RNIC Failures

During NCCL initialization, each GPU is assigned a dedicated RNIC to avoid bandwidth contention within a node. Consequently, a single RNIC failure during NCCL communication results in a connection loss or a timeout error, even if the other RNICs are still well functioning. The GDR path is hence vulnerable to RNIC failures.

The CPU-based communication delegation provides an inherent tolerance to RNIC failures as it bypasses the faulty GDR path. During training, each delegate process can flexibly choose an RNIC for data transfer using Gloo [18]. In the event of an RNIC failure, the delegate process reroutes the affected communication traffic from the faulty RNIC to a healthy one to continue data transfer, enabling uninterrupted training as opposed to conventional checkpoint-and-restart failover.

## **6** ADAPTRA Design and Implementation

ADAPTRA is an efficient parallel training system that integrates the two key designs described in §4 and §5 to deliver robust resilience against communication stragglers. As illustrated in Figure 13, it comprises three main components: (1) a *profiler* that continuously monitors each node's compute and communication performance, (2) a *hybrid-parallel orchestrator* that dynamically determines the communication topology and constructs TP, DP, and PP communication groups based on runtime performance, and (3) a *pipeline scheduler* that adaptively configures a resilient pipeline schedule against dynamic stragglers using the algorithms developed in §4.



Figure 13: ADAPTRA system design.

**Initialization.** During system initialization, ① the orchestrator establishes the initial TP/DP/PP communication groups according to the parallelism strategy and hardware configuration (e.g., network topology). ② The scheduler then generates an initial pipeline schedule that provides uniform resilience to potential stragglers across all stages (§4). ③ This schedule is deployed on the cluster, and the training starts with all inter-node communication performed via GPU-direct RDMA.

**Straggler mitigation.** Throughout training, the profiler continuously tracks communication and computation performance. Upon detecting slow communication (using detection techniques in [8, 48]), it reports this straggler event to the orchestrator (④). If the affected link is between PP stages (e.g., stages 0 and 1), the orchestrator notifies the pipeline scheduler (⑤), which then adapts the pipeline schedule as described in §4. The updated schedule is then deployed on the cluster, and CPU communication delegates are activated at the affected nodes to eliminate HOL blocking stalls (⑥). If the slow link is part of a DP communication group, the orchestrator reconfigures the training topology to reassign this link for PP communication, effectively converting a DP straggler into a less detrimental PP straggler [48], which is then addressed using the above mechanisms.

**Implementation.** ADAPTRA is implemented on top of Megatron-LM [30] and ZeroBubble [33], comprising 5.3K lines of code (LoC), primarily in Python, with performancecritical data transfer kernels written in CUDA. The straggler detector and orchestrator are adapted from Falcon [48], while the profiler leverages CUDA Events and exposes performance profiles to the scheduler via Redis [37]. For CPU-side communication, ADAPTRA utilizes Gloo [18] to facilitate RDMA data transfers.

# 7 Evaluation

In this section, we evaluate ADAPTRA to answer the following questions: (1) Does ADAPTRA effectively address dependency bubbles and HOL blocking stalls caused by PP stragglers (§7.2)? (3) Does ADAPTRA also effectively handle DP stragglers (§7.3)? (2) Can ADAPTRA generate an opti-

| Model Size                  | 7B        | 14B       | 30B       | 60B       | 140B      |
|-----------------------------|-----------|-----------|-----------|-----------|-----------|
| Parallelism<br>(TP, DP, PP) | (1, 1, 4) | (1, 1, 8) | (2, 4, 8) | (4, 2, 8) | (8, 2, 8) |
| #GPUs                       | 4         | 8         | 64        | 64        | 128       |

Table 2: Models and corresponding 3D-parallelism settings.



Figure 14: The actual execution of the schedule using ADAP-TRA and other two baselines on a 7B model under 30 ms delay on the link between last two PP stages.

mal schedule and delegate communication with acceptable overhead (§7.4)? (4) How does ADAPTRA perform in largescale pretraining in the presence of frequent communication stragglers and RNIC failures (§7.5)?

### 7.1 Experimental Setup

**Cluster setup.** Our evaluation is conducted on a 128-GPU cluster, where each node is equipped with 8 NVIDIA H800 GPUs and 400 Gbps InfiniBand inter-node connections. We use CUDA 12.1 and NCCL 2.18.1 in the test environment.

**Baselines.** We evaluate ADAPTRA against four baselines.

- 1. 1F1B [29] is a classic pipeline schedule with low bubble rate and controllable memory footprint.
- 2. ZeroBubble (ZB) [33] is a SOTA pipeline schedule that eliminates bubbles via decoupled backward passes.
- 3. Falcon [48] migrates slow links to PP groups if stragglers occur on DP groups, but does not mitigate the stragglers' residual impact on pipeline execution.
- 4. ADAPTRA-CPU only enables delegated communication (§5) without pipeline adaptation.

**Models and Parallelism.** We evaluate ADAPTRA using GPT-2 models of varying sizes, ranging from 7B to 140B parameters, on up to 128 GPUs across 16 nodes. The models and corresponding parallelism settings are given in Table 2.

# 7.2 Mitigating PP Stragglers

**Microbenchmark.** Before introducing end-to-end performance, we first demonstrate the behavior of ADAPTRA's two designs in addressing dependency bubbles and HOL blocking stalls using a GPT2-7B model. We inject a 30 ms delay between pipeline stages 2 and 3 and then profile the execution



Figure 15: Sensitivity analysis of ADAPTRA and baselines using a 14B model under various delay values.

of each operator within an iteration using cudaEvent, with the execution timeline shown in Figure 14.

In the original ZB execution, we observe significant bubbles between warm-up forward operators in stage 2 caused by HOL blocking stalls and dependency-bubbles exacerbate the performance. This compound effect extends the iteration time to 703 ms with 57.4% bubble rate  $(1.9 \times \text{longer than the})$ normal execution). ADAPTRA-CPU retains the same pipeline schedule as ZB but activates CPU-based delegation, eliminating HOL blocking stalls by redirecting the original GPUdirect RDMA to CPU-based RDMA operations. As a result, the iteration time improves to 579 ms, with the bubble rate reduced to 48.8% solely due to dependency issues. Further enabling pipeline adaptation (i.e., the complete ADAPTRA) reduces the iteration time to 398 ms (only 30 ms slowdown) and the bubble rate to only 25.3%. This  $1.76 \times$  improvement is achieved by increasing the slackness between stages 2 and 3 (i.e.,  $\Delta_2$ ), substantially enhancing the pipeline's resilience to the injected communication delays.

Sensitivity analysis. We assess the impact of delay values on end-to-end iteration times by gradually increasing the latency between the last two stages of a 14B model from 0 to 60 ms. As shown in Figure 15, a 60 ms communication delay slows down 1F1B, ZB, and ADAPTRA-CPU significantly by 2.70×,  $4.24\times$ , and  $2.15\times$ , respectively. Notably, ZB, though achieving better performance without stragglers, is more vulnerable to communication delays due to its tightly coupled schedule. In contrast, ADAPTRA consistently outperforms baseline systems with slightly increased iteration times. Specifically, under a 60 ms delay, ADAPTRA measures a modest slowdown of  $1.13 \times$  thanks to the two designs described in §4 and §5. Compared to ZB, switching to CPU-based communication delegation (ADAPTRA-CPU) mitigates the straggler impact by 48.1%; this impact is further alleviated by 24.6% using pipeline adaptation.

**Resilience to single-link degradation.** We next evaluate ADAPTRA's performance in the presence of a single-link straggler under various model and parallelism settings. As illustrated in Figure 16, we inject a delay of 30 ms (or 60 ms) into a single communication link between the first (or last) two PP stages. Across all model sizes from 7B to 60B, ADAP-TRA consistently outperforms baseline methods. In particular, it achieves up to  $3.71 \times$  speedup over 1F1B (in the scenario of 7B, 60 ms, last two stages) and  $3.49 \times$  speedup over ZB



Figure 16: Evaluation on single inter-PP communication degradation under various model settings and delay locations.



Figure 17: Iteration times of a 14B model under multiple simultaneous inter-PP communication stragglers.



Figure 18: A communication straggler in DP group introduces significant baseline degradation. Both Falcon [48] and ADAP-TRA migrates this link to PP groups, while ADAPTRA further optimizes the residual impacts.

# 7.3 Mitigating DP Stragglers

(14B, 60 ms, last). When the communication delay increases from 30 ms to 60 ms, the average iteration time measured across all models increases by only  $1.07 \times$  using ADAPTRA, compared to  $1.49 \times$ ,  $1.69 \times$ , and  $1.30 \times$  using 1F1B, ZB, and ADAPTRA-CPU, respectively. These results suggest that dependency bubbles account for 39% of slowdown, while HOL blocking stalls contribute 23% on average. ADAPTRA effectively mitigates both issues.

Note that the straggler location also matters, as delays between the last two PP stages are difficult to hide in the original ZB schedule due to their tight dependencies. ADAPTRA effectively addresses this issue through pipeline adaptation: it improves the average iteration time by 19.3% compared to ADAPTRA-CPU under a 60 ms delay between the first two stages; this gain increases to 38.4% when the same delay occurs between the last two stages.

**Multi-link degradation.** To evaluate ADAPTRA under more complex straggler conditions, we configure multiple stragglers in the 14B setting with 30 ms delays occurring on two adjacent links (0-1 and 1-2), two skip links (0-1 and 2-3), first-and-last links (0-1 and 6-7), and three skip links (0-1, 3-4, 6-7), respectively. As detailed in Figure 17, ADAPTRA reduces the iteration time by 51.6% and 57.5% on average across the four settings, compared to 1F1B and ZB. Importantly, adaptive pipeline reconfiguration improves the average performance by 23.1% (comparing to ADAPTRA-CPU), further validating the effectiveness of ADAPTRA's scheduling algorithm under complicated delay conditions.

Communication stragglers can also occur between DP groups. We evaluate ADAPTRA in this scenario using a GPT2-7B model on 8 nodes with ZB scheduling under a configuration of (1 TP, 2 DP, 4 PP). We inject per-packet delays of 0.125/0.25/0.375 ms (10/20/30 ms inter-PP stage latency) into a designated link. As shown in Figure 18, when this link is for DP communications, the baseline ZB degrades by  $8.04\times$ , far exceeding the impact of PP communication stragglers. In response, both ADAPTRA and Falcon [48] mitigate this by reassigning the slow link to PP communication groups, leading to  $3.6\times$  improvement. ADAPTRA further mitigates the residual PP straggler through pipeline adaptation and CPU-delegated communications, achieving  $1.96\times$  additional speedup over Falcon.

#### 7.4 Optimality and Overhead

**Performance and overhead of pipeline scheduling.** We evaluate the performance of our pipeline scheduling algorithm described in §4 against the optimal schedule obtained by formulating an MILP problem. We consider four pipeline configurations (with 3-8 stages and 6-32 microbatches) with randomly generated profiles. As illustrated in Figure 19, configuring a smaller time step  $\delta$  (higher  $\lceil t_o/\delta \rceil$ ) for fine-grained simulation narrows the gap between the generated schedule and the optimum, at a cost of increased schedule generation time. In all settings, the gap, measured by the relative difference in execution time, is less than 1% when running at a fine granularity of  $\lceil t_o/\delta \rceil = 30$ . These near-optimal schedules are



Figure 19: The relative error to optimal solution and solving time of ADAPTRA's scheduler, where it achieves an near-optimal solution within 1% error in 0.1 seconds.



Figure 20: Worst-case overhead of ADAPTRA's delegated communication w/o presence of communication stragglers.

generated in less than 100 ms, as opposed to computing the optimal schedules that requires solving an MILP in hours.

**Overhead of delegation.** We stress-test the delegated path across models from 7B to 60B parameters. Under a *worst-case scenario* where all pipeline communications are forcibly routed through CPU delegates (All-CPU), ADAPTRA maintains comparable performance (<5% overhead) to the GPU-direct RDMA (GDR) baselines (ZB and 1F1B) for models with  $\leq$  30B parameters. Even at 60B scale, All-CPU introduces only 17% additional iteration time compared to GDR.

### 7.5 Large-Scale Evaluation

We further evaluate ADAPTRA on a 140B model using 128 GPUs across 16 nodes. We construct a 1,200-iteration trace which includes 9 communication straggler events in PP groups (with 1–3 concurrent slow links per event, 20–60 ms latency) and one RNIC failure (details given in Appendix). Each straggler event starts at a certain iteration and lasts for 70 iterations before reverting to normal operation. During the RNIC failure, 1F1B and ZB perform checkpoint-and-restart, while ADAPTRA runs uninterruptedly via delegation.

As shown in Figure 21, without delays, 1F1B's inherent pipeline bubbles caused lower throughput compared to ZB and ADAPTRA. However, when the latency value is relatively large, the throughput of ZB decreases to around 10 samples per second, even worse than that of 1F1B. In contrast, by resolving HOL blocking stalls and dependency bubbles, ADAP-TRA maintains more than 20 samples per second most of the time, significantly surpassing the two baselines. Over the full training cycle, ADAPTRA completed in 33.2 minutes, outperforming 1F1B (45.4 minutes) and ZB (46.9 minutes) by  $1.37 \times$  and  $1.41 \times$ , respectively. This demonstrates ADAP-TRA's ability to maintain robust performance under simulta-



Figure 21: Throughput of ADAPTRA of pretraining a 140B model on 128 NVIDIA H800 GPUs against baselines, where ADAPTRA improves the throughput by up to  $1.41 \times$ .

neous stragglers and hardware failures.

# 8 Related Work

**Reliability issues in training.** Abundant studies address training crashes using checkpoints [28, 47], redundant computations [44], and elastic frameworks [19, 28, 44, 47]. However, seldom existing works address communication stragglers, while they have been identified in several reports [11, 21],. Malleus [24] solely mitigates compute stragglers without considering communications. Falcon [48] addresses slow communication by shifting the degraded links to PP groups without optimizing the residual impact. Crux [5]'s communication-aware scheduling tries to reduce the occurrence probability of stragglers, yet not mitigating their impacts.

**Communication optimizations for training.** Communication optimizations span three critical layers. Infrastructurelevel efforts like Alibaba HPN [34] and Megascale [21] propose specialized network topologies for training clusters. At the library level, TACCL [39], ACCL [10], and MSCCL [7] develop optimized communication primitives for collective operations. Framework-level approaches including Megatron-LM [30], Varuna [4], and DeepEP [51] enhance computationcommunication overlap in hybrid-parallel settings.

**Pipeline parallelism optimizations.** Pipeline scheduling remains challenging in distributed training. Classic approaches like Gpipe [17] and 1F1B [29] achieve comparable bubble rates, with 1F1B additionally reducing memory usage. Recent advances address distinct dimensions: Interleaved 1F1B [30] reduces bubbles via introducing virtual stages, while ZeroBubble [33] eliminates them through decoupled backward passes. For specialized architectures, DualPipe [14] optimizes MoE training pipelines and RLHFuse [53] tailors for RLHF workloads. In terms of improving reliability, Recycle [12] employs precomputed schedules with microbatch rerouting for fail-stop recovery, whereas SDPipe [27] trades training accuracy for computation straggler-resilience.

# 9 Conclusion

This paper presents ADAPTRA, a system designed for efficient hybrid-parallel training in the presence of communication stragglers. ADAPTRA employs dynamic pipeline adaption to minimize dependency bubbles and CPU-delegated communication to eliminate head-of-line blocking stalls. Experiments demonstrate that ADAPTRA achieves  $1.2-3.5 \times$  speedup over SOTA baselines under communication stragglers, and  $1.41 \times$  higher throughput with zero restart overhead upon RNIC failures.

# References

- [1] Josh Achiam, Steven Adler, Sandhini Agarwal, Lama Ahmad, Ilge Akkaya, Florencia Leoni Aleman, Diogo Almeida, Janko Altenschmidt, Sam Altman, Shyamal Anadkat, et al. Gpt-4 technical report. *arXiv preprint arXiv:2303.08774*, 2023.
- [2] Vamsi Addanki, Prateesh Goyal, and Ilias Marinos. Challenging the need for packet spraying in large-scale distributed training. *arXiv preprint arXiv:2407.00550*, 2024.
- [3] Mohammad Alizadeh, Tom Edsall, Sarang Dharmapurikar, Ramanan Vaidyanathan, Kevin Chu, Andy Fingerhut, Vinh The Lam, Francis Matus, Rong Pan, Navindra Yadav, et al. Conga: Distributed congestion-aware load balancing for datacenters. In *Proceedings of the* 2014 ACM conference on SIGCOMM, pages 503–514, 2014.
- [4] Sanjith Athlur, Nitika Saran, Muthian Sivathanu, Ramachandran Ramjee, and Nipun Kwatra. Varuna: scalable, low-cost training of massive deep learning models. In Proceedings of the Seventeenth European Conference on Computer Systems, pages 472–487, 2022.
- [5] Jiamin Cao, Yu Guan, Kun Qian, Jiaqi Gao, Wencong Xiao, Jianbo Dong, Binzhang Fu, Dennis Cai, and Ennan Zhai. Crux: Gpu-efficient communication scheduling for deep learning training. In *Proceedings of the ACM SIGCOMM 2024 Conference*, pages 1–15, 2024.
- [6] Jianmin Chen, Xinghao Pan, Rajat Monga, Samy Bengio, and Rafal Jozefowicz. Revisiting distributed synchronous sgd. arXiv preprint arXiv:1604.00981, 2016.
- [7] Meghan Cowan, Saeed Maleki, Madanlal Musuvathi, Olli Saarikivi, and Yifan Xiong. Mscclang: Microsoft collective communication language. In Proceedings of the 28th ACM International Conference on Architectural Support for Programming Languages and Operating Systems, Volume 2, pages 502–514, 2023.
- [8] Weihao Cui, Ji Zhang, Han Zhao, Chao Liu, Wenhao Zhang, Jian Sha, Quan Chen, Bingsheng He, and Minyi Guo. Xputimer: Anomaly diagnostics for divergent llm training in gpu clusters of thousand-plus scale. arXiv preprint arXiv:2502.05413, 2025.
- [9] Advait Dixit, Pawan Prakash, Y Charlie Hu, and Ramana Rao Kompella. On the impact of packet spraying in data center networks. In 2013 Proceedings IEEE INFOCOM, pages 2130–2138. IEEE, 2013.
- [10] Jianbo Dong, Shaochuang Wang, Fei Feng, Zheng Cao, Heng Pan, Lingbo Tang, Pengcheng Li, Hao Li,

Qianyuan Ran, Yiqun Guo, et al. ACCL: Architecting highly scalable distributed training systems with highly efficient collective communication library. *IEEE micro*, 41(5):85–92, 2021.

- [11] Abhimanyu Dubey, Abhinav Jauhri, Abhinav Pandey, Abhishek Kadian, Ahmad Al-Dahle, Aiesha Letman, Akhil Mathur, Alan Schelten, Amy Yang, Angela Fan, et al. The Llama 3 herd of models. arXiv preprint arXiv:2407.21783, 2024.
- [12] Swapnil Gandhi, Mark Zhao, Athinagoras Skiadopoulos, and Christos Kozyrakis. Recycle: Resilient training of large dnns using pipeline adaptation. In *Proceedings* of the ACM SIGOPS 30th Symposium on Operating Systems Principles, pages 211–228, 2024.
- [13] Adithya Gangidi, Rui Miao, Shengbao Zheng, Sai Jayesh Bondu, Guilherme Goes, Hany Morsy, Rohit Puri, Mohammad Riftadi, Ashmitha Jeevaraj Shetty, Jingyi Yang, et al. Rdma over ethernet for distributed training at meta scale. In *Proceedings of the ACM SIGCOMM 2024 Conference*, pages 57–70, 2024.
- [14] Daya Guo, Dejian Yang, Haowei Zhang, Junxiao Song, Ruoyu Zhang, Runxin Xu, Qihao Zhu, Shirong Ma, Peiyi Wang, Xiao Bi, et al. Deepseek-r1: Incentivizing reasoning capability in LLMs via reinforcement learning. arXiv preprint arXiv:2501.12948, 2025.
- [15] Aaron Harlap, Henggang Cui, Wei Dai, Jinliang Wei, Gregory R Ganger, Phillip B Gibbons, Garth A Gibson, and Eric P Xing. Addressing the straggler problem for iterative convergent parallel ml. In *Proceedings of the seventh ACM symposium on cloud computing*, pages 98–111, 2016.
- [16] Qinghao Hu, Zhisheng Ye, Zerui Wang, Guoteng Wang, Meng Zhang, Qiaoling Chen, Peng Sun, Dahua Lin, Xiaolin Wang, Yingwei Luo, et al. Characterization of large language model development in the datacenter. In 21st USENIX Symposium on Networked Systems Design and Implementation (NSDI 24), pages 709–729, 2024.
- [17] Yanping Huang, Youlong Cheng, Ankur Bapna, Orhan Firat, Dehao Chen, Mia Chen, HyoukJoong Lee, Jiquan Ngiam, Quoc V Le, Yonghui Wu, et al. Gpipe: Efficient training of giant neural networks using pipeline parallelism. Advances in neural information processing systems, 32, 2019.
- [18] Facebook Incubator. Gloo, 2025. Accessed: 2025-03-26.
- [19] Insu Jang, Zhenning Yang, Zhen Zhang, Xin Jin, and Mosharaf Chowdhury. Oobleck: Resilient distributed training of large models using pipeline templates. In

Proceedings of the 29th Symposium on Operating Systems Principles, pages 382–395, 2023.

- [20] Myeongjae Jeon, Shivaram Venkataraman, Amar Phanishayee, Junjie Qian, Wencong Xiao, and Fan Yang. Analysis of {Large-Scale}{Multi-Tenant}{GPU} clusters for {DNN} training workloads. In 2019 USENIX Annual Technical Conference (USENIX ATC 19), pages 947–960, 2019.
- [21] Ziheng Jiang, Haibin Lin, Yinmin Zhong, Qi Huang, Yangrui Chen, Zhi Zhang, Yanghua Peng, Xiang Li, Cong Xie, Shibiao Nong, et al. MegaScale: Scaling large language model training to more than 10,000 {GPUs}. In 21st USENIX Symposium on Networked Systems Design and Implementation (NSDI 24), pages 745–760, 2024.
- [22] Jared Kaplan, Sam McCandlish, Tom Henighan, Tom B. Brown, Benjamin Chess, Rewon Child, Scott Gray, Alec Radford, Jeffrey Wu, and Dario Amodei. Scaling laws for neural language models. arXiv preprint arXiv:2001.08361, 2020.
- [23] Yanfang Le, Rong Pan, Peter Newman, Jeremias Blendin, Abdul Kabbani, Vipin Jain, Raghava Sivaramu, and Francis Matus. Strack: A reliable multipath transport for ai/ml clusters. arXiv preprint arXiv:2407.15266, 2024.
- [24] Haoyang Li, Fangcheng Fu, Hao Ge, Sheng Lin, Xuanyu Wang, Jiawen Niu, Yujie Wang, Hailin Zhang, Xiaonan Nie, and Bin Cui. Malleus: Straggler-resilient hybrid parallel training of large-scale models via malleable data and model parallelization. arXiv preprint arXiv:2410.13333, 2024.
- [25] Wanchao Liang, Tianyu Liu, Less Wright, Will Constable, Andrew Gu, Chien-Chin Huang, Iris Zhang, Wei Feng, Howard Huang, Junjie Wang, et al. Torchtitan: One-stop pytorch native solution for production ready llm pre-training. arXiv preprint arXiv:2410.06511, 2024.
- [26] Aixin Liu, Bei Feng, Bing Xue, Bingxuan Wang, Bochao Wu, Chengda Lu, Chenggang Zhao, Chengqi Deng, Chenyu Zhang, Chong Ruan, et al. Deepseek-v3 technical report. arXiv preprint arXiv:2412.19437, 2024.
- [27] Xupeng Miao, Yining Shi, Zhi Yang, Bin Cui, and Zhihao Jia. Sdpipe: A semi-decentralized framework for heterogeneity-aware pipeline-parallel training. *Proceed*ings of the VLDB Endowment, 16(9):2354–2363, 2023.
- [28] Jayashree Mohan, Amar Phanishayee, and Vijay Chidambaram. {CheckFreq}: Frequent,{Fine-Grained}{DNN} checkpointing. In 19th USENIX

*Conference on File and Storage Technologies (FAST 21)*, pages 203–216, 2021.

- [29] Deepak Narayanan, Aaron Harlap, Amar Phanishayee, Vivek Seshadri, Nikhil R Devanur, Gregory R Ganger, Phillip B Gibbons, and Matei Zaharia. Pipedream: Generalized pipeline parallelism for dnn training. In Proceedings of the 27th ACM symposium on operating systems principles, pages 1–15, 2019.
- [30] Deepak Narayanan, Mohammad Shoeybi, Jared Casper, Patrick LeGresley, Mostofa Patwary, Vijay Korthikanti, Dmitri Vainbrand, Prethvi Kashinkunti, Julie Bernauer, Bryan Catanzaro, et al. Efficient large-scale language model training on gpu clusters using megatron-lm. In Proceedings of the International Conference for High Performance Computing, Networking, Storage and Analysis, pages 1–15, 2021.
- [31] NVIDIA Cooperation. Nvidia nsight systems, 2025. Accessed: 2025-03-24.
- [32] OpenAI. Openai sora, 2024. Accessed: 2024-09-13.
- [33] Penghui Qi, Xinyi Wan, Guangxing Huang, and Min Lin. Zero bubble pipeline parallelism. *arXiv preprint arXiv:2401.10241*, 2023.
- [34] Kun Qian, Yongqing Xi, Jiamin Cao, Jiaqi Gao, Yichi Xu, Yu Guan, Binzhang Fu, Xuemei Shi, Fangbo Zhu, Rui Miao, et al. Alibaba hpn: A data center network for large language model training. In *Proceedings of the ACM SIGCOMM 2024 Conference*, pages 691–706, 2024.
- [35] Sudarsanan Rajasekaran, Manya Ghobadi, and Aditya Akella. {CASSINI}:{Network-Aware} job scheduling in machine learning clusters. In 21st USENIX Symposium on Networked Systems Design and Implementation (NSDI 24), pages 1403–1420, 2024.
- [36] Samyam Rajbhandari, Jeff Rasley, Olatunji Ruwase, and Yuxiong He. Zero: Memory optimizations toward training trillion parameter models. In *IEEE/ACM SC*, 2020.
- [37] Salvatore Sanfilippo. Redis the real-time data platform, 2009. Accessed: 2024-09-08.
- [38] Teven Le Scao, Angela Fan, Christopher Akiki, Ellie Pavlick, Suzana Ilić, et al. BLOOM: A 176bparameter open-access multilingual language model. *arXiv preprint arXiv:2211.05100*, 2023.
- [39] Aashaka Shah, Vijay Chidambaram, Meghan Cowan, Saeed Maleki, Madan Musuvathi, Todd Mytkowicz, Jacob Nelson, Olli Saarikivi, and Rachee Singh.

{TACCL}: Guiding collective algorithm synthesis using communication sketches. In 20th USENIX Symposium on Networked Systems Design and Implementation (NSDI 23), pages 593–612, 2023.

- [40] Mohammad Shoeybi, Mostofa Patwary, Raul Puri, Patrick LeGresley, Jared Casper, and Bryan Catanzaro. Megatron-LM: Training multi-billion parameter language models using model parallelism. arXiv preprint arXiv:1909.08053, 2019.
- [41] Mohammed Sourouri, Tor Gillberg, Scott B Baden, and Xing Cai. Effective multi-gpu communication using multiple cuda streams and threads. In 2014 20th IEEE International Conference on Parallel and Distributed Systems (ICPADS), pages 981–986. IEEE, 2014.
- [42] Gemini Team, Rohan Anil, Sebastian Borgeaud, Yonghui Wu, Jean-Baptiste Alayrac, Jiahui Yu, Radu Soricut, Johan Schalkwyk, Andrew M Dai, Anja Hauth, et al. Gemini: a family of highly capable multimodal models. *arXiv preprint arXiv:2312.11805*, 2023.
- [43] Dave Thaler and C Hopps. Multipath issues in unicast and multicast next-hop selection. Technical report, 2000.
- [44] John Thorpe, Pengzhan Zhao, Jonathan Eyolfson, Yifan Qiao, Zhihao Jia, Minjia Zhang, Ravi Netravali, and Guoqing Harry Xu. Bamboo: Making preemptible instances resilient for affordable training of large {DNNs}. In 20th USENIX Symposium on Networked Systems Design and Implementation (NSDI 23), pages 497–513, 2023.
- [45] Jeffrey D. Ullman. Np-complete scheduling problems. Journal of Computer and System sciences, 10(3):384– 393, 1975.
- [46] Pablo Villalobos, Jaime Sevilla, Tamay Besiroglu, Lennart Heim, Anson Ho, and Marius Hobbhahn. Machine learning model sizes and the parameter gap. *arXiv preprint arXiv:2207.02852*, 2022.
- [47] Zhuang Wang, Zhen Jia, Shuai Zheng, Zhen Zhang, Xinwei Fu, T. S. Eugene Ng, and Yida Wang. Gemini: Fast failure recovery in distributed training with in-memory checkpoints. In *Proceedings of the 29th Symposium on Operating Systems Principles*, SOSP '23, page 364–381, New York, NY, USA, 2023. Association for Computing Machinery.
- [48] Tianyuan Wu, Wei Wang, Yinghao Yu, Siran Yang, Wenchao Wu, Qinkai Duan, Guodong Yang, Jiamang Wang, Lin Qu, and Liping Zhang. FALCON: Pinpointing and mitigating stragglers for large-scale hybrid-parallel training. arXiv preprint arXiv:2410.12588, 2024.

- [49] Yifan Xiong, Yuting Jiang, Ziyue Yang, Lei Qu, Guoshuai Zhao, Shuguang Liu, Dong Zhong, Boris Pinzur, Jie Zhang, Yang Wang, et al. SuperBench: Improving cloud AI infrastructure reliability with proactive validation. In 2024 USENIX Annual Technical Conference (ATC'24), pages 835–850, 2024.
- [50] Susan Zhang, Stephen Roller, Naman Goyal, Mikel Artetxe, Moya Chen, Shuohui Chen, Christopher Dewan, Mona Diab, Xian Li, Xi Victoria Lin, et al. Opt: Open pre-trained transformer language models. arXiv preprint arXiv:2205.01068, 2022.
- [51] Chenggang Zhao, Shangyan Zhou, Liyue Zhang, Chengqi Deng, Zhean Xu, Yuxuan Liu, Kuai Yu, Jiashi Li, and Liang Zhao. Deepep: an efficient expertparallel communication library. https://github.com/ deepseek-ai/DeepEP, 2025.
- [52] Lianmin Zheng, Zhuohan Li, Hao Zhang, Yonghao Zhuang, Zhifeng Chen, Yanping Huang, Yida Wang, Yuanzhong Xu, Danyang Zhuo, Eric P Xing, et al. Alpa: Automating inter-and {Intra-Operator} parallelism for distributed deep learning. In *16th USENIX Symposium on Operating Systems Design and Implementation (OSDI 22)*, pages 559–578, 2022.
- [53] Yinmin Zhong, Zili Zhang, Bingyang Wu, Shengyu Liu, Yukun Chen, Changyi Wan, Hanpeng Hu, Lei Xia, Ranchen Ming, Yibo Zhu, et al. Rlhfuse: Efficient rlhf training for large language models with inter-and intrastage fusion. arXiv preprint arXiv:2409.13221, 2024.
- [54] Qihua Zhou, Song Guo, Haodong Lu, Li Li, Minyi Guo, Yanfei Sun, and Kun Wang. Falcon: Addressing stragglers in heterogeneous parameter server via multiple parallelism. *IEEE Transactions on Computers*, 70(1):139– 155, 2020.

#### Appendix

# **Proof of the Lemma in § 4.1**

Assume for contradiction that  $x_i < x_{i+1}$  for some stage  $S_i$ . Since the warm-up phase of  $S_i$  ends after  $F_{i,x_i}$ ,  $F_{i,x_i+1}$  must belong to the steady phase of  $S_i$ , preceded by  $B_{i,1}$ , i.e.,

$$F_{i,x_i} \prec B_{i,1} \prec F_{i,x_i+1}. \tag{2}$$

However,  $B_{i+1,1}$  can only occur after  $S_{i+1}$ 's warm-up phase ends with  $F_{i+1,x_{i+1}}$ . Furthermore, due to pipeline dependencies,  $F_{i+1,x_{i+1}}$  depends on  $F_{i,x_{i+1}}$ . Thus:

$$F_{i,x_{i+1}} \prec F_{i+1,x_{i+1}} \prec B_{i+1,1}.$$
 (3)

Combining these inequalities, we have:

$$B_{i,1} \prec F_{i,x_{i+1}} \prec B_{i+1,1}.$$
 (4)

This implies that  $B_{i,1}$  starts before  $B_{i+1,1}$  which violates the data dependency of backward between  $S_i$  and  $S_{i+1}$ . Hence,  $x_i \ge x_{i+1}$  must hold for all  $1 \le i \le S$ .

# Scheduling Algorithm in § 4.3

We present the detailed algorithm of generating the full pipeline schedule, which employs a discrete-time simulator and a localized operation selection policy described in § 4.3. Algorithm 3 presents our two-stage operator selection policy, which guarantees the slackness on the communication stragglers and minimizes the bubble rate for subsequent steady and cool-down phases. Algorithm 4 then demonstrates the implementation of pipeline simulation, which asks the policy for operator selection and propagates scheduable operators to the upstream and downstream stages.

| Algorithm 3 Operator Selection Policy                      | icy                                       |
|------------------------------------------------------------|-------------------------------------------|
| <b>Require:</b> Current stage $i$ ( $0 \le i < S$ ), avail | vailable operator sets $\mathcal{A}_i$ at |
| current step of $S_i$ , required warm-up fo                | forward counts $x_i$ .                    |
| <b>Ensure:</b> An operator $o \in \{F, B, W\}$ or Non      | one if no operators should                |
| be executed.                                               |                                           |
| 1: <b>function</b> SELECTOP $(i, \mathcal{A}_i, x_i)$      |                                           |

```
2: if \mathcal{A}_i = \emptyset then
```

10

3: return None

• / 1

4:  $\triangleright$  *Warm-up phase, do*  $x_i$  *forwards at first.* 5: **if**  $x_i > 0$  **then** 6: **if**  $F \in \mathcal{A}_i$  **then** 

```
7: x_i \leftarrow x_i - 1
```

```
8: return \mathcal{A}_i.pop(F)
```

```
9: else
```

```
10: return None
```

```
11: \triangleright Execution priority after warm-up: B > F > W.
```

```
12: Pri \leftarrow \{B: 3, F: 2, W: 1\}
```

```
13: ▷ Find an available operator with the highest priority.
```

```
14: return \mathcal{A}_i.pop(max_{o \in \mathcal{A}_i}(Pri[o.type]))
```

# Injection Trace in § 7.5

We inject nine communication stragglers and one RNIC failure in the large-scale experiment (§ 7.5). Their durations and Algorithm 4 Full Pipeline Schedule Generation

Require: Number of stages S, number of microbatches N, per-stage compute times  $\{t_i^F\}, \{t_i^B\}, \{t_i^W\}$ , inter-PP communication times  $\{c_i\}$ , warm-up forward counts  $\{x_i\}$ , time step  $\delta$ . **Ensure:** A pipeline schedule X. 1: function  $SCHEDULE(S, N, \{t_i^F\}, \{t_i^B\}, \{t_i^W\}, \{x_i\}, \{c_i\}, \delta)$ 2:  $\mathcal{X} \leftarrow [\emptyset] \times S$ ▷ Initialize an empty schedule. 3:  $\mathcal{A} \leftarrow [\mathbf{0}] \times S$ ▷ Current available operators.  $\mathcal{A}_0 \leftarrow [F] \times N$ 4:  $\triangleright$  Initially, *F*'s are available for  $S_0$ . 5:  $t \leftarrow 0$ 6: while  $\exists A \in \mathcal{A}, A \neq \emptyset$  do 7: for  $i \in [0 ... S - 1]$  do 8: if not *i*.busy() then 9: > Decide the next operator to execute. 10:  $o \leftarrow \text{Selectop}(i, \mathcal{A}_i, x_i)$ i.execute $(o, duration = t_i^{o.type})$ 11: 12: ▷ Add dependent operators after execution. if o.type = F and  $i \neq S - 1$  then 13: 14:  $\mathcal{A}_{i+1}$ .append $(F(ready = t + c_i))$ 15: else if o.type = B and  $s \neq 0$  then  $\mathcal{A}_{i-1}$ .append $(B(ready = t + c_{i-1}))$ 16. 17:  $\mathcal{A}_{i-1}$ .append $(W(ready = t + c_{i-1}))$ 18:  $X_i \leftarrow X_i \cup \{o\}$ ▷ Update schedule. 19:  $t \leftarrow t + \delta$ 20: return X

severity (i.e., inter-stage communication latencies) are provided in Table 3. The  $\infty$  latency at step 1030 indicates a single RNIC failure, where a checkpoint-and-restart process is required to resume training for 1F1B or ZB schedule, while it can be smoothly handled by ADAPTRA's delegated path.

|              | • •                                                                   |                                                                           |                                                                                                  | 0                                                                     | -                     |  |
|--------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-----------------------|--|
| EventID      | 0                                                                     | 1                                                                         | 2                                                                                                | 3                                                                     | 4                     |  |
| Duration     | 15-85                                                                 | 120-190                                                                   | 230-300                                                                                          | 340-410                                                               | 450-520               |  |
| Stages       | $2 \leftrightarrow 3$                                                 | $\begin{array}{c} 0 \leftrightarrow 1 \\ 5 \leftrightarrow 6 \end{array}$ | $6\leftrightarrow 7$                                                                             | $2 \leftrightarrow 3 \\ 3 \leftrightarrow 4 \\ 6 \leftrightarrow 7$   | $5 \leftrightarrow 6$ |  |
| Lat. (ms) 30 |                                                                       | 40                                                                        | 20                                                                                               | 50                                                                    | 60                    |  |
| EventID      | 5                                                                     | 6                                                                         | 7                                                                                                | 8                                                                     | 9                     |  |
| Duration     | 560-630                                                               | 670-740                                                                   | 780-850                                                                                          | 890-960                                                               | 1030                  |  |
| Stages       | $\begin{array}{c} 1\leftrightarrow 2\\ 6\leftrightarrow 7\end{array}$ | $\begin{array}{c} 0 \leftrightarrow 1 \\ 4 \leftrightarrow 5 \end{array}$ | $\begin{array}{c} 0 \leftrightarrow 1 \\ 1 \leftrightarrow 2 \\ 2 \leftrightarrow 3 \end{array}$ | $\begin{array}{c} 4\leftrightarrow 5\\ 5\leftrightarrow 6\end{array}$ | 2                     |  |
| Lat. (ms) 60 |                                                                       | 20                                                                        | 40                                                                                               | 50                                                                    | $\infty$              |  |

Table 3: Injected trace of communication stragglers and RNIC crashes used in § 7.5.