Does anything beat buy & hold on S&P 500 Index (SPX)?
Every setup we tested on S&P 500 Index (SPX) — ranked out-of-sample, corrected for multiple testing, and forward-tracked in public from the day this page published. The honest answer is the headline.
No setup beat simply holding once tested honestly. We say so plainly.
Its best setup trailed buy-and-hold out-of-sample. Buy-and-hold benchmark: +19.5% CAGR over 2.9 years (+18.7% CAGR in the out-of-sample window).
Educational research from historical backtests — not investment advice. Past performance does not predict future results.
S&P 500 Index: Nothing Beat Buy-and-Hold, and That Is the Honest Answer
Broad, diversified instruments like S&P 500 Index are where indicator strategies go to disappoint. We ran 1,514 setups against GSPC, and none cleared the bar once scored honestly — on data the strategy never saw. The best of the batch, RSI Mean-Reversion on the 1-hour timeframe, posted an out-of-sample Sharpe of 2.06, short of the 4.03 hurdle we require before calling anything real. For an index fund this is the expected result: whatever inefficiency exists in single names tends to average away in the basket, leaving buy-and-hold's +19.5% annualized return as the number nothing here managed to beat.
Read these figures with the selection problem in mind. Test 1,514 indicators, keep the best, and the winner looks impressive by construction — which is exactly why the hurdle exists instead of applause for a lucky draw. Here, only 0.2% of setups outperformed buy-and-hold even in-sample, and the top candidate produced -4.8% annual alpha over 0.9 unseen years, across 36 trades with a 83.3% win rate and a -8.4% drawdown. That pattern reads as noise, not signal. Markets also change, so even a genuine past edge can fade. This page documents what failed — useful to know before assuming something works.
Every figure above is computed from our own backtests — nothing is estimated or invented. Hypothetical results; not investment advice.
The least-bad setups — shown with their failure numbers
Nothing here earned a verdict — these are the best of a losing field, published so you can see exactly how "best" still failed.
RSI Mean-Reversion
Mechanical rule (exactly as backtested): Buy oversold bounces — enter when RSI(14) crosses back above 30, exit above 55. Signals are evaluated at 1-hour-bar close, the position changes on the NEXT bar, 0.08% cost per side, long/flat only — no leverage, no shorting.
Out-of-sample (last ~30% of the window, never used to pick this setup): Sharpe 2.06 · alpha -4.8% · 14 trades over 0.9 yrs.
Hull MA 30 Trend
Mechanical rule (exactly as backtested): VARIANT — price above a rising Hull MA(30). Signals are evaluated at 4-hour-bar close, the position changes on the NEXT bar, 0.08% cost per side, long/flat only — no leverage, no shorting.
Out-of-sample (last ~30% of the window, never used to pick this setup): Sharpe 1.79 · alpha -3.3% · 25 trades over 1.2 yrs.
Nadaraya-Watson Envelope
Mechanical rule (exactly as backtested): Causal Gaussian kernel-regression envelope (LuxAlgo concept) — long when price dips below the lower band. Signals are evaluated at 1-hour-bar close, the position changes on the NEXT bar, 0.08% cost per side, long/flat only — no leverage, no shorting.
Out-of-sample (last ~30% of the window, never used to pick this setup): Sharpe 1.62 · alpha -11.5% · 11 trades over 0.9 yrs.
Since publication — including if it loses
The forward record is just getting started — the gap between the two is the honest score. Marked to market nightly from real prices, rules frozen at publication, as of 2026-07-02. Currently FLAT.
We tested 1,514 setups (indicator × parameters × timeframe) on S&P 500 Index (SPX). Only setups with ≥30 trades qualify (1,407 did). Setups are ranked by out-of-sample Sharpe — the last ~30% of history, which standard-parameter rules never saw during selection. Because picking the best of 1,514 tries mines even the holdout, the VALIDATED verdict additionally requires the top setup’s OOS Sharpe to clear a selection hurdle of 4.03 (√(2 ln N)/√T) AND positive alpha in both windows. Of the eligible setups, 0.2% had positive out-of-sample alpha (median OOS Sharpe 0.21) — the table below is truncated, but this summary covers all of them. Full recipe: methodology · the engine’s contract lives in the repo as STRATEGY_METHODOLOGY.md.
Top 20 of 1,407 eligible setups
Ranked by out-of-sample Sharpe. Full + out-of-sample columns, costs included. Hypothetical.
| # | Setup | TF | Total ret | Sharpe | Max DD | Win | Trades | α vs B&H | OOS Sharpe | OOS α | OOS trades |
|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | RSI Mean-Reversion | 1-Hour | +16.7% | 0.7 | -8.4% | 83.3% | 36 | -14.0% | 2.06 | -4.8% | 14 |
| 2 | Hull MA 30 Trend | 4-Hour | +27.4% | 1.16 | -6.6% | 46.3% | 95 | -7.7% | 1.79 | -3.3% | 25 |
| 3 | Nadaraya-Watson Envelope | 1-Hour | +7.7% | 0.46 | -9.8% | 63.9% | 36 | -16.9% | 1.62 | -11.5% | 11 |
| 4 | Zero-Lag LSMA | 4-Hour | +9.7% | 0.29 | -17.1% | 45.5% | 110 | -11.7% | 1.51 | -2.7% | 30 |
| 5 | Keltner Mean-Reversion | 1-Hour | +3.4% | 0.18 | -13.1% | 66.2% | 71 | -18.4% | 1.41 | -7.5% | 23 |
| 6 | Connors RSI | 4-Hour | +13.4% | 0.42 | -12.8% | 61.3% | 75 | -10.9% | 1.34 | -5.2% | 26 |
| 7 | Stoch RSI (fast) | 4-Hour | +19.1% | 0.51 | -12.1% | 41.2% | 165 | -9.5% | 1.23 | -4.4% | 45 |
| 8 | Chaikin Oscillator | 4-Hour | +16.2% | 0.47 | -23.1% | 44.7% | 85 | -10.2% | 1.22 | -3.4% | 28 |
| 9 | A/D Oscillator | 4-Hour | +16.2% | 0.47 | -23.1% | 44.7% | 85 | -10.2% | 1.22 | -3.4% | 28 |
| 10 | EMA 10/40 Cross | 1-Hour | +18.5% | 0.69 | -18.0% | 35.3% | 68 | -13.5% | 1.2 | -8.7% | 18 |
| 11 | Ehlers TrendFlex | 4-Hour | +48.6% | 1.33 | -7.5% | 51.4% | 35 | -3.4% | 1.17 | -4.1% | 12 |
| 12 | Elder Ray (Bull/Bear Power) | 4-Hour | +24.6% | 0.78 | -16.7% | 36.7% | 90 | -8.3% | 1.16 | -5.3% | 30 |
| 13 | FRAMA 100 Trend | 4-Hour | +24.8% | 0.74 | -13.5% | 42.2% | 135 | -8.3% | 1.12 | -5.8% | 37 |
| 14 | Impulse MACD | 4-Hour | +6.8% | 0.35 | -6.0% | 38.1% | 126 | -12.5% | 1.12 | -7.8% | 33 |
| 15 | Williams %R | 4-Hour | +8.9% | 0.27 | -15.8% | 68.9% | 45 | -11.9% | 1.11 | -6.7% | 14 |
| 16 | Adaptive Supertrend | 4-Hour | +40.1% | 1.05 | -16.2% | 45.6% | 57 | -5.1% | 1.1 | -5.1% | 19 |
| 17 | KDJ | 4-Hour | +12.5% | 0.36 | -17.6% | 42.2% | 154 | -11.1% | 1.1 | -5.6% | 44 |
| 18 | WaveTrend (8/6/4) | 1-Hour | +31.2% | 0.89 | -11.1% | 77.3% | 75 | -9.7% | 1.1 | -7.6% | 25 |
| 19 | Triangular Hull MA | 4-Hour | +28.1% | 1.11 | -5.8% | 44.8% | 96 | -7.5% | 1.09 | -7.0% | 25 |
| 20 | Bollinger Mean-Reversion | 1-Hour | +6.0% | 0.28 | -11.1% | 66.7% | 84 | -17.5% | 1.09 | -10.2% | 24 |
Hypothetical backtests with 0.08%/side costs. Not investment advice — see the full disclaimer.
These are historical backtests of mechanical rules. They are educational research, not investment advice, not a recommendation, and not tailored to you. Educational information only — not investment advice. Hypothetical backtested results; past performance does not guarantee future results. Trading involves risk of loss.