In a leveraged buyout, cash does not flow freely to equity until every obligation above it in the capital structure has been satisfied. That sequencing — senior debt first, mezzanine second, equity last — is what a waterfall model formalizes. Get the order wrong and you will either overstate free cash flow to equity or miss a covenant breach entirely.
The mechanics are straightforward: operating cash flow enters the top of the waterfall. From there, it cascades through each tranche in strict priority order. What remains after each tranche's interest and required principal is the cash available to the next level. What exits the bottom is the true free cash flow available to equity holders — often a very different number than EBITDA minus interest expense suggests.
EBITDA-based valuations routinely overstate equity value by treating all debt as equal. A $12M EBITDA business with $9M in senior debt at 8.5% and $3M in mezzanine at 14.5% has roughly $1.3M in true free cash flow after full service — not $3.9M. The difference can make or break a deal thesis.
Every LBO waterfall model starts with an accurate representation of each debt tranche. The minimum attributes you need for each instrument are the outstanding principal, the annual interest rate, and the required annual principal payment. In practice you also want the tranche name and its position in the priority stack, since that order drives everything else.
Before cash flows to debt service, two additional deductions reduce operating cash flow: capital expenditure requirements (which sustain the asset base that generates earnings) and cash taxes on post-interest income. Many simplified models skip cash taxes entirely, which overstates available cash for service by 25–35% depending on the tax jurisdiction.
The implementation below structures each debt tranche as a dataclass and runs the waterfall logic through a single run() method on a parent model. This design keeps the tranche attributes immutable while letting the waterfall execute cleanly against any operating cash flow input.
from dataclasses import dataclass, field
from typing import List, Dict
@dataclass
class DebtTranche:
name: str
principal: float # outstanding balance
rate: float # annual interest rate as decimal
required_amortization: float # mandatory annual principal payment
priority: int # 1 = most senior
@dataclass
class WaterfallModel:
ebitda: float
capex: float
tax_rate: float
tranches: List[DebtTranche] = field(default_factory=list)
def run(self) -> Dict:
# Sort tranches by priority (most senior first)
ordered = sorted(self.tranches, key=lambda t: t.priority)
# Compute total interest for tax shield calculation
total_interest = sum(t.principal * t.rate for t in ordered)
taxable_income = self.ebitda - total_interest
cash_taxes = max(0, taxable_income * self.tax_rate)
# Cash available after capex and taxes
available = self.ebitda - self.capex - cash_taxes
results = []
for tranche in ordered:
interest = tranche.principal * tranche.rate
total_service = interest + tranche.required_amortization
dscr = available / total_service if total_service > 0 else float('inf')
available -= total_service
results.append({
'tranche': tranche.name,
'interest': round(interest, 2),
'amortization': tranche.required_amortization,
'total_service': round(total_service, 2),
'dscr': round(dscr, 2),
'cash_after_service': round(available, 2),
})
return {
'ebitda': self.ebitda,
'capex': self.capex,
'cash_taxes': round(cash_taxes, 2),
'total_interest': round(total_interest, 2),
'free_cash_flow': round(available, 2),
'tranches': results,
}
The debt service coverage ratio — EBITDA available for service divided by total debt service due — is the single number lenders watch most closely. A ratio below 1.0x means the business cannot cover its own debt obligations from operating cash flow, which typically triggers default provisions. But even ratios above 1.0x can represent thin margins that make covenant compliance brittle.
| DSCR Range | Interpretation | Lender Signal |
|---|---|---|
| Below 1.0x | Cash flow insufficient to cover service | Covenant breach, potential default |
| 1.0x – 1.15x | Barely covering; no cushion | Elevated scrutiny; covenant waiver likely needed |
| 1.15x – 1.35x | Adequate but tight; standard for mezz debt | Within typical covenant thresholds |
| 1.35x – 2.0x | Comfortable coverage; senior debt territory | Favorable terms; prepayment conversation possible |
| Above 2.0x | Strong coverage; possible over-equity at acquisition | Refinancing or dividend recapitalization opportunity |
Consider a $15M revenue light manufacturing business acquired in an LBO at 5.5x EBITDA. The deal is structured with two tranches: $9M in senior secured debt at 8.5% with 7% annual amortization, and $3M in mezzanine debt at 14.5% with PIK interest allowed in year one. The business generates $2.7M in EBITDA and requires $400K in annual maintenance capex.
senior = DebtTranche(
name="Senior Secured",
principal=9_000_000,
rate=0.085,
required_amortization=630_000, # 7% of balance
priority=1
)
mezzanine = DebtTranche(
name="Mezzanine",
principal=3_000_000,
rate=0.145,
required_amortization=0, # PIK year one
priority=2
)
model = WaterfallModel(
ebitda=2_700_000,
capex=400_000,
tax_rate=0.26,
tranches=[senior, mezzanine]
)
result = model.run()
# Free cash flow to equity: ~$1,310,000
# Senior DSCR: 1.47x | Blended DSCR after both tranches: 1.19x
The model surfaces a 1.47x DSCR at the senior tranche — comfortable — but drops to 1.19x after accounting for mezzanine interest. With the senior lender's covenant typically set at 1.25x minimum on blended service, this deal operates with only 40 basis points of EBITDA cushion before a breach. A 15% revenue miss would push the company into covenant violation territory in year one.
"The waterfall tells you where the money actually goes. Everyone negotiates on EBITDA multiples, but the number that determines whether the deal works is free cash flow after full debt service — and those two numbers are rarely the same."
Once the waterfall is running cleanly, the natural follow-on question is capital structure optimization: should excess free cash flow go toward accelerated principal repayment, or toward refinancing the most expensive tranche? The answer depends on the prepayment penalty, the current rate environment, and whether DSCR improvement creates meaningful covenant headroom.
Mezzanine debt — typically carrying 200–400 basis points more than senior — is almost always the priority target. Every dollar of mezzanine retired eliminates 14–17 cents in annual interest expense with no prepayment penalty in most structures after year three. At $3M outstanding, refinancing the mezzanine tranche with proceeds from a senior revolver expansion (at 8.5% versus 14.5%) saves $180K annually — which in a business with $1.3M of free cash flow is a meaningful improvement in equity return.
The waterfall model makes these decisions transparent. Rather than arguing about blended cost of capital in the abstract, operators and sponsors can run the model forward with each scenario and see precisely how the DSCR profile and equity cash flow change across a three-to-five-year hold period.
We build waterfall models, DSCR dashboards, and scenario analyses for PE-backed companies and their lenders.
Talk to Our Team