Fundamentals Above average
55.8 / 100How the books look — profitability, leverage, valuation, growth. · 46 metrics weighted.
Fiscal Wizard · Single-issue tearsheet
Run #6Composite verdict
Above-average across fundamentals and technicals.
Industry rank 5th of 25 in Software - Application
Fundamentals Above average
55.8 / 100How the books look — profitability, leverage, valuation, growth. · 46 metrics weighted.
Technicals Above average
63.0 / 100How the chart looks — momentum, trend, volume, volatility. · 31 signals weighted.
Breakdown
Empty pane
Every chip in either subscore card drills into the metrics or signals that fed it — including the formula, the threshold band, and what the current reading means for DT.

Fundamentals · Valuation
Weak Valuation — most metrics in this section are scoring below the professional bands' midpoints.
Cheap on cash earnings — but check whether D&A is masking real reinvestment needs that EBITDA doesn't capture. The 'EBITDA isn't free cash flow' trap is most painful here.
| Raw value | 48.8x |
|---|---|
| Score (0-100) | 0.00 |
| Weight | 1.000× |
| Direction | lower |
What it would cost to take over the entire firm (equity plus debt, less cash) per dollar of pre-interest, pre-tax, pre-depreciation operating earnings. Capital-structure-agnostic — directly comparable across heavily and lightly levered businesses, which a P/E can't do. The weakness: EBITDA ignores capex, so capital-intensive businesses look artificially cheap on this metric. Cross-check with EV/FCF when capex is meaningful.
EV = market_cap + total_debt + preferred_equity + minority_interest - cash; EV/EBITDA = EV / ebitda_ttm
EV/FCF in the broad-market range. Most large-cap industrials and consumer staples cluster here.
| Raw value | 25.8x |
|---|---|
| Score (0-100) | 47.32 |
| Weight | 1.000× |
| Direction | lower |
Valuation expressed against the cash actually available to all capital providers after capex. Often more honest than EV/EBITDA when capital expenditure is meaningful relative to depreciation, because EBITDA ignores capex entirely while FCF reflects it. The cleanest single-number 'what would I pay to own this whole business?' valuation lens for capital-intensive firms.
EV/FCF = (market_cap + total_debt - cash) / free_cash_flow_ttm
Cheap on revenue once you account for the balance sheet. Confirm gross margin is structurally workable and the business isn't carrying invisible debt that compresses the equity claim.
| Raw value | 6.5x |
|---|---|
| Score (0-100) | 0.00 |
| Weight | 1.000× |
| Direction | lower |
Adjusts the numerator for debt and cash so heavily-levered or cash-rich companies become comparable on a revenue-multiple basis. Particularly useful for cross-industry valuation work where some firms run net cash and others carry meaningful debt loads. Same caveats as P/S: best read alongside gross margin to translate the multiple into expected steady-state earnings power.
EV/Sales = (market_cap + total_debt - cash) / revenue_ttm
Forward multiple in the broad-market range. Read with the gap to trailing P/E — a widening gap implies analysts expect strong forward growth.
| Raw value | 21.0x |
|---|---|
| Score (0-100) | 40.87 |
| Weight | 1.000× |
| Direction | lower |
The multiple equity analysts most commonly quote because it reflects expected earnings rather than the trailing window. Same caveats as trailing P/E plus one extra: the denominator depends on consensus estimates, which can be systematically optimistic going into a downturn or pessimistic at a cyclical trough. Worth cross-checking against trailing P/E and sell-side estimate trend.
Forward P/E = price / forward_eps
Limited operating earnings against EV — growth or quality must justify the valuation.
| Raw value | 1.61% |
|---|---|
| Score (0-100) | 0.00 |
| Weight | 1.000× |
| Direction | higher |
Capital-structure-agnostic earnings yield. Pairs with Greenblatt ROC to compute the famous Magic Formula rank (the universe-rank of earnings yield plus universe-rank of return on capital). Pre-tax operating earnings divided by the full claim on the firm gives a cleaner cross-firm valuation comparison than P/E or earnings yield alone, because it strips out the distortions from leverage, cash, and tax structure.
Greenblatt EY = EBIT / Enterprise Value * 100
P/B in the broad-market range. Read alongside ROE: a 3x P/B with 25% ROE is more defensible than a 3x P/B with 8% ROE.
| Raw value | 4.4x |
|---|---|
| Score (0-100) | 51.66 |
| Weight | 1.000× |
| Direction | lower |
Share price divided by per-share book value of common equity — what the market values the franchise at versus what the accountants say it's worth on paper. Most informative for asset-heavy businesses (banks, insurers, industrials) where book value approximates a liquidation floor; far less informative for asset-light franchises whose value sits in brand, software, or other intangibles that GAAP under-states or excludes entirely.
P/B = market_cap / common_equity
Either a genuine bargain or earnings about to fall. Check FCF margin, cash conversion, and forward EPS estimates before assuming it's a value play — single-digit P/Es most often pair with structural decline or a heavily cyclical business at the top of its earnings cycle.
| Raw value | 25.3x |
|---|---|
| Score (0-100) | 21.36 |
| Weight | 1.000× |
| Direction | lower |
How many dollars of share price the market is willing to pay for one dollar of trailing-twelve-month earnings. The universal valuation anchor for profitable companies — useful for cross-sector comparison and as a quick read on whether the market expects earnings growth, decline, or a quality re-rating. Sensitive to one-off items in the denominator (write-downs, tax holidays, share buybacks); pair with EV/EBITDA when capital structure or non-cash charges look noisy.
P/E = market_cap / net_income_ttm
Cheap on revenue. Investigate whether margins are structurally low (commodity producer, contract manufacturer) or revenue quality is poor (one-time contracts, channel-stuffing).
| Raw value | 7.1x |
|---|---|
| Score (0-100) | 0.00 |
| Weight | 1.000× |
| Direction | lower |
Useful when earnings are negative, noisy, or one-time-distorted (early-stage growth, restructurings, cyclical troughs). Works best within an industry, not across — gross margin profiles vary so wildly that 1x P/S for a software company means something completely different from 1x P/S for a grocery chain.
P/S = market_cap / revenue_ttm
Multiple looks cheap relative to recent growth. The trap: confirm the growth is sustainable, not a one-off rebound off a depressed prior period or a margin spike that's about to mean-revert.
| Raw value | 0.12 |
|---|---|
| Score (0-100) | 12.30 |
| Weight | 1.000× |
| Direction | target |
Divides the trailing P/E by the annualised three-year EPS growth rate (in percentage points). Below 1.0 is conventionally read as 'cheap relative to growth'; above 2 implies the multiple is well ahead of recent growth. Sensitive to which growth window you choose and unstable when earnings cross zero — flips sign or explodes when prior EPS is negative.
PEG = (P/E) / eps_growth_3y_pct
| Raw value | — |
|---|---|
| Score (0-100) | — |
| Weight | 1.000× |
| Direction | target |
Peter Lynch's adjustment to PEG: adds the dividend yield to the growth rate in the denominator so that mature dividend payers don't get unfairly punished by a low growth rate alone. Sweet spot is 1.0 (P/E equals growth plus yield); below 0.5 often signals a broken growth assumption rather than genuine value; above 2 is over-paying.
PEGY = (P/E) / (eps_growth_rate_pct + dividend_yield_pct)

Fundamentals · Profitability
Above-average Profitability — more positives than negatives in this section.
Heavy assets needed per dollar of revenue — utilities, telecoms, heavy industrial, capital goods. Often the right number for the industry, but compounds the impact of any margin compression.
| Raw value | 0.45 |
|---|---|
| Score (0-100) | 12.50 |
| Weight | 1.000× |
| Direction | higher |
Productivity of the asset base — how efficiently the firm converts assets into sales. Combined with net margin, this is the core of the DuPont decomposition: ROA = net margin × asset turnover. Two businesses can land at the same ROA via opposite paths: thin-margin / high-turnover (Costco, supermarkets) vs. fat-margin / low-turnover (luxury, software).
Asset Turnover = revenue_ttm / average_total_assets
Heavy capex needed per dollar of revenue — utilities, energy, semiconductor, and heavy industrial territory. Often the right number for the industry, but raises the bar for FCF generation.
| Raw value | 1.54% |
|---|---|
| Score (0-100) | 89.75 |
| Weight | 1.000× |
| Direction | lower |
Lower is generally better for shareholder cash returns — less of every dollar of revenue gets reinvested in maintaining the asset base. But very low values can flag under-investment in a capital-intensive business, which catches up later via deteriorating capacity or competitiveness. Pairs with FCF margin to separate 'thin operating margin' from 'fat operating margin offset by heavy capex'.
Capex to Sales = capital_expenditures_ttm / revenue * 100
Earnings quality is good — real cash arriving in step with reported income, sometimes more (when D&A overstates true economic depreciation).
| Raw value | 0.89 |
|---|---|
| Score (0-100) | 78.06 |
| Weight | 1.000× |
| Direction | target |
Sanity-check on earnings quality — a ratio of 1.0 means every dollar of GAAP earnings shows up as free cash flow. Persistently below 1.0 means working-capital build or capex is consuming earnings; persistently above 1.0 is unusual and may flag accounting conservatism (heavy non-cash charges) or a one-time release. Trend matters more than absolute level.
Cash Conversion = free_cash_flow_ttm / net_income_ttm
Thin EBITDA per dollar of revenue — exposed to input cost or wage shocks. Operating leverage works against the business when revenue dips.
| Raw value | 13.4% |
|---|---|
| Score (0-100) | 19.98 |
| Weight | 1.000× |
| Direction | higher |
Easier to compare than operating margin across firms with very different leverage and depreciation profiles, because it adds D&A back. Software platforms commonly run above 30%; capital-light service businesses cluster around 20%; capital-intensive industrials sit below 15%. The weakness: ignores the cash needed to maintain the asset base — pair with FCF margin for a complete profitability picture.
EBITDA Margin = ebitda / revenue * 100
Cash flowing through to owners — the hallmark of high-quality compounders. Capital-light franchises and software platforms cluster above 25%.
| Raw value | 25.4% |
|---|---|
| Score (0-100) | 100.00 |
| Weight | 1.000× |
| Direction | higher |
End-to-end conversion ratio: of every dollar of revenue, how much falls through to genuine free cash flow available to all capital providers? More honest than net margin because it accounts for the capex needed to maintain (and grow) the business. The single best indicator of whether the business is a quality compounder or a GAAP-earnings illusion.
FCF Margin = (free_cash_flow_ttm / revenue_ttm) * 100
FCF yield in the broad-market range. Compare to the 10-year treasury — the implied risk premium tells you whether the multiple is leaning on growth or pricing in a stable, durable cash stream.
| Raw value | 3.55% |
|---|---|
| Score (0-100) | 36.43 |
| Weight | 1.000× |
| Direction | higher |
Free cash flow the business throws off, divided by what the market currently charges for the equity. Treats the equity claim as a perpetual stream of free cash. More honest than earnings yield because it reflects the cash actually available to shareholders after all reinvestment. Cyclicals can swing below zero in a downturn — read with the trailing-cycle range.
FCF Yield = (free_cash_flow_ttm / market_cap) * 100
Operating capital is producing limited EBIT relative to its size. Either a capital-intensive business at the bottom of its margin cycle or a structurally low-return industry where reinvestment doesn't compound.
| Raw value | 29.3% |
|---|---|
| Score (0-100) | 31.85 |
| Weight | 1.000× |
| Direction | higher |
Joel Greenblatt's reformulation of return-on-capital, designed to filter for businesses that earn high pre-tax returns on the tangible operating capital that actually generates EBIT. Excludes goodwill, acquired intangibles, and financial assets so that two firms with the same operating economics rank similarly regardless of acquisition history. Pairs with Greenblatt's Earnings Yield (EBIT/EV) to produce the famous 'Magic Formula' rank — quality stocks at value prices.
Greenblatt ROC = EBIT / (working_capital + net_fixed_assets) * 100
Strong unit economics — software, branded consumer, and IP-heavy businesses cluster here. Defensible as long as the moat (brand, switching costs, network effect) holds.
| Raw value | 81.2% |
|---|---|
| Score (0-100) | 100.00 |
| Weight | 1.000× |
| Direction | higher |
First-line profitability measure — how much revenue is left after the direct cost of producing it. Stable or rising gross margin signals pricing power and low input-cost exposure; falling gross margin is one of the earliest reliable signals of competitive pressure or commodity-input squeeze. Industry context is everything: 30% gross margin is excellent for a grocery chain and disastrous for a software company.
Gross Margin = ((revenue_ttm - cogs_ttm) / revenue_ttm) * 100
Strong all-in profitability after every expense category. Sustainable when the operating margin engine is structural, not when net margin is temporarily inflated by tax holidays or one-time gains.
| Raw value | 28.5% |
|---|---|
| Score (0-100) | 100.00 |
| Weight | 1.000× |
| Direction | higher |
Operating margin minus interest, tax, and below-the-line items. Useful but noisier than operating margin: tax rate changes, debt-service shifts, and one-time items can move net margin year-over-year even when the operating business is unchanged. Always pair with operating margin and FCF margin — divergence between them is a tell about leverage, tax structure, or earnings quality.
Net Margin = (net_income_ttm / revenue_ttm) * 100
Operating cash flow validates net income — accrual quality is high, GAAP earnings are backed by real cash collection.
| Raw value | 0.95 |
|---|---|
| Score (0-100) | 89.97 |
| Weight | 1.000× |
| Direction | target |
Pre-capex version of cash conversion: compares operating cash flow directly to net income, before subtracting capex. Numbers persistently below 1.0 suggest accruals are doing the work (revenue recognised before cash collected, or expenses deferred). Numbers above 1.0 are typically driven by D&A exceeding true economic depreciation — a mild positive sign but not always meaningful.
OCF/NI = operating_cash_flow_ttm / net_income_ttm
Thin profit per dollar of revenue — exposed to input cost or wage shocks. Common in commodity producers, contract manufacturers, and unscaled businesses.
| Raw value | 10.6% |
|---|---|
| Score (0-100) | 18.54 |
| Weight | 1.000× |
| Direction | higher |
Captures the leverage between revenue and operating profit — the core test of whether a business converts sales into income at the operating level. Independent of capital structure (excludes interest) and tax-jurisdiction noise. Trend matters as much as level: an improving operating margin indicates pricing power or operational efficiency gains; a falling margin signals input-cost pressure, wage inflation, or competitive erosion.
Operating Margin = (operating_income_ttm / revenue_ttm) * 100
Assets are working hard — typical of asset-light, high-margin businesses (software, franchises, branded consumer).
| Raw value | 12.8% |
|---|---|
| Score (0-100) | 83.18 |
| Weight | 1.000× |
| Direction | higher |
Capital-efficiency measure that ignores how the assets are financed. Useful for comparing within a sector but heavily biased by industry — banks and utilities run low ROA by design (huge balance sheets), software and franchise businesses run high ROA (asset-light). The DuPont decomposition links it to ROE: ROE = ROA × (assets / equity) × (1/(1-tax)), so leverage inflates the gap between ROA and ROE.
ROA = (net_income_ttm / average_total_assets) * 100
Operating capital is producing weak returns — watch the gap to estimated cost of capital. Sustained ROCE below cost of capital destroys value as the business reinvests.
| Raw value | 6.5% |
|---|---|
| Score (0-100) | 0.00 |
| Weight | 1.000× |
| Direction | higher |
Pre-tax cousin of ROIC using operating capital employed (long-term debt plus equity, approximately equal to total assets minus current liabilities). Damodaran publishes ROCE by industry annually, so it benchmarks cleanly against sector norms. Particularly useful for capital-intensive businesses where you want to see pre-tax returns on the long-term capital base.
ROCE = ebit / (total_assets - current_liabilities) * 100
ROE in the broad-market range for large-cap profitable firms. Decompose via DuPont (margin × turnover × leverage) to see whether the engine is operating efficiency, asset turnover, or balance-sheet leverage.
| Raw value | 20.9% |
|---|---|
| Score (0-100) | 63.45 |
| Weight | 1.000× |
| Direction | higher |
The headline profitability metric. Net income divided by average book equity tells you how productive each dollar of shareholders' capital is. High sustained ROE compounds book value when the business can reinvest at a similar return. Two warnings: ROE rises mechanically with leverage (high D/E inflates ROE without making the business better), and aggressive buybacks can shrink the equity denominator faster than they shrink earnings, artificially boosting ROE even as fundamental returns are flat.
ROE = (net_income_ttm / average_common_equity) * 100
Operating capital is being deployed unproductively. Watch for businesses earning less than their cost of capital — every dollar of growth investment shrinks intrinsic value rather than growing it.
| Raw value | 12.5% |
|---|---|
| Score (0-100) | 20.34 |
| Weight | 1.000× |
| Direction | higher |
Measures how productive the actual operating capital base is, independent of capital structure. Strips out the effects of cash, leverage, and below-the-line items so you see the underlying economic engine. The benchmark is the firm's weighted-average cost of capital (WACC) — sustained ROIC above WACC creates value, sustained ROIC below WACC destroys it. The single most important profitability metric for long-term compounding.
NOPAT = operating_income_ttm * (1 - effective_tax_rate); invested_capital = shareholders_equity + total_debt - cash; ROIC = NOPAT / avg_invested_capital * 100
Fundamentals · Growth
Strong Growth — most metrics are scoring well above the professional bands' midpoints.
Earnings per share are compounding meaningfully. Decompose into revenue growth, margin expansion, and buyback contribution to understand the source.
| Raw value | 205.8% |
|---|---|
| Score (0-100) | 100.00 |
| Weight | 1.000× |
| Direction | higher |
Bottom-line growth on a per-share basis — captures both operating progress and any net buyback effect. The denominator uses the absolute value of prior EPS so a turnaround from negative to positive earnings reads with the conventional sign rather than producing arithmetic nonsense. Pair with revenue growth to separate real franchise expansion from buyback-driven per-share lift.
EPS Growth = (diluted_eps_ttm - diluted_eps_prior_ttm) / abs(diluted_eps_prior_ttm)
Top line is expanding meaningfully. Watch whether margins keep pace — high-margin growth compounds, discount-led growth often doesn't.
| Raw value | 18.7% |
|---|---|
| Score (0-100) | 74.98 |
| Weight | 1.000× |
| Direction | higher |
Top-line growth — the cleanest way to see whether the franchise is expanding. Best read alongside margin trend: revenue rising while margin compresses is often discount-driven volume rather than real growth, and can mask underlying weakness. Compare to industry peers — what looks weak in absolute terms can be best-in-sector if the industry is contracting.
Revenue Growth = (revenue_ttm - revenue_prior_ttm) / revenue_prior_ttm

Fundamentals · Balance Sheet
Strong Balance Sheet — most metrics are scoring well above the professional bands' midpoints.
Heavy cash backstop — common with profitable cash-rich franchises (mature tech, branded consumer). Provides resilience but also raises the question of why capital isn't being deployed.
| Raw value | 0.74 |
|---|---|
| Score (0-100) | 76.37 |
| Weight | 1.000× |
| Direction | target |
Strips out receivables and inventory entirely, leaving only cash and equivalents over current liabilities. Stress-tests whether the business can meet its near-term obligations even if collections seize up and inventory becomes unsaleable. The harshest, simplest liquidity check — used as a credit-stress indicator.
Cash Ratio = cash_and_equivalents / current_liabilities
Current ratio in the healthy range. Most large-cap industrials and consumer firms cluster between 1.5x and 2.5x.
| Raw value | 1.40 |
|---|---|
| Score (0-100) | 39.83 |
| Weight | 1.000× |
| Direction | target |
Whether the company can cover near-term obligations from near-term assets. Below 1.0 doesn't necessarily mean insolvent (operating cash flow can cover the gap), but it's worth a closer look. Conversely, very high current ratios can signal trapped working capital that's earning no return.
Current Ratio = current_assets / current_liabilities
Debt funds a heavy share of the asset base — returns are amplified, so are stress responses. Read alongside coverage and maturity profile.
| Raw value | 0.00 |
|---|---|
| Score (0-100) | 100.00 |
| Weight | 1.000× |
| Direction | lower |
Useful complement to debt-to-equity. Banks, REITs, and post-buyback firms can carry small or even negative book equity, which makes D/E unstable; D/A stays well-behaved because total assets is always positive. Industry context still matters — utilities run higher than software by design — but the comparability across capital structures is much better.
Debt-to-Assets = total_debt / total_assets
Capital structure is debt-heavy — amplifies equity returns in good times but also stress in downturns. Check interest coverage and refinancing windows.
| Raw value | 0.00 |
|---|---|
| Score (0-100) | 100.00 |
| Weight | 1.000× |
| Direction | lower |
How much the company funds itself with debt vs. equity. Higher leverage amplifies both returns (through ROE) and risk (through interest coverage and refinancing exposure). The 'right' level varies enormously by industry — utilities and REITs run higher than industrials, software runs near zero. Becomes unstable when book equity is small or negative; complement with debt-to-assets in those cases.
Debt-to-Equity = total_debt / common_equity
EBIT covers the interest bill many times over — balance sheet has plenty of breathing room even at trough earnings.
| Raw value | 179.4x |
|---|---|
| Score (0-100) | 100.00 |
| Weight | 1.000× |
| Direction | higher |
Solvency-under-stress measure. A ratio of 1x means EBIT exactly covers interest with nothing left over for taxes, capex, or principal; 5x is comfortable for an industrial; below 2x is a credit-watch level. Especially important when leverage is rising or profits are cyclical — the ratio should be evaluated at a stress-cycle EBIT, not the current peak.
Interest Coverage = EBIT / interest_expense
Permanent leverage is high. Check coverage ratios, debt maturity profile, and the spread between coupon and cost of capital — refinancing in a higher-rate environment can reset the economics meaningfully.
| Raw value | 0.00 |
|---|---|
| Score (0-100) | 100.00 |
| Weight | 1.000× |
| Direction | lower |
Strips out short-term operating debt and revolver use to focus on the permanent capital structure. Useful when comparing companies that fund working capital differently — a high D/E that's mostly short-term commercial paper means something different from a high D/E that's mostly long-dated bonds. Watch refinancing maturities alongside the level.
LT D/E = long_term_debt / common_equity
Net debt looks heavy relative to operating cash earnings — watch covenant headroom and refinancing windows.
| Raw value | -4.47 |
|---|---|
| Score (0-100) | 100.00 |
| Weight | 1.000× |
| Direction | lower |
Bond covenants are commonly written against this ratio because it directly answers 'how many years of operating cash earnings would it take to retire all the debt?' Above ~5x is high-yield territory for industrials; investment-grade industrials typically run below 3x. Negative net debt (more cash than debt) means the firm could pay off its bonds and still hold cash — a common position for mature tech.
Net Debt / EBITDA = (total_debt - cash_and_equivalents) / ebitda_ttm
| Raw value | — |
|---|---|
| Score (0-100) | — |
| Weight | 1.000× |
| Direction | target |
The acid-test variant of current ratio strips inventory from the numerator, since inventory can be stale, obsolete, or written down before it converts to cash. A purer view of near-term liquidity than current ratio. Sweet spot around 1.2x; below 0.5x signals real liquidity stress, above 3x suggests trapped working capital that could be returned to shareholders or reinvested.
Quick Ratio = (current_assets - inventory) / current_liabilities
Fundamentals · Efficiency
Weak Efficiency — most metrics in this section are scoring below the professional bands' midpoints.
| Raw value | — |
|---|---|
| Score (0-100) | — |
| Weight | 1.000× |
| Direction | lower |
The single best operations-quality metric. Negative CCC means the firm is funded by suppliers — the customer pays before the supplier needs to be paid (Apple, Costco, Amazon at scale). Long CCC ties up working capital and forces operating-loan dependence. Combines three sub-metrics: days inventory outstanding, days sales outstanding, days payable outstanding.
CCC = DIO + DSO - DPO
Cash collection is fast — high-quality receivables, typical of consumer-facing businesses where most sales are cash or card.
| Raw value | 132d |
|---|---|
| Score (0-100) | 0.00 |
| Weight | 1.000× |
| Direction | lower |
How long the average sale sits as a receivable before becoming cash. Earnings-quality flag: receivables growing faster than revenue is one of the cleanest tells for revenue recognition stretching — Beneish flagged exactly this pattern as a primary fraud indicator. Industry context matters: B2B / project businesses run longer DSO than retail, but the trend is more important than the level.
DSO = 365 * average_accounts_receivable / revenue
| Raw value | — |
|---|---|
| Score (0-100) | — |
| Weight | 1.000× |
| Direction | higher |
DuPont productivity measure. Combined with margin, it tells the asset-light vs. asset-heavy story: low turnover with high margin is the luxury / branded model, high turnover with thin margin is the supermarket / discount model. Very high turnover in retail can also flag stockouts (lost sales) — the metric reads best industry-relative, not absolute.
Inventory Turnover = cogs / average_inventory

Fundamentals · Income
Weak Income — most metrics in this section are scoring below the professional bands' midpoints.
| Raw value | — |
|---|---|
| Score (0-100) | — |
| Weight | 1.000× |
| Direction | stepped |
Direct cash income from holding the share. Stable dividend yield over time often signals capital discipline and predictable cash generation; abnormally high yield is frequently a warning that the dividend isn't covered by free cash flow and may be cut. Always read alongside payout ratio and FCF coverage.
Dividend Yield = (dividends_per_share_ttm / price) * 100
You're earning a small income yield on the cap — the rest of the expected return has to come from growth or multiple expansion. Risk: if growth disappoints, the multiple has nothing else to lean on.
| Raw value | 3.95% |
|---|---|
| Score (0-100) | 10.58 |
| Weight | 1.000× |
| Direction | higher |
Net income divided by market cap, expressed as a percent. Lets you compare equity earning power directly to bond yields: a 6% earnings yield is the equity-side analog to a 6% coupon, with the difference that earnings can grow (or contract) while a bond coupon is fixed. The standard 'is the equity risk-premium adequate?' framing.
Earnings Yield = (net_income_ttm / market_cap) * 100
| Raw value | — |
|---|---|
| Score (0-100) | — |
| Weight | 1.000× |
| Direction | target |
Sustainability check on the dividend yield. Below 30% means the dividend has substantial room to grow; 30–60% is the conventional sweet spot for a mature payer; above 85% is stretched and frequently precedes a cut. REITs and utilities run higher than the broad market by design — REIT payouts above 80% are normal because the structure requires distributing most income.
Payout Ratio = dividends_paid_ttm / net_income_ttm

Fundamentals · Composite
Strong Composite — most metrics are scoring well above the professional bands' midpoints.
Far from distress on Altman's classic formulation — strong combination of liquidity, profitability, and equity cushion against liabilities.
| Raw value | 5.60 |
|---|---|
| Score (0-100) | 84.31 |
| Weight | 1.000× |
| Direction | stepped |
Edward Altman's 1968 five-factor distress signal, originally calibrated against US public manufacturers that went bankrupt vs. those that didn't. Above 3.0 is the conventional 'safe' zone, 1.8–3.0 is the grey zone, below 1.8 historically associates with elevated bankruptcy risk within two years. Less reliable for non-manufacturing businesses, financial firms, and asset-light franchises — but the conceptual frame (liquidity + profitability + leverage cushion) translates broadly.
Z = 1.2X1 + 1.4X2 + 3.3X3 + 0.6X4 + 1.0X5; X1=working_capital/total_assets, X2=retained_earnings/total_assets, X3=ebit/total_assets, X4=market_cap/total_liabilities, X5=revenue/total_assets
| Raw value | — |
|---|---|
| Score (0-100) | — |
| Weight | 1.000× |
| Direction | stepped |
Beneish (1999) calibrated eight financial-statement indices against a sample of known earnings manipulators vs. matched controls. M < -2.22 reads as 'unlikely manipulator'; M ≥ -1.78 reads as 'likely manipulator'; the gap between is grey. Companion to Altman Z but for fraud risk rather than bankruptcy. Famously flagged Enron prior to the public disclosure of accounting fraud.
M = -4.84 + 0.92*DSRI + 0.528*GMI + 0.404*AQI + 0.892*SGI + 0.115*DEPI - 0.172*SGAI + 4.679*TATA - 0.327*LVGI
F-score in the middle band — some fundamentals improving, others not. Worth dissecting which of the nine criteria failed.
| Raw value | 5/9 |
|---|---|
| Score (0-100) | 52.50 |
| Weight | 1.000× |
| Direction | stepped |
Joseph Piotroski's 2000 score for distinguishing winners from losers among low-P/B value stocks. Asks nine yes/no questions across profitability (4 questions), leverage and liquidity (3 questions), and operating efficiency (2 questions); each 'yes' adds one point. The original study found that high-F-score value stocks meaningfully outperformed low-F-score value stocks, suggesting it's a useful filter for separating real value from value traps.
Sum of 9 binary indicators across profitability (ROA>0, CFO>0, ROA improving, CFO>NI), leverage (LT debt/assets falling, current ratio rising, no share issuance), and operating efficiency (gross margin rising, asset turnover rising)
Net income outpacing cash by an unusual amount — earnings quality may be deteriorating. Original Sloan research found this band associates with future earnings disappointments.
| Raw value | 0.023 |
|---|---|
| Score (0-100) | 90.96 |
| Weight | 1.000× |
| Direction | target |
Richard Sloan's 1996 accruals-quality measure. Persistent positive accruals (net income meaningfully exceeds cash flow) tend to mean-revert via earnings disappointments — Sloan documented that high-accruals firms underperform low-accruals firms over the following year. Large negative values are usually fine but can flag one-time working-capital releases or non-cash drags. Phase D-2 made this a target-window metric centred on zero.
Sloan = (net_income_ttm - operating_cash_flow_ttm - cash_flow_from_investing_ttm) / total_assets
Technicals · Momentum
Weak Momentum — most metrics in this section are scoring below the professional bands' midpoints.
Active pullback-short in an established downtrend — short-term pop into resistance fading off a 2-period overbought reading.
| Score (0-100) | 1.57 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 0 |
| Last trigger date | 2026-05-11 |
| Triggers in last 60 bars | 16 |
| Bars evaluated | 500 |
| Threshold upper | 90.000 |
| Threshold lower | 10.000 |
| Threshold mid | 50.000 |
| Indicator scale | 0.00 – 100.00 |
| Last bar value | 49.6565 |
Designed to buy oversold pullbacks within an established uptrend (price above the 200-day SMA). Uses a 2-period RSI rather than the standard 14 to make it hyper-responsive to short-term swings. Holds while RSI(2) is below an exit threshold and exits when RSI(2) crosses above 60 — a classic 1–4 day mean-reversion trade. Whipsaws hard outside an uptrend regime, hence the regime filter.
+1 when price is above regime_ma and RSI(2) drops below oversold; held while inside the trade; back to 0 when RSI(2) crosses above exit.
+1 = pullback-buy state active, 0 = flat. Bear-side variant uses the symmetric short rule.
period=2, oversold=10, exit=70, regime_ma=200
MACD histogram printing lower highs beneath higher highs in price — momentum is fading even as the tape grinds higher. Reversal-down confirmation tell.
| Score (0-100) | 43.29 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 37 |
| Last trigger date | 2026-03-18 |
| Triggers in last 60 bars | 1 |
| Bars evaluated | 500 |
| Last bar value | 0.5625 |
Compares price pivots against the MACD histogram (MACD line minus signal line) at those same bars. Bullish divergence: price makes a lower low, histogram makes a higher low — momentum is improving beneath the surface. Bearish divergence: price makes a higher high, histogram makes a lower high. Slower than the MACD signal cross but a richer confirmatory tell — the histogram captures momentum acceleration, not just direction.
+1 at the right-hand pivot of bullish divergence; -1 at right-hand pivot of bearish divergence; 0 otherwise.
+1 = bullish divergence, -1 = bearish divergence.
fast=12, slow=26, signal=9, pivot_window=5
MACD line crossed up through its signal line — short-term momentum trigger long. Strongest when in an uptrend regime.
| Score (0-100) | 68.85 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 14 |
| Last trigger date | 2026-04-21 |
| Triggers in last 60 bars | 2 |
| Bars evaluated | 500 |
| Last bar value | 0.9443 |
| Last bar signal | 0.3819 |
Fires on the bar where the MACD line (EMA12 minus EMA26) crosses through the signal line (EMA9 of MACD). Bullish when MACD crosses up through signal, bearish when it crosses down. Far more commonly used as a trade trigger than divergence — see macd_divergence for the slower confirmatory tell. Whipsaws in chop; cleanest when combined with a trend-regime filter.
+1 on bullish cross (MACD crosses up through signal); -1 on bearish cross (MACD crosses down through signal); 0 otherwise.
+1 = bullish MACD-signal cross, -1 = bearish MACD-signal cross.
fast=12, slow=26, signal=9
RSI and price are aligned — no divergence in the recent window. The signal isn't telling you anything; rely on other tools.
| Score (0-100) | 50.00 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 213 |
| Last trigger date | 2025-07-07 |
| Triggers in last 60 bars | 0 |
| Bars evaluated | 500 |
| Threshold upper | 70.000 |
| Threshold lower | 30.000 |
| Threshold mid | 50.000 |
| Indicator scale | 0.00 – 100.00 |
| Last bar value | 63.1847 |
When price prints a lower low while RSI prints a higher low at those same pivot bars, momentum is improving even though price is still falling — a classic bullish divergence that often precedes a reversal up. The bearish mirror fires when price makes a higher high but RSI prints a lower high, telegraphing exhausted upside. Divergences are confirmation tells rather than precise timing signals — best used as a 'something is changing under the surface' alert, not a trade trigger on their own.
+1 at the right-hand pivot of a (lower-low price, higher-low RSI) pair; -1 at the right-hand pivot of a (higher-high price, lower-high RSI) pair; 0 otherwise.
+1 = bullish divergence, -1 = bearish divergence, 0 = no divergence at this bar.
period=14, pivot_window=5, lookback=60
%K crossed down through %D from overbought — short-term sell trigger after a stretched-up move.
| Score (0-100) | 16.58 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 3 |
| Last trigger date | 2026-05-06 |
| Triggers in last 60 bars | 4 |
| Bars evaluated | 500 |
| Threshold upper | 80.000 |
| Threshold lower | 20.000 |
| Threshold mid | 50.000 |
| Indicator scale | 0.00 – 100.00 |
| Last bar value | 91.3324 |
| Last bar d | 88.8689 |
Bullish when %K crosses above %D while both lines are below the oversold threshold (typically 20); bearish when %K crosses below %D while both are above overbought (typically 80). Filters out mid-range stochastic crosses, which whipsaw in chop. Best used at well-defined ranges and at trend extremes.
+1 on bullish cross in oversold; -1 on bearish cross in overbought; 0 otherwise.
+1 = oversold bullish cross, -1 = overbought bearish cross.
k=14, d=3, smooth=3, ob=80, os=20
Technicals · Trend
Strong Trend — most metrics are scoring well above the professional bands' midpoints.
Price hugging its 52-week low — weakness regime, base-building candidates. Stocks at new lows tend to keep making new lows.
| Score (0-100) | 33.68 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 21 |
| Last trigger date | 2026-04-10 |
| Triggers in last 60 bars | 3 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
| Last bar upper | 56.6400 |
| Last bar lower | 32.3600 |
Reports whether the close sits within the configured proximity (default 2%) of the rolling 252-bar high or low. New-highs and new-lows are universally watched screening filters — momentum and breakout strategies start from here, and the broad market's new-high / new-low spread is a foundational breadth indicator.
+1 while close is within proximity of the 252-bar high; -1 while close is within proximity of the 252-bar low; 0 mid-range.
+1 = near 52-week high, -1 = near 52-week low, 0 = mid-range.
window=252, proximity=0.01
ADX below threshold — trend is weak, prefer mean-reversion to trend strategies right now.
| Score (0-100) | 96.93 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 2 |
| Last trigger date | 2026-05-07 |
| Triggers in last 60 bars | 26 |
| Bars evaluated | 500 |
| Threshold lower | 20.000 |
| Threshold mid | 25.000 |
| Indicator scale | 0.00 – 60.00 |
| Last bar value | 20.5104 |
ADX (Average Directional Index) measures trend strength regardless of direction — high ADX means a strong trend (in either direction), low ADX means chop. Below ~20 historically associates with sideways/choppy markets unfavourable to trend strategies and favourable to mean-reversion strategies. Used as a regime gate to disable trend-following systems when the tape isn't trending.
+1 while ADX is below the threshold (weak trend); 0 otherwise.
+1 = weak trend (chop) — typically a signal to disable trend strategies, not to trade direction.
period=14, weak_threshold=20
Active long breakout state — close above the N-day highest high. Trend-follow entry; cut on a close back below the breakout level.
| Score (0-100) | 100.00 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 0 |
| Last trigger date | 2026-05-11 |
| Triggers in last 60 bars | 59 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
| Last bar upper | 41.0000 |
| Last bar lower | 32.5800 |
Turtle-style breakout signal: enters long on a close above the highest high of the lookback window, short on a close below the lowest low. Holds the position for a fixed number of bars regardless of subsequent action. Cornerstone of trend-following strategies — runs hot in directional regimes, gets chopped up in range-bound markets.
+1 on long entry, held for hold_bars; -1 on short entry, held for hold_bars.
+1 = long breakout state, -1 = short breakout state.
period=20, hold_bars=20
Ichimoku components disagree — no clean setup either direction. Wait for alignment.
| Score (0-100) | 49.68 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 91 |
| Last trigger date | 2025-12-29 |
| Triggers in last 60 bars | 0 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
| Last bar tenkan | 38.2050 |
| Last bar kijun | 36.3175 |
| Last bar cloud_a | 37.1388 |
| Last bar cloud_b | 37.2250 |
Composite trend system: bullish when price is above the cloud (Kumo), the tenkan crosses above the kijun, and the cloud projected ahead is green (Senkou A above Senkou B). Bearish on the symmetric short-side configuration. The full bull/bear signal requires all three components to align, making it slower but cleaner than any single-line indicator.
+1 on bullish trigger conditions, -1 on bearish, 0 otherwise.
+1 = full Ichimoku bullish setup, -1 = full bearish setup.
tenkan=9, kijun=26, senkou_b=52
Fast MA above slow MA — bullish bias state held. Use as a directional gate for other long-side signals.
| Score (0-100) | 78.37 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 9 |
| Last trigger date | 2026-04-28 |
| Triggers in last 60 bars | 5 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
| Last bar fast | 39.5768 |
| Last bar slow | 38.5973 |
Holds +1 while the fast moving average is above the slow one (bullish bias) and -1 when below (bearish bias). The simplest possible directional bias gate. Whipsaws hard in chop because both averages bounce around the same level; works best when combined with a regime filter or used as an entry gate rather than a primary signal.
+1 while fast > slow, -1 while fast < slow.
+1 = bullish state (fast above slow), -1 = bearish state.
fast=12, slow=26, ma_type=ema
SAR flipped from above to below price — switch to long bias. Trail-stop long entries here.
| Score (0-100) | 74.14 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 14 |
| Last trigger date | 2026-04-21 |
| Triggers in last 60 bars | 5 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
| Last bar sar | 36.0778 |
The Parabolic SAR (Stop and Reverse) plots a dot above or below price; when price crosses the SAR, the trend side flips and the dot jumps to the opposite side. The flip event itself is the trade trigger. Works well in clean trends, gets whipsawed in chop.
+1 on flip from above-price (bearish) to below-price (bullish); -1 on flip the other way.
+1 = bullish flip, -1 = bearish flip.
accel=0.02, max_accel=0.2
Regime filter is unset — no long-term bias gate active.
| Score (0-100) | 50.00 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 196 |
| Last trigger date | 2025-07-30 |
| Triggers in last 60 bars | 0 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
| Last bar regime | 43.3011 |
Simplest possible regime filter: long-only when price is above its long-term MA (typically 200-day), flat or short-only when below. Often used as a gate on other signals — e.g., 'only take long pullback trades when the regime is bullish'. The 200-day SMA is the most-watched line on Wall Street and behaves as a self-fulfilling regime divider.
+1 while close > MA, -1 while close < MA.
+1 = bullish regime (above 200dma), -1 = bearish regime (below 200dma).
ma_period=200
Ticker outperforming the broad market by more than its trailing-year norm — sector or stock-specific tailwind in play.
| Score (0-100) | 98.94 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 0 |
| Last trigger date | 2026-05-11 |
| Triggers in last 60 bars | 18 |
| Bars evaluated | 500 |
| Last bar value | 0.0362 |
Computes the period-bar log-return spread (ticker minus SPY) and ranks the spread against its trailing 252-bar quantile. SPY = SPDR S&P 500 ETF Trust ('SPDR' = Standard & Poor's Depositary Receipts), the standard proxy for the US large-cap market. Ranking against the trailing window means the same threshold works in both gentle bull markets and high-volatility regimes — the metric is calibrated against the ticker's own history, not a fixed cutoff.
+1 while the ticker-vs-SPY spread is in the top high_pct of its trailing window; -1 while in the bottom low_pct; 0 otherwise.
+1 = clear outperformance regime, -1 = clear underperformance regime.
period=63, rank_window=252, high_pct=0.8, low_pct=0.2
Technicals · Price Action
Above-average Price Action — more positives than negatives in this section.
No notable doji in the recent window — indecision hasn't printed at a meaningful extreme.
| Score (0-100) | 50.29 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 93 |
| Last trigger date | 2025-12-24 |
| Triggers in last 60 bars | 0 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
Open and close are nearly equal (tiny body, under ~5% of the bar's range) with comparable upper and lower wicks. By itself, a doji marks indecision: buyers and sellers fought to a standstill within the bar. Meaningful when it appears at trend extremes (potential reversal) or after extended runs (potential exhaustion); meaningless in the middle of a chop range.
+1 on doji (the bar marks the indecision candle regardless of direction).
+1 = doji formed; direction depends on context (use with prior trend).
body_max=0.1, wick_balance=0.3
Active short setup on the bearish mirror — fade the 7-day high in a downtrend.
| Score (0-100) | 0.04 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 0 |
| Last trigger date | 2026-05-11 |
| Triggers in last 60 bars | 34 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
While price is above its 200-day MA (uptrend regime), buy when today's close is the lowest in 7 sessions; exit when today's close is the highest in 7 sessions. A simple, robust short-term mean-reversion system — works because pullbacks within an uptrend tend to be shallow and quickly retraced. Symmetrically, the bearish variant short-sells 7-day highs in downtrends.
+1 on entry day (new 7-day low above regime); held until exit on new 7-day high; back to 0 on exit.
+1 = pullback-buy state active, 0 = flat.
lookback=7, regime_ma=200
Down candle fully engulfed the prior up body after an uptrend — sellers took control inside one session. Reversal-down tell.
| Score (0-100) | 36.55 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 23 |
| Last trigger date | 2026-04-08 |
| Triggers in last 60 bars | 2 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
Bullish engulfing: a down candle followed by an up candle whose body fully covers the prior body. Bearish engulfing: an up candle followed by a larger down candle covering the prior body. Strongest when it appears after an established trend — the reversal candle erases the prior bar entirely, signalling a clear shift in short-term control.
+1 on bullish engulfing after a downtrend; -1 on bearish engulfing after an uptrend.
+1 = bullish engulfing reversal, -1 = bearish engulfing reversal.
prior_trend_window=5
Price wicked into a Fibonacci support level and closed back above it — the level held. Trend-continuation buy zone with the rejection candle itself as the confirmation.
| Score (0-100) | 98.53 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 1 |
| Last trigger date | 2026-05-08 |
| Triggers in last 60 bars | 46 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
Identifies the most recent significant swing high and low, projects the standard Fibonacci levels (23.6%, 38.2%, 50%, 61.8%, 78.6%) across the swing, and fires only when price rejects off one of those levels back in the prior-trend direction. In an active uptrend the trigger fires when a bar's low pierces a Fib support by up to 0.5 ATR and closes back above it; in a downtrend the mirror case fires at Fib resistance. A 2×ATR swing-range floor suppresses emission inside noisy consolidations where every level sits within one ATR of every other. Fibonacci levels are self-fulfilling support/resistance — heavily watched by chart-driven traders, so rejections at them tend to act as decision points whether the underlying ratios mean anything or not.
+1 in an uptrend when the bar's low pierces a Fib support (within atr_mult x ATR) and the close finishes above it. -1 in a downtrend when the bar's high pierces a Fib resistance and the close finishes below it. 0 otherwise.
+1 = bullish rejection at Fib support, -1 = bearish rejection at Fib resistance, 0 = no rejection event.
swing_lookback=60, levels=[0.236,0.382,0.5,0.618,0.786], atr_mult=0.5, atr_period=14
Inverse H&S confirmed — three-trough bottoming pattern that broke its neckline up. Conventional measured-move target is the head-to-neckline distance projected above the neckline.
| Score (0-100) | 67.65 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 13 |
| Last trigger date | 2026-04-22 |
| Triggers in last 60 bars | 1 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
Bearish head-and-shoulders: a left shoulder, a higher center peak (head), and a right shoulder of comparable height to the left, broken by a decisive close below the neckline (the line connecting the two intervening troughs). The inverse pattern — three troughs with a deeper middle and an upward neckline break — is bullish. Among the most-watched and most-cited topping/bottoming patterns in classical chart analysis.
+1 at neckline break of inverse-H&S; -1 at neckline break of standard H&S.
+1 = bullish inverse H&S confirmed, -1 = bearish H&S confirmed.
shoulder_tol=0.01, head_prom=0.03
Price tagged a key MA and bounced — moving average held as support. Trend-continuation entry, target the prior swing high.
| Score (0-100) | 92.17 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 6 |
| Last trigger date | 2026-05-01 |
| Triggers in last 60 bars | 33 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
When price comes within an ATR-relative band of a key moving average (typically 50- or 200-period) and reverses without closing through it, the MA is acting as support (in an uptrend) or resistance (in a downtrend). The cleanest trend-continuation entry — buy the pullback to a rising MA, sell the rally to a falling MA. The proximity band is sized as 0.5 × Wilder ATR(14), so a high-volatility name and a quiet utility get proportionally-scaled bands instead of a fixed percentage that fires constantly on one and almost never on the other. Failure of the rejection (a clean close through) is itself meaningful and often signals a regime change.
+1 when price prints a low near the MA in an uptrend and closes back above; -1 when price prints a high near the MA in a downtrend and closes back below.
+1 = bullish MA rejection (support held), -1 = bearish MA rejection (resistance held).
ma_periods=[50,200], atr_mult=0.5, atr_period=14
Price retested a prior high and rolled — multi-top resistance confirmed. The rejected level is distribution; failure to break it warns of a top.
| Score (0-100) | 23.03 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 7 |
| Last trigger date | 2026-04-30 |
| Triggers in last 60 bars | 3 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
Finds two or more pivot highs (tops) or lows (bottoms) within a price tolerance and minimum bar separation. Confirmed multi-bottom is bullish — the price level repeatedly defended is acting as support, suggesting a base. Multi-top is bearish — the level repeatedly rejected is acting as resistance, suggesting distribution. Pattern strength rises with the number of touches and the time between them.
+1 at confirmation of a multi-bottom (price retests prior low and holds); -1 at confirmation of a multi-top.
+1 = multi-bottom (support pattern), -1 = multi-top (resistance pattern).
peak_count=2, tolerance=0.01, min_sep=20
Long upper wick rejected the prior upswing — sellers stepped in at the high. Reversal-down candle, strongest at structural resistance.
| Score (0-100) | 38.97 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 24 |
| Last trigger date | 2026-04-07 |
| Triggers in last 60 bars | 1 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
A pin bar has a small real body (under ~30% of the bar's range) and a long wick (over ~60%) on one side, sticking out beyond the prior trend. Bullish pin: long lower wick after a downtrend, body near the top — price probed lower and was rejected, buyers absorbed the supply. Bearish pin: long upper wick after an uptrend, body near the bottom. Most reliable at structural levels (prior support/resistance, key MAs).
+1 for bullish pin (long lower wick, body near top, after downtrend); -1 for bearish pin.
+1 = bullish reversal candle, -1 = bearish reversal candle.
body_max=0.33, wick_min=0.67, prior_trend=5
No completed star pattern recently — the three-candle structure isn't formed.
| Score (0-100) | 50.05 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 130 |
| Last trigger date | 2025-10-31 |
| Triggers in last 60 bars | 0 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
Morning star (bullish): a big down candle, a small-body middle candle showing indecision, and a big up candle that closes well into the first body. Evening star is the bearish mirror at a top: big up, indecision, big down. The three-candle structure is more reliable than a single doji because it provides built-in follow-through confirmation.
+1 on confirmed morning star; -1 on confirmed evening star.
+1 = morning star (bullish reversal), -1 = evening star (bearish reversal).
middle_body_max=0.3, penetration=0.5
Outside-range bar after a downtrend closed up — buyers absorbed the prior decline and pushed past the prior window's range. Reversal-up pattern.
| Score (0-100) | 60.98 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 29 |
| Last trigger date | 2026-03-30 |
| Triggers in last 60 bars | 2 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
Two consecutive non-overlapping windows where the second window's high is above the first's high AND the second's low is below the first's low (an outside range). Reads as a reversal signal off the prior trend: an outside-range bar that closes against the prior direction is a structural shift in supply and demand, not noise.
+1 if prior trend was down and current outside-range closes higher than it opens; -1 in the symmetric down-reversal case.
+1 = bullish outside reversal, -1 = bearish outside reversal.
window=10
Decisive close above a downward trendline — resistance line gave way. Regime-change candidate; combine with volume to gauge conviction.
| Score (0-100) | 79.82 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 6 |
| Last trigger date | 2026-05-01 |
| Triggers in last 60 bars | 4 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
Fits a trendline through pivot points and flags decisive closes through the line. Distinguishes a clean break (close violates the line) from a wick-test (intra-bar tag that closes back inside the trend). Trendline breaks are early-warning regime-change signals — the prior trend's structure has been violated, and the next leg may move in the opposite direction.
+1 on close above a downward trendline; -1 on close below an upward trendline.
+1 = bullish breakout above resistance line, -1 = bearish breakdown below support line.
lookback=60, min_touches=3
Falling wedge resolved up — compression broke in favor of buyers. Continuation entry on the breakout retest.
| Score (0-100) | 99.90 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 0 |
| Last trigger date | 2026-05-11 |
| Triggers in last 60 bars | 30 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
A wedge is a price compression where two trendlines converge. Rising wedge (both lines sloping up but the upper less steep than the lower) typically resolves down — price runs out of room as buyers exhaust. Falling wedge (both lines sloping down with the lower less steep) typically resolves up. Compressions resolve eventually; the direction is what the wedge predicts.
+1 on confirmed break above falling wedge; -1 on confirmed break below rising wedge.
+1 = bullish wedge resolution, -1 = bearish wedge resolution.
lookback=40, min_touches=3
Technicals · Volume
Above-average Volume — more positives than negatives in this section.
Decline running on falling volume — sellers losing conviction. The down move is being maintained by inertia, not fresh selling. Reversal candidate.
| Score (0-100) | 95.23 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 0 |
| Last trigger date | 2026-05-11 |
| Triggers in last 60 bars | 10 |
| Bars evaluated | 500 |
| Last bar value | 1305877.0000 |
| Last bar sma | 5787228.8500 |
Trends backed by declining volume tend to lose conviction. The signal compares the slope of price against the slope of volume over a rolling window: if price keeps moving but volume is shrinking, fewer participants are committed to the move. Often precedes a stall or reversal because the move is running on inertia rather than fresh capital.
+1 when price is rising but volume slope is negative (weak rally); -1 when price is falling but volume slope is negative (weak decline / potential reversal).
+1 = weak uptrend (sell into strength), -1 = weak downtrend (cover or buy into weakness).
trend_window=20
Distribution beginning even as price breaks higher — smart money may be quietly exiting into strength. Reversal-down confirmation tell.
| Score (0-100) | 44.84 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 45 |
| Last trigger date | 2026-03-06 |
| Triggers in last 60 bars | 1 |
| Bars evaluated | 500 |
| Last bar value | 46229523.0000 |
OBV cumulates signed volume — adds volume on up days and subtracts it on down days. Rising OBV reflects accumulation, falling OBV distribution. Same pivot-pair divergence rule as RSI/MACD: when price makes a new low but OBV doesn't, big-money has stopped selling at the lows. When price makes a new high but OBV lags, the rally lacks volume confirmation — distribution may be quietly underway.
+1 at right-hand pivot of (price lower-low, OBV higher-low); -1 at right-hand pivot of (price higher-high, OBV lower-high).
+1 = bullish OBV divergence, -1 = bearish OBV divergence.
pivot_window=5, lookback=60
No climax bar in the recent window — volume profile is unremarkable.
| Score (0-100) | 50.61 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 78 |
| Last trigger date | 2026-01-16 |
| Triggers in last 60 bars | 0 |
| Bars evaluated | 500 |
| Last bar value | 1305877.0000 |
| Last bar sma | 5787228.8500 |
| Last bar threshold | 14468072.1250 |
Identifies bars whose volume is well above their recent average AND whose body is small relative to the bar's true range. The classic 'climax' shape: an exhaustion bar where heavy participation produced very little net price change, often marking short-term turning points after a directional run. Bullish climax (capitulation) prints near the low of the bar; bearish climax (distribution) prints near the high.
+1 (long-side capitulation) when the climax bar prints near its low; -1 (distribution) when it prints near its high.
+1 = capitulation/buying climax (potential reversal lower-to-higher), -1 = distribution/selling climax (potential reversal higher-to-lower).
vol_ma=20, spike_mult=2, body_range_max=0.5
Technicals · Volatility
Weak Volatility — most metrics in this section are scoring below the professional bands' midpoints.
ATR%-of-close in the top decile — elevated volatility regime, mean-reversion strategies have an edge as ranges over-extend.
| Score (0-100) | 89.07 |
|---|---|
| Weight | 1.000× |
| Last trigger value | 1.000 |
| Bars since trigger | 9 |
| Last trigger date | 2026-04-28 |
| Triggers in last 60 bars | 33 |
| Bars evaluated | 500 |
| Last bar value | 3.7924 |
Computes Wilder ATR over `period`, divides by close to get ATR%-of-close, then ranks each bar against the trailing `window` quantile. High-percentile readings flag elevated volatility regimes (mean-reversion strategies have an edge); low-percentile flags compression regimes (breakout strategies tend to lead, because compressed ranges resolve sooner). Used to dynamically allocate between strategy types as the volatility environment shifts.
+1 while ATR%-of-close is in the top high_pct of its trailing window; -1 while in the bottom low_pct; 0 otherwise.
+1 = high-volatility regime, -1 = compression regime, 0 = average regime.
period=14, window=252, high_pct=0.8, low_pct=0.2
Active short mean-reversion held — price tagged the upper band, exits at the midline.
| Score (0-100) | 0.03 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 0 |
| Last trigger date | 2026-05-11 |
| Triggers in last 60 bars | 36 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
| Last bar upper | 40.7527 |
| Last bar middle | 36.7638 |
| Last bar lower | 32.7748 |
Enters +1 when close ≤ lower band, holds until close ≥ middle band. Symmetric short-side state. Captures reversion-to-mean trades inside Bollinger bands — the trade is the move from the band back to the centre, not the breakout. Best in trending-but-noisy regimes where pullbacks cleanly retrace to the midline.
+1 enter on close ≤ lower band, exit on close ≥ middle. -1 enter on close ≥ upper, exit on close ≤ middle.
+1 = long mean-reversion held, -1 = short mean-reversion held, 0 = flat.
period=20, std=2
Price closed back inside the bands from above — short-term reversion-short signal. Stretched-up move snapping back.
| Score (0-100) | 12.40 |
|---|---|
| Weight | 1.000× |
| Last trigger value | -1.000 |
| Bars since trigger | 0 |
| Last trigger date | 2026-05-11 |
| Triggers in last 60 bars | 4 |
| Bars evaluated | 500 |
| Last bar value | 39.9850 |
| Last bar upper | 40.7527 |
| Last bar middle | 36.7638 |
| Last bar lower | 32.7748 |
Fires on the bar where the close returns inside the bands after the prior close was outside. Long reentry from below the lower band is a mean-reversion long trigger; short reentry from above the upper band is a mean-reversion short trigger. The reentry — not the initial breakout — is the actual signal, because it confirms the move is reversing back toward the mean.
+1 when prior close < lower band and current close inside; -1 when prior close > upper band and current close inside.
+1 = long-side reentry from oversold, -1 = short-side reentry from overbought.
period=20, std=2
Most-recent reported values. Bar shows where each value lands on the 0–100 absolute-band score, with ticks at the 40 / 55 / 70 verdict cutoffs.
Profitability
Valuation
Health
Growth & Yield
Quality