skills/financial-statement-analyzer/SKILL.md
Reads and normalizes a company's financial statements to extract clean valuation inputs. Performs accounting adjustments including R&D capitalization, operating lease conversion to debt, stock-based compensation treatment, and one-time item normalization. Computes FCFF, FCFE, and key financial ratios. Use when preparing financials for valuation, cleaning accounting data, computing free cash flows, analyzing financial ratios, or when user mentions financial statements, FCFF, FCFE, ROIC, R&D capitalization, or operating lease adjustment.
npx skillsauth add lyndonkl/claude financial-statement-analyzerInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Scenario: Technology company -- $2B revenue, $500M R&D, $100M annual operating lease payments
Raw financials (as reported):
Adjustment 1 -- R&D capitalization (5-year asset life):
| Year | R&D Spend | Amortization (1/5) | |------|-----------|-------------------| | Current | $500M | $100M | | Year -1 | $450M | $90M | | Year -2 | $400M | $80M | | Year -3 | $350M | $70M | | Year -4 | $300M | $60M |
Adjustment 2 -- Operating lease conversion:
Adjusted financials:
Ratio dashboard:
| Ratio | Reported | Adjusted | |-------|----------|----------| | Operating margin | 30.0% | 35.7% | | ROIC | 12.9% | 10.6% | | Debt-to-capital | 20.0% | 28.5% | | Reinvestment rate | 14.9% | 28.0% |
The adjustments reveal that the company reinvests more heavily than reported figures suggest (R&D is investment, not expense) and carries more leverage once lease obligations are recognized as debt.
Copy this checklist and track progress:
Financial Statement Analysis Progress:
- [ ] Step 1: Collect raw financial statements
- [ ] Step 2: Identify and apply accounting adjustments
- [ ] Step 3: Compute free cash flows (FCFF and FCFE)
- [ ] Step 4: Calculate key financial ratios
- [ ] Step 5: Compare to industry benchmarks
- [ ] Step 6: Validate and document
Step 1: Collect raw financial statements
Gather the three statements: income statement, balance sheet, and cash flow statement. Record at least two years for trend analysis. See resources/template.md for data input fields.
Step 2: Identify and apply accounting adjustments
Determine which adjustments apply based on company characteristics. See resources/methodology.md for step-by-step procedures for each adjustment type.
See resources/template.md for adjustment documentation format.
Step 3: Compute free cash flows
Calculate both FCFF and FCFE from adjusted figures. Verify they reconcile. See resources/methodology.md for detailed formulas and reconciliation.
Step 4: Calculate key financial ratios
Compute ratios from adjusted financials for a consistent picture. See resources/template.md for the full ratio dashboard.
Step 5: Compare to industry benchmarks
Place the company's adjusted ratios in context. See Quick Reference for benchmark ranges by sector.
Step 6: Validate and document
Review completeness and consistency. Validate using resources/evaluators/rubric_financial_statement_analyzer.json. Minimum standard: average score of 3.5 or above.
Pattern 1: Tech Company (Heavy R&D)
Pattern 2: Capital-Heavy Company (Leases and CapEx)
Pattern 3: Financial Services Company
special-situations-valuation skill handles this in depth.Pattern 4: Cyclical Company (Earnings Normalization)
R&D capitalization asset life: Use industry-appropriate asset lives. Software and internet: 2-3 years. Consumer products: 5-7 years. Pharmaceuticals: 8-10 years. Using the wrong life distorts both the research asset and adjusted income.
Operating lease discount rate: Discount future lease commitments at the pre-tax cost of debt, not WACC. The lease obligation is debt-like, so the discount rate should reflect the company's borrowing cost.
Separate operating from non-operating items: Cash and marketable securities are non-operating assets. Minority interests and cross-holdings need separate treatment. Do not mix operating and financial assets when computing invested capital.
Tax rate selection: Use marginal tax rate for FCFF computation (forward-looking). Use effective tax rate for historical ratio analysis. If the two diverge significantly, investigate why (tax loss carryforwards, foreign income, tax credits).
FCFF and FCFE reconciliation: FCFE should equal FCFF minus after-tax interest expense plus net debt issuance. If the two do not reconcile, there is an error in the computation. Check for missed items.
Stock-based compensation is a real cost: SBC reduces the value of existing shares through dilution. Do not add it back to compute "adjusted" earnings or cash flow. Treat it as an operating expense in the income statement.
Recurring "non-recurring" items: If a company reports restructuring charges in three of the past five years, these are not genuinely one-time. Normalize by averaging rather than excluding. Truly non-recurring items include asset write-downs from specific events, litigation settlements, and natural disaster impacts.
Document every adjustment: Each adjustment should include the pre-adjustment value, the post-adjustment value, and the rationale. This makes the analysis reproducible and allows others to disagree with specific adjustments without discarding the entire analysis.
Key formulas:
FCFF = After-tax Operating Income - (CapEx - Depreciation) - Change in Non-cash WC
FCFE = Net Income - (CapEx - Depreciation) - Change in WC - (Debt Repaid - Debt Issued)
Reinvestment Rate = (Net CapEx + Change in WC) / After-tax Operating Income
ROIC = After-tax Operating Income / Invested Capital
ROE = Net Income / Book Value of Equity
Debt-to-Capital = Total Debt / (Total Debt + Market Value of Equity)
Interest Coverage = EBIT / Interest Expense
Sales-to-Capital = Revenue / Invested Capital
R&D Capitalization:
Research Asset = Sum of unamortized R&D from past N years
Adjusted Operating Income = Reported OI + Current R&D - Total Amortization
Operating Lease Conversion:
Lease Debt = PV of future lease commitments at pre-tax cost of debt
Adjusted EBIT = Reported EBIT + Lease Expense - Depreciation of Lease Asset
Ratio benchmarks by sector (approximate medians):
| Metric | Tech | Industrial | Consumer | Healthcare | |--------|------|-----------|----------|------------| | Operating margin | 20-25% | 10-15% | 8-12% | 15-20% | | ROIC | 15-25% | 10-15% | 12-18% | 12-20% | | Debt-to-capital | 10-20% | 25-35% | 20-30% | 15-25% | | Reinvestment rate | 40-60% | 30-50% | 25-40% | 35-55% | | Sales-to-capital | 1.5-2.5 | 1.0-1.5 | 1.5-2.0 | 1.0-1.5 |
Key resources:
Inputs required:
Outputs produced:
development
--- name: zettel-note description: The note-writing discipline for this vault's evergreen knowledge graph, modeled on a Zettelkasten reading companion and governed by the vault conventions. Enforces declarative-claim titles, one claim per note (atomicity), own-words prose with no block quotes, the piped [[slug|Title]] link form, the labeled link-relationship vocabulary (Confirms/Contradicts/Extends/Context/Prerequisite/Builds-on/Applies/Example-of/Contrasts-with), 3-6 links per note, and search-
development
Plans between-round FIFA World Cup Fantasy transfers — budgets the round's free transfer(s), forces out players whose nation has been eliminated, chases fixture-swing drops, upgrades on value, and decides when a rebuild is large enough to fire the Wildcard instead of spending free transfers one at a time. Ranks candidate in/out pairs by EV gain over each player's remaining survival horizon (delta xEV weighted by progression_carry) MINUS transfer cost (a free transfer is cheap, a points hit is real, churning the squad for marginal swings is a critic flag), and tags forced/fixture/upgrade priority. Emits a `transfer-plan` signal. Use when called by wc-squad-architect (whose transfer work this skill is the engine for) and by the strategists in the populate stage when their candidate is transfer-adjacent rather than a full rebuild.
testing
Reads and updates the FIFA World Cup Fantasy tournament state machine (footballfantasy/context/tournament-state.md) — the temporal backbone tracking phase (pre-tournament → group MD1-3 → R32 → R16 → QF → SF → final), budget ($100m group / $105m knockouts), nation cap (3 group, loosening in knockouts), chips remaining, surviving nations, each owned player's elimination-risk horizon, and deadlines. Validates state on load (count/feasibility checks), applies phase transitions, and appends to the append-only state log (never silent overwrite). Use to load state at the start of a run and to commit state changes after the manager makes a move.
development
Validates and persists FIFA World Cup Fantasy signal files to signals/YYYY-MM-DD-<type>.md. Checks the required frontmatter (type, round, date, emitted_by, confidence, source_urls), range-checks declared numeric signals, confirms every factual claim carries a source URL or "manager-provided", rejects unknown signal types, and refuses to persist a signal that fails validation (logging the failure instead). Keeps the inter-agent signal layer auditable so downstream agents can trust what they read and never re-derive it. Use whenever an agent or skill writes a signal.