Does anything beat buy & hold on ExxonMobil (XOM)?
Every setup we tested on ExxonMobil (XOM) — 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: +9.5% CAGR over 3.9 years (+28.4% CAGR in the out-of-sample window).
Educational research from historical backtests — not investment advice. Past performance does not predict future results.
XOM: we tested 1,518 setups and none beat simply holding ExxonMobil
For ExxonMobil (XOM), we ran 1,518 indicator configurations against a plain buy-and-hold benchmark, and none of them earned the right to replace it. Individual stocks carry idiosyncratic risk — earnings surprises, guidance changes, sector rotation — that indicators built on price history cannot see coming. The best-looking setup, Bullish Engulfing on the 4-hour timeframe, ranked at the top in-sample but delivered an out-of-sample Sharpe of 2.18, short of our hurdle of 3.49. Buy-and-hold returned +9.5% annualized over the test period; the top strategies mostly captured pieces of that same move while adding trading friction.
How to read this honestly: when you test 1,518 setups and keep the best one, something will always look impressive by chance alone. That is why we require the survivor to clear 3.49 out of sample. Bullish Engulfing managed 2.18, with out-of-sample alpha of -10.0% across 1.2 years and 62 trades, and only 0.4% of everything we tested beat the benchmark on unseen data — roughly what luck would produce. None of this predicts anything: the regime that generated these numbers can shift, and single stocks shift faster than most. Treat this page as a record of what failed under honest testing, not a forecast.
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.
Bullish Engulfing
Mechanical rule (exactly as backtested): Classic bullish-engulfing reversal — enter long, hold a short horizon. 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 2.18 · alpha -10.0% · 16 trades over 1.2 yrs.
Supertrend (10,3)
Mechanical rule (exactly as backtested): Follow the Supertrend (10,3) — long while the ATR trend flips bullish. 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.1 · alpha +2.6% · 20 trades over 0.9 yrs.
Supertrend (20,3)
Mechanical rule (exactly as backtested): VARIANT — Supertrend ATR 20 ×3; long while bullish. 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.09 · alpha +1.2% · 20 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,518 setups (indicator × parameters × timeframe) on ExxonMobil (XOM). Only setups with ≥30 trades qualify (1,418 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,518 tries mines even the holdout, the VALIDATED verdict additionally requires the top setup’s OOS Sharpe to clear a selection hurdle of 3.49 (√(2 ln N)/√T) AND positive alpha in both windows. Of the eligible setups, 0.4% had positive out-of-sample alpha (median OOS Sharpe 0.16) — 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,418 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 | Bullish Engulfing | 4-Hour | +39.8% | 1.04 | -10.6% | 58.1% | 62 | -0.5% | 2.18 | -10.0% | 16 |
| 2 | Supertrend (10,3) | 1-Hour | +31.5% | 0.64 | -20.2% | 38.4% | 73 | -3.1% | 2.1 | +2.6% | 20 |
| 3 | Supertrend (20,3) | 1-Hour | +28.3% | 0.6 | -20.4% | 45.9% | 74 | -4.0% | 2.09 | +1.2% | 20 |
| 4 | CCI | 4-Hour | +49.8% | 0.9 | -14.9% | 81.1% | 37 | +1.5% | 2.09 | -1.7% | 12 |
| 5 | Supertrend (14,4) | 1-Hour | +29.5% | 0.63 | -17.8% | 38.9% | 54 | -3.7% | 1.95 | -3.7% | 16 |
| 6 | Supertrend (7,3) | 1-Hour | +20.6% | 0.47 | -22.3% | 36.8% | 76 | -6.4% | 1.89 | -2.5% | 21 |
| 7 | UT Bot (ATR Trailing) | 4-Hour | +2.2% | 0.11 | -37.0% | 38.9% | 108 | -8.9% | 1.87 | +3.0% | 28 |
| 8 | Morning Star | 4-Hour | +15.6% | 0.45 | -17.4% | 60.0% | 60 | -5.7% | 1.83 | -12.4% | 17 |
| 9 | Stochastic RSI | 4-Hour | +35.2% | 0.75 | -20.5% | 63.6% | 55 | -1.4% | 1.78 | -6.7% | 17 |
| 10 | ADX / DMI | 1-Hour | -4.2% | -0.03 | -28.8% | 38.8% | 152 | -14.5% | 1.72 | -14.8% | 42 |
| 11 | RSI Mean-Reversion | 1-Hour | +27.6% | 0.79 | -12.7% | 72.5% | 40 | -4.3% | 1.62 | -26.3% | 11 |
| 12 | Bullish Engulfing | 1-Hour | -7.7% | -0.15 | -30.9% | 43.8% | 258 | -15.8% | 1.6 | -21.6% | 72 |
| 13 | Stochastic | 4-Hour | +83.6% | 1.24 | -12.3% | 83.3% | 36 | +7.5% | 1.52 | -5.5% | 11 |
| 14 | SMC: Fair Value Gap | 1-Hour | -17.8% | -0.33 | -42.9% | 35.9% | 256 | -19.7% | 1.48 | -16.3% | 72 |
| 15 | Negative Volume Index | 1-Hour | +38.4% | 0.68 | -21.2% | 55.4% | 56 | -1.1% | 1.47 | -3.5% | 17 |
| 16 | ROC (30) | 1-Hour | +0.1% | 0.09 | -33.4% | 33.5% | 170 | -13.0% | 1.47 | -13.3% | 43 |
| 17 | CMO (30) | 1-Hour | +0.1% | 0.09 | -33.4% | 33.5% | 170 | -13.0% | 1.47 | -13.3% | 43 |
| 18 | Momentum (30) | 1-Hour | +0.1% | 0.09 | -33.4% | 33.5% | 170 | -13.0% | 1.47 | -13.3% | 43 |
| 19 | T3 30 Trend | 1-Hour | +4.0% | 0.17 | -28.9% | 35.3% | 102 | -11.7% | 1.45 | -16.6% | 25 |
| 20 | WaveTrend (8/6/4) | 1-Hour | +32.5% | 0.69 | -13.7% | 65.0% | 80 | -2.8% | 1.43 | -20.7% | 23 |
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.